@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,1993 +1,1993 @@
|
|
|
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
|
-
var ApplicationShell_1;
|
|
18
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
exports.ApplicationShell = exports.DockPanelRenderer = exports.DockPanelRendererFactory = exports.ApplicationShellOptions = exports.applicationShellLayoutVersion = void 0;
|
|
20
|
-
const tslib_1 = require("tslib");
|
|
21
|
-
const inversify_1 = require("inversify");
|
|
22
|
-
const algorithm_1 = require("@phosphor/algorithm");
|
|
23
|
-
const widgets_1 = require("@phosphor/widgets");
|
|
24
|
-
const common_1 = require("../../common");
|
|
25
|
-
const browser_1 = require("../browser");
|
|
26
|
-
const saveable_1 = require("../saveable");
|
|
27
|
-
const status_bar_1 = require("../status-bar/status-bar");
|
|
28
|
-
const theia_dock_panel_1 = require("./theia-dock-panel");
|
|
29
|
-
const side_panel_handler_1 = require("./side-panel-handler");
|
|
30
|
-
const tab_bars_1 = require("./tab-bars");
|
|
31
|
-
const split_panels_1 = require("./split-panels");
|
|
32
|
-
const frontend_application_state_1 = require("../frontend-application-state");
|
|
33
|
-
const tab_bar_toolbar_1 = require("./tab-bar-toolbar");
|
|
34
|
-
const context_key_service_1 = require("../context-key-service");
|
|
35
|
-
const event_1 = require("../../common/event");
|
|
36
|
-
const widgets_2 = require("../widgets");
|
|
37
|
-
const core_preferences_1 = require("../core-preferences");
|
|
38
|
-
const breadcrumbs_renderer_1 = require("../breadcrumbs/breadcrumbs-renderer");
|
|
39
|
-
const promise_util_1 = require("../../common/promise-util");
|
|
40
|
-
const save_resource_service_1 = require("../save-resource-service");
|
|
41
|
-
const nls_1 = require("../../common/nls");
|
|
42
|
-
const secondary_window_handler_1 = require("../secondary-window-handler");
|
|
43
|
-
const uri_1 = require("../../common/uri");
|
|
44
|
-
const opener_service_1 = require("../opener-service");
|
|
45
|
-
const previewable_widget_1 = require("../widgets/previewable-widget");
|
|
46
|
-
const window_service_1 = require("../window/window-service");
|
|
47
|
-
/** The class name added to ApplicationShell instances. */
|
|
48
|
-
const APPLICATION_SHELL_CLASS = 'theia-ApplicationShell';
|
|
49
|
-
/** The class name added to the main and bottom area panels. */
|
|
50
|
-
const MAIN_BOTTOM_AREA_CLASS = 'theia-app-centers';
|
|
51
|
-
/** Status bar entry identifier for the bottom panel toggle button. */
|
|
52
|
-
const BOTTOM_PANEL_TOGGLE_ID = 'bottom-panel-toggle';
|
|
53
|
-
/** The class name added to the main area panel. */
|
|
54
|
-
const MAIN_AREA_CLASS = 'theia-app-main';
|
|
55
|
-
/** The class name added to the bottom area panel. */
|
|
56
|
-
const BOTTOM_AREA_CLASS = 'theia-app-bottom';
|
|
57
|
-
/**
|
|
58
|
-
* When a version is increased, make sure to introduce a migration (ApplicationShellLayoutMigration) to this version.
|
|
59
|
-
*/
|
|
60
|
-
exports.applicationShellLayoutVersion = 5.0;
|
|
61
|
-
exports.ApplicationShellOptions = Symbol('ApplicationShellOptions');
|
|
62
|
-
exports.DockPanelRendererFactory = Symbol('DockPanelRendererFactory');
|
|
63
|
-
/**
|
|
64
|
-
* A renderer for dock panels that supports context menus on tabs.
|
|
65
|
-
*/
|
|
66
|
-
let DockPanelRenderer = class DockPanelRenderer {
|
|
67
|
-
constructor(tabBarRendererFactory, tabBarToolbarRegistry, tabBarToolbarFactory, breadcrumbsRendererFactory, corePreferences) {
|
|
68
|
-
this.tabBarRendererFactory = tabBarRendererFactory;
|
|
69
|
-
this.tabBarToolbarRegistry = tabBarToolbarRegistry;
|
|
70
|
-
this.tabBarToolbarFactory = tabBarToolbarFactory;
|
|
71
|
-
this.breadcrumbsRendererFactory = breadcrumbsRendererFactory;
|
|
72
|
-
this.corePreferences = corePreferences;
|
|
73
|
-
this.tabBarClasses = [];
|
|
74
|
-
this.onDidCreateTabBarEmitter = new event_1.Emitter();
|
|
75
|
-
}
|
|
76
|
-
get onDidCreateTabBar() {
|
|
77
|
-
return this.onDidCreateTabBarEmitter.event;
|
|
78
|
-
}
|
|
79
|
-
createTabBar() {
|
|
80
|
-
const getDynamicTabOptions = () => {
|
|
81
|
-
if (this.corePreferences.get('workbench.tab.shrinkToFit.enabled')) {
|
|
82
|
-
return {
|
|
83
|
-
minimumTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.minimumSize'),
|
|
84
|
-
defaultTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.defaultSize')
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
return undefined;
|
|
89
|
-
}
|
|
90
|
-
};
|
|
91
|
-
const renderer = this.tabBarRendererFactory();
|
|
92
|
-
const tabBar = new tab_bars_1.ToolbarAwareTabBar(this.tabBarToolbarRegistry, this.tabBarToolbarFactory, this.breadcrumbsRendererFactory, {
|
|
93
|
-
renderer,
|
|
94
|
-
// Scroll bar options
|
|
95
|
-
handlers: ['drag-thumb', 'keyboard', 'wheel', 'touch'],
|
|
96
|
-
useBothWheelAxes: true,
|
|
97
|
-
scrollXMarginOffset: 4,
|
|
98
|
-
suppressScrollY: true
|
|
99
|
-
}, getDynamicTabOptions());
|
|
100
|
-
this.tabBarClasses.forEach(c => tabBar.addClass(c));
|
|
101
|
-
renderer.tabBar = tabBar;
|
|
102
|
-
renderer.contextMenuPath = tab_bars_1.SHELL_TABBAR_CONTEXT_MENU;
|
|
103
|
-
tabBar.currentChanged.connect(this.onCurrentTabChanged, this);
|
|
104
|
-
const prefChangeDisposable = this.corePreferences.onPreferenceChanged(change => {
|
|
105
|
-
if (change.preferenceName === 'workbench.tab.shrinkToFit.enabled' ||
|
|
106
|
-
change.preferenceName === 'workbench.tab.shrinkToFit.minimumSize' ||
|
|
107
|
-
change.preferenceName === 'workbench.tab.shrinkToFit.defaultSize') {
|
|
108
|
-
tabBar.dynamicTabOptions = getDynamicTabOptions();
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
tabBar.disposed.connect(() => {
|
|
112
|
-
prefChangeDisposable.dispose();
|
|
113
|
-
renderer.dispose();
|
|
114
|
-
});
|
|
115
|
-
this.onDidCreateTabBarEmitter.fire(tabBar);
|
|
116
|
-
return tabBar;
|
|
117
|
-
}
|
|
118
|
-
createHandle() {
|
|
119
|
-
return widgets_1.DockPanel.defaultRenderer.createHandle();
|
|
120
|
-
}
|
|
121
|
-
onCurrentTabChanged(sender, { currentIndex }) {
|
|
122
|
-
if (currentIndex >= 0) {
|
|
123
|
-
sender.revealTab(currentIndex);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
};
|
|
127
|
-
(0, tslib_1.__decorate)([
|
|
128
|
-
(0, inversify_1.inject)(theia_dock_panel_1.TheiaDockPanel.Factory),
|
|
129
|
-
(0, tslib_1.__metadata)("design:type", Function)
|
|
130
|
-
], DockPanelRenderer.prototype, "dockPanelFactory", void 0);
|
|
131
|
-
DockPanelRenderer = (0, tslib_1.__decorate)([
|
|
132
|
-
(0, inversify_1.injectable)(),
|
|
133
|
-
(0, tslib_1.__param)(0, (0, inversify_1.inject)(tab_bars_1.TabBarRendererFactory)),
|
|
134
|
-
(0, tslib_1.__param)(1, (0, inversify_1.inject)(tab_bar_toolbar_1.TabBarToolbarRegistry)),
|
|
135
|
-
(0, tslib_1.__param)(2, (0, inversify_1.inject)(tab_bar_toolbar_1.TabBarToolbarFactory)),
|
|
136
|
-
(0, tslib_1.__param)(3, (0, inversify_1.inject)(breadcrumbs_renderer_1.BreadcrumbsRendererFactory)),
|
|
137
|
-
(0, tslib_1.__param)(4, (0, inversify_1.inject)(core_preferences_1.CorePreferences)),
|
|
138
|
-
(0, tslib_1.__metadata)("design:paramtypes", [Function, tab_bar_toolbar_1.TabBarToolbarRegistry, Function, Function, Object])
|
|
139
|
-
], DockPanelRenderer);
|
|
140
|
-
exports.DockPanelRenderer = DockPanelRenderer;
|
|
141
|
-
/**
|
|
142
|
-
* The application shell manages the top-level widgets of the application. Use this class to
|
|
143
|
-
* add, remove, or activate a widget.
|
|
144
|
-
*/
|
|
145
|
-
let ApplicationShell = ApplicationShell_1 = class ApplicationShell extends widgets_1.Widget {
|
|
146
|
-
/**
|
|
147
|
-
* Construct a new application shell.
|
|
148
|
-
*/
|
|
149
|
-
constructor(dockPanelRendererFactory, statusBar, sidePanelHandlerFactory, splitPositionHandler, applicationStateService, options = {}, corePreferences, saveResourceService, secondaryWindowHandler, windowService) {
|
|
150
|
-
super(options);
|
|
151
|
-
this.dockPanelRendererFactory = dockPanelRendererFactory;
|
|
152
|
-
this.statusBar = statusBar;
|
|
153
|
-
this.sidePanelHandlerFactory = sidePanelHandlerFactory;
|
|
154
|
-
this.splitPositionHandler = splitPositionHandler;
|
|
155
|
-
this.applicationStateService = applicationStateService;
|
|
156
|
-
this.corePreferences = corePreferences;
|
|
157
|
-
this.saveResourceService = saveResourceService;
|
|
158
|
-
this.secondaryWindowHandler = secondaryWindowHandler;
|
|
159
|
-
this.windowService = windowService;
|
|
160
|
-
/**
|
|
161
|
-
* The current state of the bottom panel.
|
|
162
|
-
*/
|
|
163
|
-
this.bottomPanelState = {
|
|
164
|
-
empty: true,
|
|
165
|
-
expansion: side_panel_handler_1.SidePanel.ExpansionState.collapsed,
|
|
166
|
-
pendingUpdate: Promise.resolve()
|
|
167
|
-
};
|
|
168
|
-
this.tracker = new widgets_1.FocusTracker();
|
|
169
|
-
this.onDidAddWidgetEmitter = new event_1.Emitter();
|
|
170
|
-
this.onDidAddWidget = this.onDidAddWidgetEmitter.event;
|
|
171
|
-
this.onDidRemoveWidgetEmitter = new event_1.Emitter();
|
|
172
|
-
this.onDidRemoveWidget = this.onDidRemoveWidgetEmitter.event;
|
|
173
|
-
this.onDidChangeActiveWidgetEmitter = new event_1.Emitter();
|
|
174
|
-
this.onDidChangeActiveWidget = this.onDidChangeActiveWidgetEmitter.event;
|
|
175
|
-
this.onDidChangeCurrentWidgetEmitter = new event_1.Emitter();
|
|
176
|
-
this.onDidChangeCurrentWidget = this.onDidChangeCurrentWidgetEmitter.event;
|
|
177
|
-
this.onDidDoubleClickMainAreaEmitter = new event_1.Emitter();
|
|
178
|
-
this.onDidDoubleClickMainArea = this.onDidDoubleClickMainAreaEmitter.event;
|
|
179
|
-
this.toDisposeOnActiveChanged = new common_1.DisposableCollection();
|
|
180
|
-
this.activationTimeout = 2000;
|
|
181
|
-
this.toDisposeOnActivationCheck = new common_1.DisposableCollection();
|
|
182
|
-
// Merge the user-defined application options with the default options
|
|
183
|
-
this.options = {
|
|
184
|
-
bottomPanel: {
|
|
185
|
-
...ApplicationShell_1.DEFAULT_OPTIONS.bottomPanel,
|
|
186
|
-
...(options === null || options === void 0 ? void 0 : options.bottomPanel) || {}
|
|
187
|
-
},
|
|
188
|
-
leftPanel: {
|
|
189
|
-
...ApplicationShell_1.DEFAULT_OPTIONS.leftPanel,
|
|
190
|
-
...(options === null || options === void 0 ? void 0 : options.leftPanel) || {}
|
|
191
|
-
},
|
|
192
|
-
rightPanel: {
|
|
193
|
-
...ApplicationShell_1.DEFAULT_OPTIONS.rightPanel,
|
|
194
|
-
...(options === null || options === void 0 ? void 0 : options.rightPanel) || {}
|
|
195
|
-
}
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
fireDidAddWidget(widget) {
|
|
199
|
-
this.onDidAddWidgetEmitter.fire(widget);
|
|
200
|
-
}
|
|
201
|
-
fireDidRemoveWidget(widget) {
|
|
202
|
-
this.onDidRemoveWidgetEmitter.fire(widget);
|
|
203
|
-
}
|
|
204
|
-
get mainPanelRenderer() {
|
|
205
|
-
return this._mainPanelRenderer;
|
|
206
|
-
}
|
|
207
|
-
init() {
|
|
208
|
-
this.initializeShell();
|
|
209
|
-
this.initSidebarVisibleKeyContext();
|
|
210
|
-
this.initFocusKeyContexts();
|
|
211
|
-
if (!common_1.environment.electron.is()) {
|
|
212
|
-
this.corePreferences.ready.then(() => {
|
|
213
|
-
this.setTopPanelVisibility(this.corePreferences['window.menuBarVisibility']);
|
|
214
|
-
});
|
|
215
|
-
this.corePreferences.onPreferenceChanged(preference => {
|
|
216
|
-
if (preference.preferenceName === 'window.menuBarVisibility') {
|
|
217
|
-
this.setTopPanelVisibility(preference.newValue);
|
|
218
|
-
}
|
|
219
|
-
});
|
|
220
|
-
}
|
|
221
|
-
this.corePreferences.onPreferenceChanged(preference => {
|
|
222
|
-
if (preference.preferenceName === 'window.tabbar.enhancedPreview') {
|
|
223
|
-
this.allTabBars.forEach(tabBar => {
|
|
224
|
-
tabBar.update();
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
});
|
|
228
|
-
}
|
|
229
|
-
initializeShell() {
|
|
230
|
-
this.addClass(APPLICATION_SHELL_CLASS);
|
|
231
|
-
this.id = 'theia-app-shell';
|
|
232
|
-
this.mainPanel = this.createMainPanel();
|
|
233
|
-
this.topPanel = this.createTopPanel();
|
|
234
|
-
this.bottomPanel = this.createBottomPanel();
|
|
235
|
-
this.leftPanelHandler = this.sidePanelHandlerFactory();
|
|
236
|
-
this.leftPanelHandler.create('left', this.options.leftPanel);
|
|
237
|
-
this.leftPanelHandler.dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
238
|
-
this.leftPanelHandler.dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
239
|
-
this.rightPanelHandler = this.sidePanelHandlerFactory();
|
|
240
|
-
this.rightPanelHandler.create('right', this.options.rightPanel);
|
|
241
|
-
this.rightPanelHandler.dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
242
|
-
this.rightPanelHandler.dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
243
|
-
this.secondaryWindowHandler.init(this);
|
|
244
|
-
this.secondaryWindowHandler.onDidAddWidget(([widget, window]) => this.fireDidAddWidget(widget));
|
|
245
|
-
this.secondaryWindowHandler.onDidRemoveWidget(([widget, window]) => this.fireDidRemoveWidget(widget));
|
|
246
|
-
this.layout = this.createLayout();
|
|
247
|
-
this.tracker.currentChanged.connect(this.onCurrentChanged, this);
|
|
248
|
-
this.tracker.activeChanged.connect(this.onActiveChanged, this);
|
|
249
|
-
}
|
|
250
|
-
initSidebarVisibleKeyContext() {
|
|
251
|
-
const leftSideBarPanel = this.leftPanelHandler.dockPanel;
|
|
252
|
-
const sidebarVisibleKey = this.contextKeyService.createKey('sidebarVisible', leftSideBarPanel.isVisible);
|
|
253
|
-
const onAfterShow = leftSideBarPanel['onAfterShow'].bind(leftSideBarPanel);
|
|
254
|
-
leftSideBarPanel['onAfterShow'] = (msg) => {
|
|
255
|
-
onAfterShow(msg);
|
|
256
|
-
sidebarVisibleKey.set(true);
|
|
257
|
-
};
|
|
258
|
-
const onAfterHide = leftSideBarPanel['onAfterHide'].bind(leftSideBarPanel);
|
|
259
|
-
leftSideBarPanel['onAfterHide'] = (msg) => {
|
|
260
|
-
onAfterHide(msg);
|
|
261
|
-
sidebarVisibleKey.set(false);
|
|
262
|
-
};
|
|
263
|
-
}
|
|
264
|
-
initFocusKeyContexts() {
|
|
265
|
-
const sideBarFocus = this.contextKeyService.createKey('sideBarFocus', false);
|
|
266
|
-
const panelFocus = this.contextKeyService.createKey('panelFocus', false);
|
|
267
|
-
const updateFocusContextKeys = () => {
|
|
268
|
-
const area = this.activeWidget && this.getAreaFor(this.activeWidget);
|
|
269
|
-
sideBarFocus.set(area === 'left');
|
|
270
|
-
panelFocus.set(area === 'main');
|
|
271
|
-
};
|
|
272
|
-
updateFocusContextKeys();
|
|
273
|
-
this.onDidChangeActiveWidget(updateFocusContextKeys);
|
|
274
|
-
}
|
|
275
|
-
setTopPanelVisibility(preference) {
|
|
276
|
-
const hiddenPreferences = ['compact', 'hidden'];
|
|
277
|
-
this.topPanel.setHidden(hiddenPreferences.includes(preference));
|
|
278
|
-
}
|
|
279
|
-
onBeforeAttach(msg) {
|
|
280
|
-
document.addEventListener('p-dragenter', this, true);
|
|
281
|
-
document.addEventListener('p-dragover', this, true);
|
|
282
|
-
document.addEventListener('p-dragleave', this, true);
|
|
283
|
-
document.addEventListener('p-drop', this, true);
|
|
284
|
-
}
|
|
285
|
-
onAfterDetach(msg) {
|
|
286
|
-
document.removeEventListener('p-dragenter', this, true);
|
|
287
|
-
document.removeEventListener('p-dragover', this, true);
|
|
288
|
-
document.removeEventListener('p-dragleave', this, true);
|
|
289
|
-
document.removeEventListener('p-drop', this, true);
|
|
290
|
-
}
|
|
291
|
-
handleEvent(event) {
|
|
292
|
-
switch (event.type) {
|
|
293
|
-
case 'p-dragenter':
|
|
294
|
-
this.onDragEnter(event);
|
|
295
|
-
break;
|
|
296
|
-
case 'p-dragover':
|
|
297
|
-
this.onDragOver(event);
|
|
298
|
-
break;
|
|
299
|
-
case 'p-drop':
|
|
300
|
-
this.onDrop(event);
|
|
301
|
-
break;
|
|
302
|
-
case 'p-dragleave':
|
|
303
|
-
this.onDragLeave(event);
|
|
304
|
-
break;
|
|
305
|
-
}
|
|
306
|
-
}
|
|
307
|
-
onDragEnter({ mimeData }) {
|
|
308
|
-
if (!this.dragState) {
|
|
309
|
-
if (mimeData && mimeData.hasData('application/vnd.phosphor.widget-factory')) {
|
|
310
|
-
// The drag contains a widget, so we'll track it and expand side panels as needed
|
|
311
|
-
this.dragState = {
|
|
312
|
-
startTime: performance.now(),
|
|
313
|
-
leftExpanded: false,
|
|
314
|
-
rightExpanded: false,
|
|
315
|
-
bottomExpanded: false
|
|
316
|
-
};
|
|
317
|
-
}
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
onDragOver(event) {
|
|
321
|
-
const state = this.dragState;
|
|
322
|
-
if (state) {
|
|
323
|
-
state.lastDragOver = event;
|
|
324
|
-
if (state.leaveTimeout) {
|
|
325
|
-
window.clearTimeout(state.leaveTimeout);
|
|
326
|
-
state.leaveTimeout = undefined;
|
|
327
|
-
}
|
|
328
|
-
const { clientX, clientY } = event;
|
|
329
|
-
const { offsetLeft, offsetTop, clientWidth, clientHeight } = this.node;
|
|
330
|
-
// Don't expand any side panels right after the drag has started
|
|
331
|
-
const allowExpansion = performance.now() - state.startTime >= 500;
|
|
332
|
-
const expLeft = allowExpansion && clientX >= offsetLeft
|
|
333
|
-
&& clientX <= offsetLeft + this.options.leftPanel.expandThreshold;
|
|
334
|
-
const expRight = allowExpansion && clientX <= offsetLeft + clientWidth
|
|
335
|
-
&& clientX >= offsetLeft + clientWidth - this.options.rightPanel.expandThreshold;
|
|
336
|
-
const expBottom = allowExpansion && !expLeft && !expRight && clientY <= offsetTop + clientHeight
|
|
337
|
-
&& clientY >= offsetTop + clientHeight - this.options.bottomPanel.expandThreshold;
|
|
338
|
-
// eslint-disable-next-line no-null/no-null
|
|
339
|
-
if (expLeft && !state.leftExpanded && this.leftPanelHandler.tabBar.currentTitle === null) {
|
|
340
|
-
// The mouse cursor is moved close to the left border
|
|
341
|
-
this.leftPanelHandler.expand();
|
|
342
|
-
this.leftPanelHandler.state.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
343
|
-
state.leftExpanded = true;
|
|
344
|
-
}
|
|
345
|
-
else if (!expLeft && state.leftExpanded) {
|
|
346
|
-
// The mouse cursor is moved away from the left border
|
|
347
|
-
this.leftPanelHandler.collapse();
|
|
348
|
-
state.leftExpanded = false;
|
|
349
|
-
}
|
|
350
|
-
// eslint-disable-next-line no-null/no-null
|
|
351
|
-
if (expRight && !state.rightExpanded && this.rightPanelHandler.tabBar.currentTitle === null) {
|
|
352
|
-
// The mouse cursor is moved close to the right border
|
|
353
|
-
this.rightPanelHandler.expand();
|
|
354
|
-
this.rightPanelHandler.state.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
355
|
-
state.rightExpanded = true;
|
|
356
|
-
}
|
|
357
|
-
else if (!expRight && state.rightExpanded) {
|
|
358
|
-
// The mouse cursor is moved away from the right border
|
|
359
|
-
this.rightPanelHandler.collapse();
|
|
360
|
-
state.rightExpanded = false;
|
|
361
|
-
}
|
|
362
|
-
if (expBottom && !state.bottomExpanded && this.bottomPanel.isHidden) {
|
|
363
|
-
// The mouse cursor is moved close to the bottom border
|
|
364
|
-
this.expandBottomPanel();
|
|
365
|
-
this.bottomPanelState.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
366
|
-
state.bottomExpanded = true;
|
|
367
|
-
}
|
|
368
|
-
else if (!expBottom && state.bottomExpanded) {
|
|
369
|
-
// The mouse cursor is moved away from the bottom border
|
|
370
|
-
this.collapseBottomPanel();
|
|
371
|
-
state.bottomExpanded = false;
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
}
|
|
375
|
-
/**
|
|
376
|
-
* This method is called after a side panel has been expanded while dragging a widget. It fires
|
|
377
|
-
* a `mousemove` event so that the drag overlay markers are updated correctly in all dock panels.
|
|
378
|
-
*/
|
|
379
|
-
dispatchMouseMove() {
|
|
380
|
-
if (this.dragState && this.dragState.lastDragOver) {
|
|
381
|
-
const { clientX, clientY } = this.dragState.lastDragOver;
|
|
382
|
-
const event = document.createEvent('MouseEvent');
|
|
383
|
-
event.initMouseEvent('mousemove', true, true, window, 0, 0, 0,
|
|
384
|
-
// eslint-disable-next-line no-null/no-null
|
|
385
|
-
clientX, clientY, false, false, false, false, 0, null);
|
|
386
|
-
document.dispatchEvent(event);
|
|
387
|
-
}
|
|
388
|
-
}
|
|
389
|
-
onDrop(event) {
|
|
390
|
-
const state = this.dragState;
|
|
391
|
-
if (state) {
|
|
392
|
-
if (state.leaveTimeout) {
|
|
393
|
-
window.clearTimeout(state.leaveTimeout);
|
|
394
|
-
}
|
|
395
|
-
this.dragState = undefined;
|
|
396
|
-
window.requestAnimationFrame(() => {
|
|
397
|
-
// Clean up the side panel state in the next frame
|
|
398
|
-
if (this.leftPanelHandler.dockPanel.isEmpty) {
|
|
399
|
-
this.leftPanelHandler.collapse();
|
|
400
|
-
}
|
|
401
|
-
if (this.rightPanelHandler.dockPanel.isEmpty) {
|
|
402
|
-
this.rightPanelHandler.collapse();
|
|
403
|
-
}
|
|
404
|
-
if (this.bottomPanel.isEmpty) {
|
|
405
|
-
this.collapseBottomPanel();
|
|
406
|
-
}
|
|
407
|
-
});
|
|
408
|
-
}
|
|
409
|
-
}
|
|
410
|
-
onDragLeave(event) {
|
|
411
|
-
const state = this.dragState;
|
|
412
|
-
if (state) {
|
|
413
|
-
state.lastDragOver = undefined;
|
|
414
|
-
if (state.leaveTimeout) {
|
|
415
|
-
window.clearTimeout(state.leaveTimeout);
|
|
416
|
-
}
|
|
417
|
-
state.leaveTimeout = window.setTimeout(() => {
|
|
418
|
-
this.dragState = undefined;
|
|
419
|
-
if (state.leftExpanded || this.leftPanelHandler.dockPanel.isEmpty) {
|
|
420
|
-
this.leftPanelHandler.collapse();
|
|
421
|
-
}
|
|
422
|
-
if (state.rightExpanded || this.rightPanelHandler.dockPanel.isEmpty) {
|
|
423
|
-
this.rightPanelHandler.collapse();
|
|
424
|
-
}
|
|
425
|
-
if (state.bottomExpanded || this.bottomPanel.isEmpty) {
|
|
426
|
-
this.collapseBottomPanel();
|
|
427
|
-
}
|
|
428
|
-
}, 100);
|
|
429
|
-
}
|
|
430
|
-
}
|
|
431
|
-
/**
|
|
432
|
-
* Create the dock panel in the main shell area.
|
|
433
|
-
*/
|
|
434
|
-
createMainPanel() {
|
|
435
|
-
const renderer = this.dockPanelRendererFactory();
|
|
436
|
-
renderer.tabBarClasses.push(MAIN_BOTTOM_AREA_CLASS);
|
|
437
|
-
renderer.tabBarClasses.push(MAIN_AREA_CLASS);
|
|
438
|
-
this._mainPanelRenderer = renderer;
|
|
439
|
-
const dockPanel = this.dockPanelFactory({
|
|
440
|
-
mode: 'multiple-document',
|
|
441
|
-
renderer,
|
|
442
|
-
spacing: 0
|
|
443
|
-
});
|
|
444
|
-
dockPanel.id = theia_dock_panel_1.MAIN_AREA_ID;
|
|
445
|
-
dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
446
|
-
dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
447
|
-
const openUri = async (fileUri) => {
|
|
448
|
-
try {
|
|
449
|
-
const opener = await this.openerService.getOpener(fileUri);
|
|
450
|
-
opener.open(fileUri);
|
|
451
|
-
}
|
|
452
|
-
catch (e) {
|
|
453
|
-
console.info(`no opener found for '${fileUri}'`);
|
|
454
|
-
}
|
|
455
|
-
};
|
|
456
|
-
dockPanel.node.addEventListener('drop', event => {
|
|
457
|
-
var _a;
|
|
458
|
-
if (event.dataTransfer) {
|
|
459
|
-
const uris = this.additionalDraggedUris || ApplicationShell_1.getDraggedEditorUris(event.dataTransfer);
|
|
460
|
-
if (uris.length > 0) {
|
|
461
|
-
uris.forEach(openUri);
|
|
462
|
-
}
|
|
463
|
-
else if (((_a = event.dataTransfer.files) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
464
|
-
// the files were dragged from the outside the workspace
|
|
465
|
-
Array.from(event.dataTransfer.files).forEach(file => {
|
|
466
|
-
if (file.path) {
|
|
467
|
-
const fileUri = uri_1.default.fromComponents({
|
|
468
|
-
scheme: 'file',
|
|
469
|
-
path: file.path,
|
|
470
|
-
authority: '',
|
|
471
|
-
query: '',
|
|
472
|
-
fragment: ''
|
|
473
|
-
});
|
|
474
|
-
openUri(fileUri);
|
|
475
|
-
}
|
|
476
|
-
});
|
|
477
|
-
}
|
|
478
|
-
}
|
|
479
|
-
});
|
|
480
|
-
dockPanel.node.addEventListener('dblclick', event => {
|
|
481
|
-
const el = event.target;
|
|
482
|
-
if (el.id === theia_dock_panel_1.MAIN_AREA_ID || el.classList.contains('p-TabBar-content')) {
|
|
483
|
-
this.onDidDoubleClickMainAreaEmitter.fire();
|
|
484
|
-
}
|
|
485
|
-
});
|
|
486
|
-
const handler = (e) => {
|
|
487
|
-
if (e.dataTransfer) {
|
|
488
|
-
e.dataTransfer.dropEffect = 'link';
|
|
489
|
-
e.preventDefault();
|
|
490
|
-
e.stopPropagation();
|
|
491
|
-
}
|
|
492
|
-
};
|
|
493
|
-
dockPanel.node.addEventListener('dragover', handler);
|
|
494
|
-
dockPanel.node.addEventListener('dragenter', handler);
|
|
495
|
-
return dockPanel;
|
|
496
|
-
}
|
|
497
|
-
addAdditionalDraggedEditorUris(uris) {
|
|
498
|
-
this.additionalDraggedUris = uris;
|
|
499
|
-
}
|
|
500
|
-
clearAdditionalDraggedEditorUris() {
|
|
501
|
-
this.additionalDraggedUris = undefined;
|
|
502
|
-
}
|
|
503
|
-
static getDraggedEditorUris(dataTransfer) {
|
|
504
|
-
const data = dataTransfer.getData('theia-editor-dnd');
|
|
505
|
-
return data ? data.split('\n').map(entry => new uri_1.default(entry)) : [];
|
|
506
|
-
}
|
|
507
|
-
static setDraggedEditorUris(dataTransfer, uris) {
|
|
508
|
-
dataTransfer.setData('theia-editor-dnd', uris.map(uri => uri.toString()).join('\n'));
|
|
509
|
-
}
|
|
510
|
-
/**
|
|
511
|
-
* Create the dock panel in the bottom shell area.
|
|
512
|
-
*/
|
|
513
|
-
createBottomPanel() {
|
|
514
|
-
const renderer = this.dockPanelRendererFactory();
|
|
515
|
-
renderer.tabBarClasses.push(MAIN_BOTTOM_AREA_CLASS);
|
|
516
|
-
renderer.tabBarClasses.push(BOTTOM_AREA_CLASS);
|
|
517
|
-
const dockPanel = this.dockPanelFactory({
|
|
518
|
-
mode: 'multiple-document',
|
|
519
|
-
renderer,
|
|
520
|
-
spacing: 0
|
|
521
|
-
});
|
|
522
|
-
dockPanel.id = theia_dock_panel_1.BOTTOM_AREA_ID;
|
|
523
|
-
dockPanel.widgetAdded.connect((sender, widget) => {
|
|
524
|
-
this.refreshBottomPanelToggleButton();
|
|
525
|
-
});
|
|
526
|
-
dockPanel.widgetRemoved.connect((sender, widget) => {
|
|
527
|
-
if (sender.isEmpty) {
|
|
528
|
-
this.collapseBottomPanel();
|
|
529
|
-
}
|
|
530
|
-
this.refreshBottomPanelToggleButton();
|
|
531
|
-
}, this);
|
|
532
|
-
dockPanel.node.addEventListener('p-dragenter', event => {
|
|
533
|
-
// Make sure that the main panel hides its overlay when the bottom panel is expanded
|
|
534
|
-
this.mainPanel.overlay.hide(0);
|
|
535
|
-
});
|
|
536
|
-
dockPanel.hide();
|
|
537
|
-
dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
538
|
-
dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
539
|
-
return dockPanel;
|
|
540
|
-
}
|
|
541
|
-
/**
|
|
542
|
-
* Create the top panel, which is used to hold the main menu.
|
|
543
|
-
*/
|
|
544
|
-
createTopPanel() {
|
|
545
|
-
const topPanel = new widgets_1.Panel();
|
|
546
|
-
topPanel.id = 'theia-top-panel';
|
|
547
|
-
topPanel.hide();
|
|
548
|
-
return topPanel;
|
|
549
|
-
}
|
|
550
|
-
/**
|
|
551
|
-
* Create a box layout to assemble the application shell layout.
|
|
552
|
-
*/
|
|
553
|
-
createBoxLayout(widgets, stretch, options) {
|
|
554
|
-
const boxLayout = new widgets_1.BoxLayout(options);
|
|
555
|
-
for (let i = 0; i < widgets.length; i++) {
|
|
556
|
-
if (stretch !== undefined && i < stretch.length) {
|
|
557
|
-
widgets_1.BoxPanel.setStretch(widgets[i], stretch[i]);
|
|
558
|
-
}
|
|
559
|
-
boxLayout.addWidget(widgets[i]);
|
|
560
|
-
}
|
|
561
|
-
return boxLayout;
|
|
562
|
-
}
|
|
563
|
-
/**
|
|
564
|
-
* Create a split layout to assemble the application shell layout.
|
|
565
|
-
*/
|
|
566
|
-
createSplitLayout(widgets, stretch, options) {
|
|
567
|
-
let optParam = { renderer: widgets_1.SplitPanel.defaultRenderer, };
|
|
568
|
-
if (options) {
|
|
569
|
-
optParam = { ...optParam, ...options };
|
|
570
|
-
}
|
|
571
|
-
const splitLayout = new widgets_1.SplitLayout(optParam);
|
|
572
|
-
for (let i = 0; i < widgets.length; i++) {
|
|
573
|
-
if (stretch !== undefined && i < stretch.length) {
|
|
574
|
-
widgets_1.SplitPanel.setStretch(widgets[i], stretch[i]);
|
|
575
|
-
}
|
|
576
|
-
splitLayout.addWidget(widgets[i]);
|
|
577
|
-
}
|
|
578
|
-
return splitLayout;
|
|
579
|
-
}
|
|
580
|
-
/**
|
|
581
|
-
* Assemble the application shell layout. Override this method in order to change the arrangement
|
|
582
|
-
* of the main area and the side panels.
|
|
583
|
-
*/
|
|
584
|
-
createLayout() {
|
|
585
|
-
const bottomSplitLayout = this.createSplitLayout([this.mainPanel, this.bottomPanel], [1, 0], { orientation: 'vertical', spacing: 0 });
|
|
586
|
-
const panelForBottomArea = new widgets_1.SplitPanel({ layout: bottomSplitLayout });
|
|
587
|
-
panelForBottomArea.id = 'theia-bottom-split-panel';
|
|
588
|
-
const leftRightSplitLayout = this.createSplitLayout([this.leftPanelHandler.container, panelForBottomArea, this.rightPanelHandler.container], [0, 1, 0], { orientation: 'horizontal', spacing: 0 });
|
|
589
|
-
const panelForSideAreas = new widgets_1.SplitPanel({ layout: leftRightSplitLayout });
|
|
590
|
-
panelForSideAreas.id = 'theia-left-right-split-panel';
|
|
591
|
-
return this.createBoxLayout([this.topPanel, panelForSideAreas, this.statusBar], [0, 1, 0], { direction: 'top-to-bottom', spacing: 0 });
|
|
592
|
-
}
|
|
593
|
-
/**
|
|
594
|
-
* Create an object that describes the current shell layout. This object may contain references
|
|
595
|
-
* to widgets; these need to be transformed before the layout can be serialized.
|
|
596
|
-
*/
|
|
597
|
-
getLayoutData() {
|
|
598
|
-
return {
|
|
599
|
-
version: exports.applicationShellLayoutVersion,
|
|
600
|
-
mainPanel: this.mainPanel.saveLayout(),
|
|
601
|
-
mainPanelPinned: this.getPinnedMainWidgets(),
|
|
602
|
-
bottomPanel: {
|
|
603
|
-
config: this.bottomPanel.saveLayout(),
|
|
604
|
-
pinned: this.getPinnedBottomWidgets(),
|
|
605
|
-
size: this.bottomPanel.isVisible ? this.getBottomPanelSize() : this.bottomPanelState.lastPanelSize,
|
|
606
|
-
expanded: this.isExpanded('bottom')
|
|
607
|
-
},
|
|
608
|
-
leftPanel: this.leftPanelHandler.getLayoutData(),
|
|
609
|
-
rightPanel: this.rightPanelHandler.getLayoutData(),
|
|
610
|
-
activeWidgetId: this.activeWidget ? this.activeWidget.id : undefined
|
|
611
|
-
};
|
|
612
|
-
}
|
|
613
|
-
// Get an array corresponding to main panel widgets' pinned state.
|
|
614
|
-
getPinnedMainWidgets() {
|
|
615
|
-
const pinned = [];
|
|
616
|
-
(0, algorithm_1.toArray)(this.mainPanel.widgets()).forEach((a, i) => {
|
|
617
|
-
pinned[i] = a.title.className.includes(widgets_2.PINNED_CLASS);
|
|
618
|
-
});
|
|
619
|
-
return pinned;
|
|
620
|
-
}
|
|
621
|
-
// Get an array corresponding to bottom panel widgets' pinned state.
|
|
622
|
-
getPinnedBottomWidgets() {
|
|
623
|
-
const pinned = [];
|
|
624
|
-
(0, algorithm_1.toArray)(this.bottomPanel.widgets()).forEach((a, i) => {
|
|
625
|
-
pinned[i] = a.title.className.includes(widgets_2.PINNED_CLASS);
|
|
626
|
-
});
|
|
627
|
-
return pinned;
|
|
628
|
-
}
|
|
629
|
-
/**
|
|
630
|
-
* Compute the current height of the bottom panel. This implementation assumes that the container
|
|
631
|
-
* of the bottom panel is a `SplitPanel`.
|
|
632
|
-
*/
|
|
633
|
-
getBottomPanelSize() {
|
|
634
|
-
const parent = this.bottomPanel.parent;
|
|
635
|
-
if (parent instanceof widgets_1.SplitPanel && parent.isVisible) {
|
|
636
|
-
const index = parent.widgets.indexOf(this.bottomPanel) - 1;
|
|
637
|
-
if (index >= 0) {
|
|
638
|
-
const handle = parent.handles[index];
|
|
639
|
-
if (!handle.classList.contains('p-mod-hidden')) {
|
|
640
|
-
const parentHeight = parent.node.clientHeight;
|
|
641
|
-
return parentHeight - handle.offsetTop;
|
|
642
|
-
}
|
|
643
|
-
}
|
|
644
|
-
}
|
|
645
|
-
}
|
|
646
|
-
/**
|
|
647
|
-
* Determine the default size to apply when the bottom panel is expanded for the first time.
|
|
648
|
-
*/
|
|
649
|
-
getDefaultBottomPanelSize() {
|
|
650
|
-
const parent = this.bottomPanel.parent;
|
|
651
|
-
if (parent && parent.isVisible) {
|
|
652
|
-
return parent.node.clientHeight * this.options.bottomPanel.initialSizeRatio;
|
|
653
|
-
}
|
|
654
|
-
}
|
|
655
|
-
/**
|
|
656
|
-
* Apply a shell layout that has been previously created with `getLayoutData`.
|
|
657
|
-
*/
|
|
658
|
-
async setLayoutData(layoutData) {
|
|
659
|
-
var _a, _b;
|
|
660
|
-
const { mainPanel, mainPanelPinned, bottomPanel, leftPanel, rightPanel, activeWidgetId } = layoutData;
|
|
661
|
-
if (leftPanel) {
|
|
662
|
-
this.leftPanelHandler.setLayoutData(leftPanel);
|
|
663
|
-
this.registerWithFocusTracker(leftPanel);
|
|
664
|
-
}
|
|
665
|
-
if (rightPanel) {
|
|
666
|
-
this.rightPanelHandler.setLayoutData(rightPanel);
|
|
667
|
-
this.registerWithFocusTracker(rightPanel);
|
|
668
|
-
}
|
|
669
|
-
// Proceed with the bottom panel once the side panels are set up
|
|
670
|
-
await Promise.all([this.leftPanelHandler.state.pendingUpdate, this.rightPanelHandler.state.pendingUpdate]);
|
|
671
|
-
if (bottomPanel) {
|
|
672
|
-
if (bottomPanel.config) {
|
|
673
|
-
this.bottomPanel.restoreLayout(bottomPanel.config);
|
|
674
|
-
this.registerWithFocusTracker(bottomPanel.config.main);
|
|
675
|
-
}
|
|
676
|
-
if (bottomPanel.size) {
|
|
677
|
-
this.bottomPanelState.lastPanelSize = bottomPanel.size;
|
|
678
|
-
}
|
|
679
|
-
if (bottomPanel.expanded) {
|
|
680
|
-
this.expandBottomPanel();
|
|
681
|
-
}
|
|
682
|
-
else {
|
|
683
|
-
this.collapseBottomPanel();
|
|
684
|
-
}
|
|
685
|
-
const widgets = (0, algorithm_1.toArray)(this.bottomPanel.widgets());
|
|
686
|
-
this.bottomPanel.markActiveTabBar((_a = widgets[0]) === null || _a === void 0 ? void 0 : _a.title);
|
|
687
|
-
if (bottomPanel.pinned && bottomPanel.pinned.length === widgets.length) {
|
|
688
|
-
widgets.forEach((a, i) => {
|
|
689
|
-
if (bottomPanel.pinned[i]) {
|
|
690
|
-
a.title.className += ` ${widgets_2.PINNED_CLASS}`;
|
|
691
|
-
a.title.closable = false;
|
|
692
|
-
}
|
|
693
|
-
});
|
|
694
|
-
}
|
|
695
|
-
this.refreshBottomPanelToggleButton();
|
|
696
|
-
}
|
|
697
|
-
// Proceed with the main panel once all others are set up
|
|
698
|
-
await this.bottomPanelState.pendingUpdate;
|
|
699
|
-
if (mainPanel) {
|
|
700
|
-
this.mainPanel.restoreLayout(mainPanel);
|
|
701
|
-
this.registerWithFocusTracker(mainPanel.main);
|
|
702
|
-
const widgets = (0, algorithm_1.toArray)(this.mainPanel.widgets());
|
|
703
|
-
// We don't store information about the last active tabbar
|
|
704
|
-
// So we simply mark the first as being active
|
|
705
|
-
this.mainPanel.markActiveTabBar((_b = widgets[0]) === null || _b === void 0 ? void 0 : _b.title);
|
|
706
|
-
if (mainPanelPinned && mainPanelPinned.length === widgets.length) {
|
|
707
|
-
widgets.forEach((a, i) => {
|
|
708
|
-
if (mainPanelPinned[i]) {
|
|
709
|
-
a.title.className += ` ${widgets_2.PINNED_CLASS}`;
|
|
710
|
-
a.title.closable = false;
|
|
711
|
-
}
|
|
712
|
-
});
|
|
713
|
-
}
|
|
714
|
-
}
|
|
715
|
-
if (activeWidgetId) {
|
|
716
|
-
this.activateWidget(activeWidgetId);
|
|
717
|
-
}
|
|
718
|
-
}
|
|
719
|
-
/**
|
|
720
|
-
* Modify the height of the bottom panel. This implementation assumes that the container of the
|
|
721
|
-
* bottom panel is a `SplitPanel`.
|
|
722
|
-
*/
|
|
723
|
-
setBottomPanelSize(size) {
|
|
724
|
-
const enableAnimation = this.applicationStateService.state === 'ready';
|
|
725
|
-
const options = {
|
|
726
|
-
side: 'bottom',
|
|
727
|
-
duration: enableAnimation ? this.options.bottomPanel.expandDuration : 0,
|
|
728
|
-
referenceWidget: this.bottomPanel
|
|
729
|
-
};
|
|
730
|
-
const promise = this.splitPositionHandler.setSidePanelSize(this.bottomPanel, size, options);
|
|
731
|
-
const result = new Promise(resolve => {
|
|
732
|
-
// Resolve the resulting promise in any case, regardless of whether resizing was successful
|
|
733
|
-
promise.then(() => resolve(), () => resolve());
|
|
734
|
-
});
|
|
735
|
-
this.bottomPanelState.pendingUpdate = this.bottomPanelState.pendingUpdate.then(() => result);
|
|
736
|
-
return result;
|
|
737
|
-
}
|
|
738
|
-
/**
|
|
739
|
-
* A promise that is resolved when all currently pending updates are done.
|
|
740
|
-
*/
|
|
741
|
-
get pendingUpdates() {
|
|
742
|
-
return Promise.all([
|
|
743
|
-
this.bottomPanelState.pendingUpdate,
|
|
744
|
-
this.leftPanelHandler.state.pendingUpdate,
|
|
745
|
-
this.rightPanelHandler.state.pendingUpdate
|
|
746
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
747
|
-
]);
|
|
748
|
-
}
|
|
749
|
-
/**
|
|
750
|
-
* Track all widgets that are referenced by the given layout data.
|
|
751
|
-
*/
|
|
752
|
-
registerWithFocusTracker(data) {
|
|
753
|
-
if (data) {
|
|
754
|
-
if (data.type === 'tab-area') {
|
|
755
|
-
for (const widget of data.widgets) {
|
|
756
|
-
if (widget) {
|
|
757
|
-
this.track(widget);
|
|
758
|
-
}
|
|
759
|
-
}
|
|
760
|
-
}
|
|
761
|
-
else if (data.type === 'split-area') {
|
|
762
|
-
for (const child of data.children) {
|
|
763
|
-
this.registerWithFocusTracker(child);
|
|
764
|
-
}
|
|
765
|
-
}
|
|
766
|
-
else if (data.type === 'sidepanel' && data.items) {
|
|
767
|
-
for (const item of data.items) {
|
|
768
|
-
if (item.widget) {
|
|
769
|
-
this.track(item.widget);
|
|
770
|
-
}
|
|
771
|
-
}
|
|
772
|
-
}
|
|
773
|
-
}
|
|
774
|
-
}
|
|
775
|
-
/**
|
|
776
|
-
* Add a widget to the application shell. The given widget must have a unique `id` property,
|
|
777
|
-
* which will be used as the DOM id.
|
|
778
|
-
*
|
|
779
|
-
* Widgets are removed from the shell by calling their `close` or `dispose` methods.
|
|
780
|
-
*
|
|
781
|
-
* Widgets added to the top area are not tracked regarding the _current_ and _active_ states.
|
|
782
|
-
*/
|
|
783
|
-
async addWidget(widget, options) {
|
|
784
|
-
if (!widget.id) {
|
|
785
|
-
console.error('Widgets added to the application shell must have a unique id property.');
|
|
786
|
-
return;
|
|
787
|
-
}
|
|
788
|
-
const { area, addOptions } = this.getInsertionOptions(options);
|
|
789
|
-
const sidePanelOptions = { rank: options === null || options === void 0 ? void 0 : options.rank };
|
|
790
|
-
switch (area) {
|
|
791
|
-
case 'main':
|
|
792
|
-
this.mainPanel.addWidget(widget, addOptions);
|
|
793
|
-
break;
|
|
794
|
-
case 'top':
|
|
795
|
-
this.topPanel.addWidget(widget);
|
|
796
|
-
break;
|
|
797
|
-
case 'bottom':
|
|
798
|
-
this.bottomPanel.addWidget(widget, addOptions);
|
|
799
|
-
break;
|
|
800
|
-
case 'left':
|
|
801
|
-
this.leftPanelHandler.addWidget(widget, sidePanelOptions);
|
|
802
|
-
break;
|
|
803
|
-
case 'right':
|
|
804
|
-
this.rightPanelHandler.addWidget(widget, sidePanelOptions);
|
|
805
|
-
break;
|
|
806
|
-
case 'secondaryWindow':
|
|
807
|
-
/** At the moment, widgets are only moved to this area (i.e. a secondary window) by moving them from one of the other areas. */
|
|
808
|
-
throw new Error('Widgets cannot be added directly to a secondary window');
|
|
809
|
-
default:
|
|
810
|
-
throw new Error('Unexpected area: ' + (options === null || options === void 0 ? void 0 : options.area));
|
|
811
|
-
}
|
|
812
|
-
if (area !== 'top') {
|
|
813
|
-
this.track(widget);
|
|
814
|
-
}
|
|
815
|
-
}
|
|
816
|
-
getInsertionOptions(options) {
|
|
817
|
-
let ref = options === null || options === void 0 ? void 0 : options.ref;
|
|
818
|
-
let area = (options === null || options === void 0 ? void 0 : options.area) || 'main';
|
|
819
|
-
if (!ref && (area === 'main' || area === 'bottom')) {
|
|
820
|
-
const tabBar = this.getTabBarFor(area);
|
|
821
|
-
ref = tabBar && tabBar.currentTitle && tabBar.currentTitle.owner || undefined;
|
|
822
|
-
}
|
|
823
|
-
// make sure that ref belongs to area
|
|
824
|
-
area = ref && this.getAreaFor(ref) || area;
|
|
825
|
-
const addOptions = {};
|
|
826
|
-
if (ApplicationShell_1.isOpenToSideMode(options === null || options === void 0 ? void 0 : options.mode)) {
|
|
827
|
-
const areaPanel = area === 'main' ? this.mainPanel : area === 'bottom' ? this.bottomPanel : undefined;
|
|
828
|
-
const sideRef = areaPanel && ref && ((options === null || options === void 0 ? void 0 : options.mode) === 'open-to-left' ?
|
|
829
|
-
areaPanel.previousTabBarWidget(ref) :
|
|
830
|
-
areaPanel.nextTabBarWidget(ref));
|
|
831
|
-
if (sideRef) {
|
|
832
|
-
addOptions.ref = sideRef;
|
|
833
|
-
}
|
|
834
|
-
else {
|
|
835
|
-
addOptions.ref = ref;
|
|
836
|
-
addOptions.mode = (options === null || options === void 0 ? void 0 : options.mode) === 'open-to-left' ? 'split-left' : 'split-right';
|
|
837
|
-
}
|
|
838
|
-
}
|
|
839
|
-
else {
|
|
840
|
-
addOptions.ref = ref;
|
|
841
|
-
addOptions.mode = options === null || options === void 0 ? void 0 : options.mode;
|
|
842
|
-
}
|
|
843
|
-
return { area, addOptions };
|
|
844
|
-
}
|
|
845
|
-
/**
|
|
846
|
-
* The widgets contained in the given shell area.
|
|
847
|
-
*/
|
|
848
|
-
getWidgets(area) {
|
|
849
|
-
switch (area) {
|
|
850
|
-
case 'main':
|
|
851
|
-
return (0, algorithm_1.toArray)(this.mainPanel.widgets());
|
|
852
|
-
case 'top':
|
|
853
|
-
return (0, algorithm_1.toArray)(this.topPanel.widgets);
|
|
854
|
-
case 'bottom':
|
|
855
|
-
return (0, algorithm_1.toArray)(this.bottomPanel.widgets());
|
|
856
|
-
case 'left':
|
|
857
|
-
return (0, algorithm_1.toArray)(this.leftPanelHandler.dockPanel.widgets());
|
|
858
|
-
case 'right':
|
|
859
|
-
return (0, algorithm_1.toArray)(this.rightPanelHandler.dockPanel.widgets());
|
|
860
|
-
case 'secondaryWindow':
|
|
861
|
-
return (0, algorithm_1.toArray)(this.secondaryWindowHandler.widgets);
|
|
862
|
-
default:
|
|
863
|
-
throw new Error('Illegal argument: ' + area);
|
|
864
|
-
}
|
|
865
|
-
}
|
|
866
|
-
/**
|
|
867
|
-
* Find the widget that contains the given HTML element. The returned widget may be one
|
|
868
|
-
* that is managed by the application shell, or one that is embedded in another widget and
|
|
869
|
-
* not directly managed by the shell, or a tab bar.
|
|
870
|
-
*/
|
|
871
|
-
findWidgetForElement(element) {
|
|
872
|
-
let widgetNode = element;
|
|
873
|
-
while (widgetNode && !widgetNode.classList.contains('p-Widget')) {
|
|
874
|
-
widgetNode = widgetNode.parentElement;
|
|
875
|
-
}
|
|
876
|
-
if (widgetNode) {
|
|
877
|
-
return this.findWidgetForNode(widgetNode, this);
|
|
878
|
-
}
|
|
879
|
-
return undefined;
|
|
880
|
-
}
|
|
881
|
-
findWidgetForNode(widgetNode, widget) {
|
|
882
|
-
if (widget.node === widgetNode) {
|
|
883
|
-
return widget;
|
|
884
|
-
}
|
|
885
|
-
let result;
|
|
886
|
-
(0, algorithm_1.each)(widget.children(), child => {
|
|
887
|
-
result = this.findWidgetForNode(widgetNode, child);
|
|
888
|
-
return !result;
|
|
889
|
-
});
|
|
890
|
-
return result;
|
|
891
|
-
}
|
|
892
|
-
/**
|
|
893
|
-
* Finds the title widget from the tab-bar.
|
|
894
|
-
* @param tabBar used for providing an array of titles.
|
|
895
|
-
* @returns the selected title widget, else returns the currentTitle or undefined.
|
|
896
|
-
*/
|
|
897
|
-
findTitle(tabBar, event) {
|
|
898
|
-
if ((event === null || event === void 0 ? void 0 : event.target) instanceof HTMLElement) {
|
|
899
|
-
const tabNode = event.target;
|
|
900
|
-
const titleIndex = Array.from(tabBar.contentNode.getElementsByClassName('p-TabBar-tab'))
|
|
901
|
-
.findIndex(node => node.contains(tabNode));
|
|
902
|
-
if (titleIndex !== -1) {
|
|
903
|
-
return tabBar.titles[titleIndex];
|
|
904
|
-
}
|
|
905
|
-
}
|
|
906
|
-
return tabBar.currentTitle || undefined;
|
|
907
|
-
}
|
|
908
|
-
/**
|
|
909
|
-
* Finds the tab-bar widget.
|
|
910
|
-
* @returns the selected tab-bar, else returns the currentTabBar.
|
|
911
|
-
*/
|
|
912
|
-
findTabBar(event) {
|
|
913
|
-
if ((event === null || event === void 0 ? void 0 : event.target) instanceof HTMLElement) {
|
|
914
|
-
const tabBar = this.findWidgetForElement(event.target);
|
|
915
|
-
if (tabBar instanceof widgets_1.TabBar) {
|
|
916
|
-
return tabBar;
|
|
917
|
-
}
|
|
918
|
-
}
|
|
919
|
-
return this.currentTabBar;
|
|
920
|
-
}
|
|
921
|
-
/**
|
|
922
|
-
* @returns the widget whose title has been targeted by a DOM event on a tabbar, or undefined if none can be found.
|
|
923
|
-
*/
|
|
924
|
-
findTargetedWidget(event) {
|
|
925
|
-
if (event) {
|
|
926
|
-
const tab = this.findTabBar(event);
|
|
927
|
-
const title = tab && this.findTitle(tab, event);
|
|
928
|
-
return title && title.owner;
|
|
929
|
-
}
|
|
930
|
-
}
|
|
931
|
-
/**
|
|
932
|
-
* The current widget in the application shell. The current widget is the last widget that
|
|
933
|
-
* was active and not yet closed. See the remarks to `activeWidget` on what _active_ means.
|
|
934
|
-
*/
|
|
935
|
-
get currentWidget() {
|
|
936
|
-
return this.tracker.currentWidget || undefined;
|
|
937
|
-
}
|
|
938
|
-
/**
|
|
939
|
-
* The active widget in the application shell. The active widget is the one that has focus
|
|
940
|
-
* (either the widget itself or any of its contents).
|
|
941
|
-
*
|
|
942
|
-
* _Note:_ Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
943
|
-
* widget implementation which DOM element will get the focus. The default implementation
|
|
944
|
-
* does not take any focus; in that case the widget is never returned by this property.
|
|
945
|
-
*/
|
|
946
|
-
get activeWidget() {
|
|
947
|
-
return this.tracker.activeWidget || undefined;
|
|
948
|
-
}
|
|
949
|
-
/**
|
|
950
|
-
* Returns the last active widget in the given shell area.
|
|
951
|
-
*/
|
|
952
|
-
getCurrentWidget(area) {
|
|
953
|
-
let title;
|
|
954
|
-
switch (area) {
|
|
955
|
-
case 'main':
|
|
956
|
-
title = this.mainPanel.currentTitle;
|
|
957
|
-
break;
|
|
958
|
-
case 'bottom':
|
|
959
|
-
title = this.bottomPanel.currentTitle;
|
|
960
|
-
break;
|
|
961
|
-
case 'left':
|
|
962
|
-
title = this.leftPanelHandler.tabBar.currentTitle;
|
|
963
|
-
break;
|
|
964
|
-
case 'right':
|
|
965
|
-
title = this.rightPanelHandler.tabBar.currentTitle;
|
|
966
|
-
break;
|
|
967
|
-
case 'secondaryWindow':
|
|
968
|
-
// The current widget in a secondary window is not tracked.
|
|
969
|
-
return undefined;
|
|
970
|
-
default:
|
|
971
|
-
throw new Error('Illegal argument: ' + area);
|
|
972
|
-
}
|
|
973
|
-
return title ? title.owner : undefined;
|
|
974
|
-
}
|
|
975
|
-
/**
|
|
976
|
-
* Handle a change to the current widget.
|
|
977
|
-
*/
|
|
978
|
-
onCurrentChanged(sender, args) {
|
|
979
|
-
this.onDidChangeCurrentWidgetEmitter.fire(args);
|
|
980
|
-
}
|
|
981
|
-
/**
|
|
982
|
-
* Handle a change to the active widget.
|
|
983
|
-
*/
|
|
984
|
-
onActiveChanged(sender, args) {
|
|
985
|
-
this.toDisposeOnActiveChanged.dispose();
|
|
986
|
-
const { newValue, oldValue } = args;
|
|
987
|
-
if (oldValue) {
|
|
988
|
-
let w = oldValue;
|
|
989
|
-
while (w) {
|
|
990
|
-
// Remove the mark of the previously active widget
|
|
991
|
-
w.title.className = w.title.className.replace(' theia-mod-active', '');
|
|
992
|
-
w = w.parent;
|
|
993
|
-
}
|
|
994
|
-
// Reset the z-index to the default
|
|
995
|
-
// eslint-disable-next-line no-null/no-null
|
|
996
|
-
this.setZIndex(oldValue.node, null);
|
|
997
|
-
}
|
|
998
|
-
if (newValue) {
|
|
999
|
-
let w = newValue;
|
|
1000
|
-
while (w) {
|
|
1001
|
-
// Mark the tab of the active widget
|
|
1002
|
-
w.title.className += ' theia-mod-active';
|
|
1003
|
-
w = w.parent;
|
|
1004
|
-
}
|
|
1005
|
-
// Reveal the title of the active widget in its tab bar
|
|
1006
|
-
const tabBar = this.getTabBarFor(newValue);
|
|
1007
|
-
if (tabBar instanceof tab_bars_1.ScrollableTabBar) {
|
|
1008
|
-
const index = tabBar.titles.indexOf(newValue.title);
|
|
1009
|
-
if (index >= 0) {
|
|
1010
|
-
tabBar.revealTab(index);
|
|
1011
|
-
}
|
|
1012
|
-
}
|
|
1013
|
-
const widget = this.toTrackedStack(newValue.id).pop();
|
|
1014
|
-
const panel = this.findPanel(widget);
|
|
1015
|
-
if (panel) {
|
|
1016
|
-
// if widget was undefined, we wouldn't have gotten a panel back before
|
|
1017
|
-
panel.markAsCurrent(widget.title);
|
|
1018
|
-
}
|
|
1019
|
-
// Add checks to ensure that the 'sash' for left panel is displayed correctly
|
|
1020
|
-
if (newValue.node.className === 'p-Widget theia-view-container p-DockPanel-widget') {
|
|
1021
|
-
// Set the z-index so elements with `position: fixed` contained in the active widget are displayed correctly
|
|
1022
|
-
this.setZIndex(newValue.node, '1');
|
|
1023
|
-
}
|
|
1024
|
-
// activate another widget if an active widget will be closed
|
|
1025
|
-
const onCloseRequest = newValue['onCloseRequest'];
|
|
1026
|
-
newValue['onCloseRequest'] = msg => {
|
|
1027
|
-
const currentTabBar = this.currentTabBar;
|
|
1028
|
-
if (currentTabBar) {
|
|
1029
|
-
const recentlyUsedInTabBar = currentTabBar['_previousTitle'];
|
|
1030
|
-
if (recentlyUsedInTabBar && recentlyUsedInTabBar.owner !== newValue) {
|
|
1031
|
-
currentTabBar.currentIndex = algorithm_1.ArrayExt.firstIndexOf(currentTabBar.titles, recentlyUsedInTabBar);
|
|
1032
|
-
if (currentTabBar.currentTitle) {
|
|
1033
|
-
this.activateWidget(currentTabBar.currentTitle.owner.id);
|
|
1034
|
-
}
|
|
1035
|
-
}
|
|
1036
|
-
else if (!this.activateNextTabInTabBar(currentTabBar)) {
|
|
1037
|
-
if (!this.activatePreviousTabBar(currentTabBar)) {
|
|
1038
|
-
this.activateNextTabBar(currentTabBar);
|
|
1039
|
-
}
|
|
1040
|
-
}
|
|
1041
|
-
}
|
|
1042
|
-
newValue['onCloseRequest'] = onCloseRequest;
|
|
1043
|
-
newValue['onCloseRequest'](msg);
|
|
1044
|
-
};
|
|
1045
|
-
this.toDisposeOnActiveChanged.push(common_1.Disposable.create(() => newValue['onCloseRequest'] = onCloseRequest));
|
|
1046
|
-
if (previewable_widget_1.PreviewableWidget.is(newValue)) {
|
|
1047
|
-
newValue.loaded = true;
|
|
1048
|
-
}
|
|
1049
|
-
}
|
|
1050
|
-
this.onDidChangeActiveWidgetEmitter.fire(args);
|
|
1051
|
-
}
|
|
1052
|
-
/**
|
|
1053
|
-
* Set the z-index of the given element and its ancestors to the value `z`.
|
|
1054
|
-
*/
|
|
1055
|
-
setZIndex(element, z) {
|
|
1056
|
-
element.style.zIndex = z || '';
|
|
1057
|
-
const parent = element.parentElement;
|
|
1058
|
-
if (parent && parent !== this.node) {
|
|
1059
|
-
this.setZIndex(parent, z);
|
|
1060
|
-
}
|
|
1061
|
-
}
|
|
1062
|
-
/**
|
|
1063
|
-
* Track the given widget so it is considered in the `current` and `active` state of the shell.
|
|
1064
|
-
*/
|
|
1065
|
-
track(widget) {
|
|
1066
|
-
if (this.tracker.widgets.indexOf(widget) !== -1) {
|
|
1067
|
-
return;
|
|
1068
|
-
}
|
|
1069
|
-
this.tracker.add(widget);
|
|
1070
|
-
this.checkActivation(widget);
|
|
1071
|
-
saveable_1.Saveable.apply(widget, () => this.widgets.filter((maybeSaveable) => !!saveable_1.Saveable.get(maybeSaveable)), async (toSave, options) => {
|
|
1072
|
-
await this.saveResourceService.save(toSave, options);
|
|
1073
|
-
});
|
|
1074
|
-
if (ApplicationShell_1.TrackableWidgetProvider.is(widget)) {
|
|
1075
|
-
for (const toTrack of widget.getTrackableWidgets()) {
|
|
1076
|
-
this.track(toTrack);
|
|
1077
|
-
}
|
|
1078
|
-
if (widget.onDidChangeTrackableWidgets) {
|
|
1079
|
-
widget.onDidChangeTrackableWidgets(widgets => widgets.forEach(w => this.track(w)));
|
|
1080
|
-
}
|
|
1081
|
-
}
|
|
1082
|
-
}
|
|
1083
|
-
/**
|
|
1084
|
-
* @returns an array of Widgets, all of which are tracked by the focus tracker
|
|
1085
|
-
* The first member of the array is the widget whose id is passed in, and the other widgets
|
|
1086
|
-
* are its tracked parents in ascending order
|
|
1087
|
-
*/
|
|
1088
|
-
toTrackedStack(id) {
|
|
1089
|
-
const tracked = new Map(this.tracker.widgets.map(w => [w.id, w]));
|
|
1090
|
-
let current = tracked.get(id);
|
|
1091
|
-
const stack = [];
|
|
1092
|
-
while (current) {
|
|
1093
|
-
if (tracked.has(current.id)) {
|
|
1094
|
-
stack.push(current);
|
|
1095
|
-
}
|
|
1096
|
-
current = current.parent || undefined;
|
|
1097
|
-
}
|
|
1098
|
-
return stack;
|
|
1099
|
-
}
|
|
1100
|
-
/**
|
|
1101
|
-
* Activate a widget in the application shell. This makes the widget visible and usually
|
|
1102
|
-
* also assigns focus to it.
|
|
1103
|
-
*
|
|
1104
|
-
* _Note:_ Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
1105
|
-
* widget implementation which DOM element will get the focus. The default implementation
|
|
1106
|
-
* does not take any focus.
|
|
1107
|
-
*
|
|
1108
|
-
* @returns the activated widget if it was found
|
|
1109
|
-
*/
|
|
1110
|
-
async activateWidget(id) {
|
|
1111
|
-
const stack = this.toTrackedStack(id);
|
|
1112
|
-
let current = stack.pop();
|
|
1113
|
-
if (current && !this.doActivateWidget(current.id)) {
|
|
1114
|
-
return undefined;
|
|
1115
|
-
}
|
|
1116
|
-
while (current && stack.length) {
|
|
1117
|
-
const child = stack.pop();
|
|
1118
|
-
if (ApplicationShell_1.TrackableWidgetProvider.is(current) && current.activateWidget) {
|
|
1119
|
-
current = current.activateWidget(child.id);
|
|
1120
|
-
}
|
|
1121
|
-
else {
|
|
1122
|
-
child.activate();
|
|
1123
|
-
current = child;
|
|
1124
|
-
}
|
|
1125
|
-
}
|
|
1126
|
-
if (!current) {
|
|
1127
|
-
return undefined;
|
|
1128
|
-
}
|
|
1129
|
-
return Promise.all([
|
|
1130
|
-
this.waitForActivation(current.id),
|
|
1131
|
-
(0, widgets_2.waitForRevealed)(current),
|
|
1132
|
-
this.pendingUpdates
|
|
1133
|
-
]).then(() => current, () => undefined);
|
|
1134
|
-
}
|
|
1135
|
-
waitForActivation(id) {
|
|
1136
|
-
if (this.activeWidget && this.activeWidget.id === id) {
|
|
1137
|
-
return Promise.resolve();
|
|
1138
|
-
}
|
|
1139
|
-
const activation = new promise_util_1.Deferred();
|
|
1140
|
-
const success = this.onDidChangeActiveWidget(() => {
|
|
1141
|
-
if (this.activeWidget && this.activeWidget.id === id) {
|
|
1142
|
-
activation.resolve();
|
|
1143
|
-
}
|
|
1144
|
-
});
|
|
1145
|
-
const failure = setTimeout(() => activation.reject(new Error(`Widget with id '${id}' failed to activate.`)), this.activationTimeout + 250);
|
|
1146
|
-
return activation.promise.finally(() => {
|
|
1147
|
-
success.dispose();
|
|
1148
|
-
clearTimeout(failure);
|
|
1149
|
-
});
|
|
1150
|
-
}
|
|
1151
|
-
/**
|
|
1152
|
-
* Activate top-level area widget.
|
|
1153
|
-
*/
|
|
1154
|
-
doActivateWidget(id) {
|
|
1155
|
-
let widget = (0, algorithm_1.find)(this.mainPanel.widgets(), w => w.id === id);
|
|
1156
|
-
if (widget) {
|
|
1157
|
-
this.mainPanel.activateWidget(widget);
|
|
1158
|
-
}
|
|
1159
|
-
if (!widget) {
|
|
1160
|
-
widget = (0, algorithm_1.find)(this.bottomPanel.widgets(), w => w.id === id);
|
|
1161
|
-
if (widget) {
|
|
1162
|
-
this.expandBottomPanel();
|
|
1163
|
-
this.bottomPanel.activateWidget(widget);
|
|
1164
|
-
}
|
|
1165
|
-
}
|
|
1166
|
-
if (!widget) {
|
|
1167
|
-
widget = this.leftPanelHandler.activate(id);
|
|
1168
|
-
}
|
|
1169
|
-
if (!widget) {
|
|
1170
|
-
widget = this.rightPanelHandler.activate(id);
|
|
1171
|
-
}
|
|
1172
|
-
if (widget) {
|
|
1173
|
-
this.windowService.focus();
|
|
1174
|
-
return widget;
|
|
1175
|
-
}
|
|
1176
|
-
return this.secondaryWindowHandler.activateWidget(id);
|
|
1177
|
-
}
|
|
1178
|
-
/**
|
|
1179
|
-
* Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
1180
|
-
* widget implementation which DOM element will get the focus. The default implementation
|
|
1181
|
-
* of Widget does not take any focus. This method can help finding such problems by logging
|
|
1182
|
-
* a warning in case a widget was explicitly activated, but did not trigger a change of the
|
|
1183
|
-
* `activeWidget` property.
|
|
1184
|
-
*/
|
|
1185
|
-
checkActivation(widget) {
|
|
1186
|
-
const onActivateRequest = widget['onActivateRequest'].bind(widget);
|
|
1187
|
-
widget['onActivateRequest'] = (msg) => {
|
|
1188
|
-
onActivateRequest(msg);
|
|
1189
|
-
this.assertActivated(widget);
|
|
1190
|
-
};
|
|
1191
|
-
return widget;
|
|
1192
|
-
}
|
|
1193
|
-
assertActivated(widget) {
|
|
1194
|
-
this.toDisposeOnActivationCheck.dispose();
|
|
1195
|
-
const onDispose = () => this.toDisposeOnActivationCheck.dispose();
|
|
1196
|
-
widget.disposed.connect(onDispose);
|
|
1197
|
-
this.toDisposeOnActivationCheck.push(common_1.Disposable.create(() => widget.disposed.disconnect(onDispose)));
|
|
1198
|
-
let start = 0;
|
|
1199
|
-
const step = timestamp => {
|
|
1200
|
-
const activeElement = widget.node.ownerDocument.activeElement;
|
|
1201
|
-
if (activeElement && widget.node.contains(activeElement)) {
|
|
1202
|
-
return;
|
|
1203
|
-
}
|
|
1204
|
-
if (!start) {
|
|
1205
|
-
start = timestamp;
|
|
1206
|
-
}
|
|
1207
|
-
const delta = timestamp - start;
|
|
1208
|
-
if (delta < this.activationTimeout) {
|
|
1209
|
-
request = window.requestAnimationFrame(step);
|
|
1210
|
-
}
|
|
1211
|
-
else {
|
|
1212
|
-
console.warn(`Widget was activated, but did not accept focus after ${this.activationTimeout}ms: ${widget.id}`);
|
|
1213
|
-
}
|
|
1214
|
-
};
|
|
1215
|
-
let request = window.requestAnimationFrame(step);
|
|
1216
|
-
this.toDisposeOnActivationCheck.push(common_1.Disposable.create(() => window.cancelAnimationFrame(request)));
|
|
1217
|
-
}
|
|
1218
|
-
/**
|
|
1219
|
-
* Reveal a widget in the application shell. This makes the widget visible,
|
|
1220
|
-
* but does not activate it.
|
|
1221
|
-
*
|
|
1222
|
-
* @returns the revealed widget if it was found
|
|
1223
|
-
*/
|
|
1224
|
-
async revealWidget(id) {
|
|
1225
|
-
const stack = this.toTrackedStack(id);
|
|
1226
|
-
let current = stack.pop();
|
|
1227
|
-
if (current && !this.doRevealWidget(current.id)) {
|
|
1228
|
-
return undefined;
|
|
1229
|
-
}
|
|
1230
|
-
while (current && stack.length) {
|
|
1231
|
-
const child = stack.pop();
|
|
1232
|
-
if (ApplicationShell_1.TrackableWidgetProvider.is(current) && current.revealWidget) {
|
|
1233
|
-
current = current.revealWidget(child.id);
|
|
1234
|
-
}
|
|
1235
|
-
else {
|
|
1236
|
-
current = child;
|
|
1237
|
-
}
|
|
1238
|
-
}
|
|
1239
|
-
if (!current) {
|
|
1240
|
-
return undefined;
|
|
1241
|
-
}
|
|
1242
|
-
await Promise.all([
|
|
1243
|
-
(0, widgets_2.waitForRevealed)(current),
|
|
1244
|
-
this.pendingUpdates
|
|
1245
|
-
]);
|
|
1246
|
-
return current;
|
|
1247
|
-
}
|
|
1248
|
-
/**
|
|
1249
|
-
* Reveal top-level area widget.
|
|
1250
|
-
*/
|
|
1251
|
-
doRevealWidget(id) {
|
|
1252
|
-
let widget = (0, algorithm_1.find)(this.mainPanel.widgets(), w => w.id === id);
|
|
1253
|
-
if (!widget) {
|
|
1254
|
-
widget = (0, algorithm_1.find)(this.bottomPanel.widgets(), w => w.id === id);
|
|
1255
|
-
if (widget) {
|
|
1256
|
-
this.expandBottomPanel();
|
|
1257
|
-
}
|
|
1258
|
-
}
|
|
1259
|
-
if (widget) {
|
|
1260
|
-
const tabBar = this.getTabBarFor(widget);
|
|
1261
|
-
if (tabBar) {
|
|
1262
|
-
tabBar.currentTitle = widget.title;
|
|
1263
|
-
}
|
|
1264
|
-
}
|
|
1265
|
-
if (!widget) {
|
|
1266
|
-
widget = this.leftPanelHandler.expand(id);
|
|
1267
|
-
}
|
|
1268
|
-
if (!widget) {
|
|
1269
|
-
widget = this.rightPanelHandler.expand(id);
|
|
1270
|
-
}
|
|
1271
|
-
if (widget) {
|
|
1272
|
-
this.windowService.focus();
|
|
1273
|
-
return widget;
|
|
1274
|
-
}
|
|
1275
|
-
else {
|
|
1276
|
-
return this.secondaryWindowHandler.revealWidget(id);
|
|
1277
|
-
}
|
|
1278
|
-
}
|
|
1279
|
-
/**
|
|
1280
|
-
* Expand the named side panel area. This makes sure that the panel is visible, even if there
|
|
1281
|
-
* are no widgets in it. If the panel is already visible, nothing happens. If the panel is currently
|
|
1282
|
-
* collapsed (see `collapsePanel`) and it contains widgets, the widgets are revealed that were
|
|
1283
|
-
* visible before it was collapsed.
|
|
1284
|
-
*/
|
|
1285
|
-
expandPanel(area) {
|
|
1286
|
-
switch (area) {
|
|
1287
|
-
case 'bottom':
|
|
1288
|
-
this.expandBottomPanel();
|
|
1289
|
-
break;
|
|
1290
|
-
case 'left':
|
|
1291
|
-
this.leftPanelHandler.expand();
|
|
1292
|
-
break;
|
|
1293
|
-
case 'right':
|
|
1294
|
-
this.rightPanelHandler.expand();
|
|
1295
|
-
break;
|
|
1296
|
-
default:
|
|
1297
|
-
throw new Error('Area cannot be expanded: ' + area);
|
|
1298
|
-
}
|
|
1299
|
-
}
|
|
1300
|
-
/**
|
|
1301
|
-
* Adjusts the size of the given area in the application shell.
|
|
1302
|
-
*
|
|
1303
|
-
* @param size the desired size of the panel in pixels.
|
|
1304
|
-
* @param area the area to resize.
|
|
1305
|
-
*/
|
|
1306
|
-
resize(size, area) {
|
|
1307
|
-
switch (area) {
|
|
1308
|
-
case 'bottom':
|
|
1309
|
-
if (this.bottomPanel.isHidden) {
|
|
1310
|
-
this.bottomPanelState.lastPanelSize = size;
|
|
1311
|
-
}
|
|
1312
|
-
else {
|
|
1313
|
-
this.setBottomPanelSize(size);
|
|
1314
|
-
}
|
|
1315
|
-
break;
|
|
1316
|
-
case 'left':
|
|
1317
|
-
this.leftPanelHandler.resize(size);
|
|
1318
|
-
break;
|
|
1319
|
-
case 'right':
|
|
1320
|
-
this.rightPanelHandler.resize(size);
|
|
1321
|
-
break;
|
|
1322
|
-
default:
|
|
1323
|
-
throw new Error('Area cannot be resized: ' + area);
|
|
1324
|
-
}
|
|
1325
|
-
}
|
|
1326
|
-
/**
|
|
1327
|
-
* Expand the bottom panel. See `expandPanel` regarding the exact behavior.
|
|
1328
|
-
*/
|
|
1329
|
-
expandBottomPanel() {
|
|
1330
|
-
const bottomPanel = this.bottomPanel;
|
|
1331
|
-
if (bottomPanel.isHidden) {
|
|
1332
|
-
let relativeSizes;
|
|
1333
|
-
const parent = bottomPanel.parent;
|
|
1334
|
-
if (parent instanceof widgets_1.SplitPanel) {
|
|
1335
|
-
relativeSizes = parent.relativeSizes();
|
|
1336
|
-
}
|
|
1337
|
-
bottomPanel.show();
|
|
1338
|
-
if (relativeSizes && parent instanceof widgets_1.SplitPanel) {
|
|
1339
|
-
// Make sure that the expansion animation starts at the smallest possible size
|
|
1340
|
-
parent.setRelativeSizes(relativeSizes);
|
|
1341
|
-
}
|
|
1342
|
-
let size;
|
|
1343
|
-
if (bottomPanel.isEmpty) {
|
|
1344
|
-
bottomPanel.node.style.minHeight = '0';
|
|
1345
|
-
size = this.options.bottomPanel.emptySize;
|
|
1346
|
-
}
|
|
1347
|
-
else if (this.bottomPanelState.lastPanelSize) {
|
|
1348
|
-
size = this.bottomPanelState.lastPanelSize;
|
|
1349
|
-
}
|
|
1350
|
-
else {
|
|
1351
|
-
size = this.getDefaultBottomPanelSize();
|
|
1352
|
-
}
|
|
1353
|
-
if (size) {
|
|
1354
|
-
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanding;
|
|
1355
|
-
this.setBottomPanelSize(size).then(() => {
|
|
1356
|
-
if (this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanding) {
|
|
1357
|
-
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1358
|
-
}
|
|
1359
|
-
});
|
|
1360
|
-
}
|
|
1361
|
-
else {
|
|
1362
|
-
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1363
|
-
}
|
|
1364
|
-
}
|
|
1365
|
-
}
|
|
1366
|
-
/**
|
|
1367
|
-
* Collapse the named side panel area. This makes sure that the panel is hidden,
|
|
1368
|
-
* increasing the space that is available for other shell areas.
|
|
1369
|
-
*/
|
|
1370
|
-
collapsePanel(area) {
|
|
1371
|
-
switch (area) {
|
|
1372
|
-
case 'bottom':
|
|
1373
|
-
return this.collapseBottomPanel();
|
|
1374
|
-
case 'left':
|
|
1375
|
-
return this.leftPanelHandler.collapse();
|
|
1376
|
-
case 'right':
|
|
1377
|
-
return this.rightPanelHandler.collapse();
|
|
1378
|
-
default:
|
|
1379
|
-
throw new Error('Area cannot be collapsed: ' + area);
|
|
1380
|
-
}
|
|
1381
|
-
}
|
|
1382
|
-
/**
|
|
1383
|
-
* Collapse the bottom panel. All contained widgets are hidden, but not closed.
|
|
1384
|
-
* They can be restored by calling `expandBottomPanel`.
|
|
1385
|
-
*/
|
|
1386
|
-
collapseBottomPanel() {
|
|
1387
|
-
const bottomPanel = this.bottomPanel;
|
|
1388
|
-
if (bottomPanel.isHidden) {
|
|
1389
|
-
return Promise.resolve();
|
|
1390
|
-
}
|
|
1391
|
-
if (this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded) {
|
|
1392
|
-
const size = this.getBottomPanelSize();
|
|
1393
|
-
if (size) {
|
|
1394
|
-
this.bottomPanelState.lastPanelSize = size;
|
|
1395
|
-
}
|
|
1396
|
-
}
|
|
1397
|
-
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.collapsed;
|
|
1398
|
-
bottomPanel.hide();
|
|
1399
|
-
return (0, browser_1.animationFrame)();
|
|
1400
|
-
}
|
|
1401
|
-
/**
|
|
1402
|
-
* Refresh the toggle button for the bottom panel. This implementation creates a status bar entry
|
|
1403
|
-
* and refers to the command `core.toggle.bottom.panel`.
|
|
1404
|
-
*/
|
|
1405
|
-
refreshBottomPanelToggleButton() {
|
|
1406
|
-
if (this.bottomPanel.isEmpty) {
|
|
1407
|
-
this.statusBar.removeElement(BOTTOM_PANEL_TOGGLE_ID);
|
|
1408
|
-
}
|
|
1409
|
-
else {
|
|
1410
|
-
const label = nls_1.nls.localize('theia/core/common/collapseBottomPanel', 'Toggle Bottom Panel');
|
|
1411
|
-
const element = {
|
|
1412
|
-
name: label,
|
|
1413
|
-
text: '$(codicon-window)',
|
|
1414
|
-
alignment: status_bar_1.StatusBarAlignment.RIGHT,
|
|
1415
|
-
tooltip: label,
|
|
1416
|
-
command: 'core.toggle.bottom.panel',
|
|
1417
|
-
accessibilityInformation: {
|
|
1418
|
-
label: label,
|
|
1419
|
-
role: 'button'
|
|
1420
|
-
},
|
|
1421
|
-
priority: -1000
|
|
1422
|
-
};
|
|
1423
|
-
this.statusBar.setElement(BOTTOM_PANEL_TOGGLE_ID, element);
|
|
1424
|
-
}
|
|
1425
|
-
}
|
|
1426
|
-
/**
|
|
1427
|
-
* Check whether the named side panel area is expanded (returns `true`) or collapsed (returns `false`).
|
|
1428
|
-
*/
|
|
1429
|
-
isExpanded(area) {
|
|
1430
|
-
switch (area) {
|
|
1431
|
-
case 'bottom':
|
|
1432
|
-
return this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1433
|
-
case 'left':
|
|
1434
|
-
return this.leftPanelHandler.state.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1435
|
-
case 'right':
|
|
1436
|
-
return this.rightPanelHandler.state.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1437
|
-
default:
|
|
1438
|
-
return true;
|
|
1439
|
-
}
|
|
1440
|
-
}
|
|
1441
|
-
/**
|
|
1442
|
-
* Close all tabs or a selection of tabs in a specific part of the application shell.
|
|
1443
|
-
*
|
|
1444
|
-
* @param tabBarOrArea
|
|
1445
|
-
* Either the name of a shell area or a `TabBar` that is contained in such an area.
|
|
1446
|
-
* @param filter
|
|
1447
|
-
* If undefined, all tabs are closed; otherwise only those tabs that match the filter are closed.
|
|
1448
|
-
*/
|
|
1449
|
-
async closeTabs(tabBarOrArea, filter) {
|
|
1450
|
-
const titles = this.getWidgetTitles(tabBarOrArea, filter);
|
|
1451
|
-
if (titles.length) {
|
|
1452
|
-
await this.closeMany(titles.map(title => title.owner));
|
|
1453
|
-
}
|
|
1454
|
-
}
|
|
1455
|
-
saveTabs(tabBarOrArea, filter) {
|
|
1456
|
-
const titles = this.getWidgetTitles(tabBarOrArea, filter);
|
|
1457
|
-
for (let i = 0; i < titles.length; i++) {
|
|
1458
|
-
const widget = titles[i].owner;
|
|
1459
|
-
const saveable = saveable_1.Saveable.get(widget);
|
|
1460
|
-
saveable === null || saveable === void 0 ? void 0 : saveable.save();
|
|
1461
|
-
}
|
|
1462
|
-
}
|
|
1463
|
-
/**
|
|
1464
|
-
* Collects all widget titles for the given tab bar or area and optionally filters them.
|
|
1465
|
-
*
|
|
1466
|
-
* @param tabBarOrArea The tab bar or area to retrieve the widget titles for
|
|
1467
|
-
* @param filter The filter to apply to the result
|
|
1468
|
-
* @returns The filtered array of widget titles or an empty array
|
|
1469
|
-
*/
|
|
1470
|
-
getWidgetTitles(tabBarOrArea, filter) {
|
|
1471
|
-
const titles = [];
|
|
1472
|
-
if (tabBarOrArea === 'main') {
|
|
1473
|
-
this.mainAreaTabBars.forEach(tabbar => titles.push(...(0, algorithm_1.toArray)(tabbar.titles)));
|
|
1474
|
-
}
|
|
1475
|
-
else if (tabBarOrArea === 'bottom') {
|
|
1476
|
-
this.bottomAreaTabBars.forEach(tabbar => titles.push(...(0, algorithm_1.toArray)(tabbar.titles)));
|
|
1477
|
-
}
|
|
1478
|
-
else if (tabBarOrArea === 'secondaryWindow') {
|
|
1479
|
-
titles.push(...this.secondaryWindowHandler.widgets.map(w => w.title));
|
|
1480
|
-
}
|
|
1481
|
-
else if (typeof tabBarOrArea === 'string') {
|
|
1482
|
-
const tabbar = this.getTabBarFor(tabBarOrArea);
|
|
1483
|
-
if (tabbar) {
|
|
1484
|
-
titles.push(...(0, algorithm_1.toArray)(tabbar.titles));
|
|
1485
|
-
}
|
|
1486
|
-
}
|
|
1487
|
-
else if (tabBarOrArea) {
|
|
1488
|
-
titles.push(...(0, algorithm_1.toArray)(tabBarOrArea.titles));
|
|
1489
|
-
}
|
|
1490
|
-
return filter ? titles.filter(filter) : titles;
|
|
1491
|
-
}
|
|
1492
|
-
/**
|
|
1493
|
-
* @param targets the widgets to be closed
|
|
1494
|
-
* @return an array of all the widgets that were actually closed.
|
|
1495
|
-
*/
|
|
1496
|
-
async closeMany(targets, options) {
|
|
1497
|
-
if ((options === null || options === void 0 ? void 0 : options.save) === false || await saveable_1.Saveable.confirmSaveBeforeClose(targets, this.widgets.filter(widget => !targets.includes(widget)))) {
|
|
1498
|
-
return (await Promise.all(targets.map(target => this.closeWidget(target.id, options)))).filter((widget) => widget !== undefined);
|
|
1499
|
-
}
|
|
1500
|
-
return [];
|
|
1501
|
-
}
|
|
1502
|
-
/**
|
|
1503
|
-
* @returns the widget that was closed, if any, `undefined` otherwise.
|
|
1504
|
-
*
|
|
1505
|
-
* If your use case requires closing multiple widgets, use {@link ApplicationShell#closeMany} instead. That method handles closing saveable widgets more reliably.
|
|
1506
|
-
*/
|
|
1507
|
-
async closeWidget(id, options) {
|
|
1508
|
-
// TODO handle save for composite widgets, i.e. the preference widget has 2 editors
|
|
1509
|
-
const stack = this.toTrackedStack(id);
|
|
1510
|
-
const current = stack.pop();
|
|
1511
|
-
if (!current) {
|
|
1512
|
-
return undefined;
|
|
1513
|
-
}
|
|
1514
|
-
const saveableOptions = options && { shouldSave: () => options.save };
|
|
1515
|
-
const pendingClose = saveable_1.SaveableWidget.is(current)
|
|
1516
|
-
? current.closeWithSaving(saveableOptions)
|
|
1517
|
-
: (current.close(), (0, widgets_2.waitForClosed)(current));
|
|
1518
|
-
await Promise.all([
|
|
1519
|
-
pendingClose,
|
|
1520
|
-
this.pendingUpdates
|
|
1521
|
-
]);
|
|
1522
|
-
return stack[0] || current;
|
|
1523
|
-
}
|
|
1524
|
-
/**
|
|
1525
|
-
* The shell area name of the currently active tab, or undefined.
|
|
1526
|
-
*/
|
|
1527
|
-
get currentTabArea() {
|
|
1528
|
-
const currentWidget = this.currentWidget;
|
|
1529
|
-
if (currentWidget) {
|
|
1530
|
-
return this.getAreaFor(currentWidget);
|
|
1531
|
-
}
|
|
1532
|
-
}
|
|
1533
|
-
/**
|
|
1534
|
-
* Determine the name of the shell area where the given widget resides. The result is
|
|
1535
|
-
* undefined if the widget does not reside directly in the shell.
|
|
1536
|
-
*/
|
|
1537
|
-
getAreaFor(input) {
|
|
1538
|
-
if (input instanceof widgets_1.TabBar) {
|
|
1539
|
-
if ((0, algorithm_1.find)(this.mainPanel.tabBars(), tb => tb === input)) {
|
|
1540
|
-
return 'main';
|
|
1541
|
-
}
|
|
1542
|
-
if ((0, algorithm_1.find)(this.bottomPanel.tabBars(), tb => tb === input)) {
|
|
1543
|
-
return 'bottom';
|
|
1544
|
-
}
|
|
1545
|
-
if (this.leftPanelHandler.tabBar === input) {
|
|
1546
|
-
return 'left';
|
|
1547
|
-
}
|
|
1548
|
-
if (this.rightPanelHandler.tabBar === input) {
|
|
1549
|
-
return 'right';
|
|
1550
|
-
}
|
|
1551
|
-
}
|
|
1552
|
-
const widget = this.toTrackedStack(input.id).pop();
|
|
1553
|
-
if (!widget) {
|
|
1554
|
-
return undefined;
|
|
1555
|
-
}
|
|
1556
|
-
const title = widget.title;
|
|
1557
|
-
const mainPanelTabBar = this.mainPanel.findTabBar(title);
|
|
1558
|
-
if (mainPanelTabBar) {
|
|
1559
|
-
return 'main';
|
|
1560
|
-
}
|
|
1561
|
-
const bottomPanelTabBar = this.bottomPanel.findTabBar(title);
|
|
1562
|
-
if (bottomPanelTabBar) {
|
|
1563
|
-
return 'bottom';
|
|
1564
|
-
}
|
|
1565
|
-
if (algorithm_1.ArrayExt.firstIndexOf(this.leftPanelHandler.tabBar.titles, title) > -1) {
|
|
1566
|
-
return 'left';
|
|
1567
|
-
}
|
|
1568
|
-
if (algorithm_1.ArrayExt.firstIndexOf(this.rightPanelHandler.tabBar.titles, title) > -1) {
|
|
1569
|
-
return 'right';
|
|
1570
|
-
}
|
|
1571
|
-
if (this.secondaryWindowHandler.widgets.includes(widget)) {
|
|
1572
|
-
return 'secondaryWindow';
|
|
1573
|
-
}
|
|
1574
|
-
return undefined;
|
|
1575
|
-
}
|
|
1576
|
-
getAreaPanelFor(input) {
|
|
1577
|
-
const widget = this.toTrackedStack(input.id).pop();
|
|
1578
|
-
if (!widget) {
|
|
1579
|
-
return undefined;
|
|
1580
|
-
}
|
|
1581
|
-
return this.findPanel(widget);
|
|
1582
|
-
}
|
|
1583
|
-
/**
|
|
1584
|
-
* Find the shell panel this top-level widget is part of
|
|
1585
|
-
*/
|
|
1586
|
-
findPanel(widget) {
|
|
1587
|
-
if (!widget) {
|
|
1588
|
-
return undefined;
|
|
1589
|
-
}
|
|
1590
|
-
const title = widget.title;
|
|
1591
|
-
const mainPanelTabBar = this.mainPanel.findTabBar(title);
|
|
1592
|
-
if (mainPanelTabBar) {
|
|
1593
|
-
return this.mainPanel;
|
|
1594
|
-
}
|
|
1595
|
-
const bottomPanelTabBar = this.bottomPanel.findTabBar(title);
|
|
1596
|
-
if (bottomPanelTabBar) {
|
|
1597
|
-
return this.bottomPanel;
|
|
1598
|
-
}
|
|
1599
|
-
if (algorithm_1.ArrayExt.firstIndexOf(this.leftPanelHandler.tabBar.titles, title) > -1) {
|
|
1600
|
-
return this.leftPanelHandler.dockPanel;
|
|
1601
|
-
}
|
|
1602
|
-
if (algorithm_1.ArrayExt.firstIndexOf(this.rightPanelHandler.tabBar.titles, title) > -1) {
|
|
1603
|
-
return this.rightPanelHandler.dockPanel;
|
|
1604
|
-
}
|
|
1605
|
-
return undefined;
|
|
1606
|
-
}
|
|
1607
|
-
/**
|
|
1608
|
-
* Return the tab bar that has the currently active widget, or undefined.
|
|
1609
|
-
*/
|
|
1610
|
-
get currentTabBar() {
|
|
1611
|
-
const currentWidget = this.currentWidget;
|
|
1612
|
-
if (currentWidget) {
|
|
1613
|
-
return this.getTabBarFor(currentWidget);
|
|
1614
|
-
}
|
|
1615
|
-
}
|
|
1616
|
-
/**
|
|
1617
|
-
* Return the tab bar in the given shell area, or the tab bar that has the given widget, or undefined.
|
|
1618
|
-
*/
|
|
1619
|
-
getTabBarFor(widgetOrArea) {
|
|
1620
|
-
if (typeof widgetOrArea === 'string') {
|
|
1621
|
-
switch (widgetOrArea) {
|
|
1622
|
-
case 'main':
|
|
1623
|
-
return this.mainPanel.currentTabBar;
|
|
1624
|
-
case 'bottom':
|
|
1625
|
-
return this.bottomPanel.currentTabBar;
|
|
1626
|
-
case 'left':
|
|
1627
|
-
return this.leftPanelHandler.tabBar;
|
|
1628
|
-
case 'right':
|
|
1629
|
-
return this.rightPanelHandler.tabBar;
|
|
1630
|
-
case 'secondaryWindow':
|
|
1631
|
-
// Secondary windows don't have a tab bar
|
|
1632
|
-
return undefined;
|
|
1633
|
-
default:
|
|
1634
|
-
throw new Error('Illegal argument: ' + widgetOrArea);
|
|
1635
|
-
}
|
|
1636
|
-
}
|
|
1637
|
-
const widget = this.toTrackedStack(widgetOrArea.id).pop();
|
|
1638
|
-
if (!widget) {
|
|
1639
|
-
return undefined;
|
|
1640
|
-
}
|
|
1641
|
-
const widgetTitle = widget.title;
|
|
1642
|
-
const mainPanelTabBar = this.mainPanel.findTabBar(widgetTitle);
|
|
1643
|
-
if (mainPanelTabBar) {
|
|
1644
|
-
return mainPanelTabBar;
|
|
1645
|
-
}
|
|
1646
|
-
const bottomPanelTabBar = this.bottomPanel.findTabBar(widgetTitle);
|
|
1647
|
-
if (bottomPanelTabBar) {
|
|
1648
|
-
return bottomPanelTabBar;
|
|
1649
|
-
}
|
|
1650
|
-
const leftPanelTabBar = this.leftPanelHandler.tabBar;
|
|
1651
|
-
if (algorithm_1.ArrayExt.firstIndexOf(leftPanelTabBar.titles, widgetTitle) > -1) {
|
|
1652
|
-
return leftPanelTabBar;
|
|
1653
|
-
}
|
|
1654
|
-
const rightPanelTabBar = this.rightPanelHandler.tabBar;
|
|
1655
|
-
if (algorithm_1.ArrayExt.firstIndexOf(rightPanelTabBar.titles, widgetTitle) > -1) {
|
|
1656
|
-
return rightPanelTabBar;
|
|
1657
|
-
}
|
|
1658
|
-
return undefined;
|
|
1659
|
-
}
|
|
1660
|
-
/**
|
|
1661
|
-
* The tab bars contained in the main shell area. If there is no widget in the main area, the
|
|
1662
|
-
* returned array is empty.
|
|
1663
|
-
*/
|
|
1664
|
-
get mainAreaTabBars() {
|
|
1665
|
-
return (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1666
|
-
}
|
|
1667
|
-
/**
|
|
1668
|
-
* The tab bars contained in the bottom shell area. If there is no widget in the bottom area,
|
|
1669
|
-
* the returned array is empty.
|
|
1670
|
-
*/
|
|
1671
|
-
get bottomAreaTabBars() {
|
|
1672
|
-
return (0, algorithm_1.toArray)(this.bottomPanel.tabBars());
|
|
1673
|
-
}
|
|
1674
|
-
/**
|
|
1675
|
-
* The tab bars contained in all shell areas.
|
|
1676
|
-
*/
|
|
1677
|
-
get allTabBars() {
|
|
1678
|
-
return [...this.mainAreaTabBars, ...this.bottomAreaTabBars, this.leftPanelHandler.tabBar, this.rightPanelHandler.tabBar];
|
|
1679
|
-
}
|
|
1680
|
-
/*
|
|
1681
|
-
* Activate the next tab in the current tab bar.
|
|
1682
|
-
*/
|
|
1683
|
-
activateNextTabInTabBar(current = this.currentTabBar) {
|
|
1684
|
-
const index = this.nextTabIndexInTabBar(current);
|
|
1685
|
-
if (!current || index === -1) {
|
|
1686
|
-
return false;
|
|
1687
|
-
}
|
|
1688
|
-
current.currentIndex = index;
|
|
1689
|
-
if (current.currentTitle) {
|
|
1690
|
-
this.activateWidget(current.currentTitle.owner.id);
|
|
1691
|
-
}
|
|
1692
|
-
return true;
|
|
1693
|
-
}
|
|
1694
|
-
nextTabIndexInTabBar(current = this.currentTabBar) {
|
|
1695
|
-
if (!current || current.titles.length <= 1) {
|
|
1696
|
-
return -1;
|
|
1697
|
-
}
|
|
1698
|
-
const index = current.currentIndex;
|
|
1699
|
-
if (index === -1) {
|
|
1700
|
-
return -1;
|
|
1701
|
-
}
|
|
1702
|
-
if (index < current.titles.length - 1) {
|
|
1703
|
-
return index + 1;
|
|
1704
|
-
}
|
|
1705
|
-
return 0;
|
|
1706
|
-
}
|
|
1707
|
-
activateNextTab() {
|
|
1708
|
-
const current = this.currentTabBar;
|
|
1709
|
-
if (current) {
|
|
1710
|
-
const ci = current.currentIndex;
|
|
1711
|
-
if (ci !== -1) {
|
|
1712
|
-
if (ci < current.titles.length - 1) {
|
|
1713
|
-
current.currentIndex += 1;
|
|
1714
|
-
if (current.currentTitle) {
|
|
1715
|
-
this.activateWidget(current.currentTitle.owner.id);
|
|
1716
|
-
}
|
|
1717
|
-
return true;
|
|
1718
|
-
}
|
|
1719
|
-
else if (ci === current.titles.length - 1) {
|
|
1720
|
-
return this.activateNextTabBar(current);
|
|
1721
|
-
}
|
|
1722
|
-
}
|
|
1723
|
-
}
|
|
1724
|
-
return false;
|
|
1725
|
-
}
|
|
1726
|
-
activateNextTabBar(current = this.currentTabBar) {
|
|
1727
|
-
const nextBar = this.nextTabBar(current);
|
|
1728
|
-
if (nextBar) {
|
|
1729
|
-
nextBar.currentIndex = 0;
|
|
1730
|
-
if (nextBar.currentTitle) {
|
|
1731
|
-
this.activateWidget(nextBar.currentTitle.owner.id);
|
|
1732
|
-
}
|
|
1733
|
-
return true;
|
|
1734
|
-
}
|
|
1735
|
-
return false;
|
|
1736
|
-
}
|
|
1737
|
-
/**
|
|
1738
|
-
* Return the tab bar next to the given tab bar; return the given tab bar if there is no adjacent one.
|
|
1739
|
-
*/
|
|
1740
|
-
nextTabBar(current = this.currentTabBar) {
|
|
1741
|
-
let bars = (0, algorithm_1.toArray)(this.bottomPanel.tabBars());
|
|
1742
|
-
let len = bars.length;
|
|
1743
|
-
let ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1744
|
-
if (ci < 0) {
|
|
1745
|
-
bars = (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1746
|
-
len = bars.length;
|
|
1747
|
-
ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1748
|
-
}
|
|
1749
|
-
if (ci >= 0 && ci < len - 1) {
|
|
1750
|
-
return bars[ci + 1];
|
|
1751
|
-
}
|
|
1752
|
-
else if (ci >= 0 && ci === len - 1) {
|
|
1753
|
-
return bars[0];
|
|
1754
|
-
}
|
|
1755
|
-
else {
|
|
1756
|
-
return current;
|
|
1757
|
-
}
|
|
1758
|
-
}
|
|
1759
|
-
/*
|
|
1760
|
-
* Activate the previous tab in the current tab bar.
|
|
1761
|
-
*/
|
|
1762
|
-
activatePreviousTabInTabBar(current = this.currentTabBar) {
|
|
1763
|
-
const index = this.previousTabIndexInTabBar(current);
|
|
1764
|
-
if (!current || index === -1) {
|
|
1765
|
-
return false;
|
|
1766
|
-
}
|
|
1767
|
-
current.currentIndex = index;
|
|
1768
|
-
if (current.currentTitle) {
|
|
1769
|
-
this.activateWidget(current.currentTitle.owner.id);
|
|
1770
|
-
}
|
|
1771
|
-
return true;
|
|
1772
|
-
}
|
|
1773
|
-
previousTabIndexInTabBar(current = this.currentTabBar) {
|
|
1774
|
-
if (!current || current.titles.length <= 1) {
|
|
1775
|
-
return -1;
|
|
1776
|
-
}
|
|
1777
|
-
const index = current.currentIndex;
|
|
1778
|
-
if (index === -1) {
|
|
1779
|
-
return -1;
|
|
1780
|
-
}
|
|
1781
|
-
if (index > 0) {
|
|
1782
|
-
return index - 1;
|
|
1783
|
-
}
|
|
1784
|
-
return current.titles.length - 1;
|
|
1785
|
-
}
|
|
1786
|
-
activatePreviousTab() {
|
|
1787
|
-
const current = this.currentTabBar;
|
|
1788
|
-
if (current) {
|
|
1789
|
-
const ci = current.currentIndex;
|
|
1790
|
-
if (ci !== -1) {
|
|
1791
|
-
if (ci > 0) {
|
|
1792
|
-
current.currentIndex -= 1;
|
|
1793
|
-
if (current.currentTitle) {
|
|
1794
|
-
this.activateWidget(current.currentTitle.owner.id);
|
|
1795
|
-
}
|
|
1796
|
-
return true;
|
|
1797
|
-
}
|
|
1798
|
-
else if (ci === 0) {
|
|
1799
|
-
if (current && current.titles.length > 0) {
|
|
1800
|
-
current.currentIndex = current.titles.length - 1;
|
|
1801
|
-
if (current.currentTitle) {
|
|
1802
|
-
this.activateWidget(current.currentTitle.owner.id);
|
|
1803
|
-
}
|
|
1804
|
-
return true;
|
|
1805
|
-
}
|
|
1806
|
-
return this.activatePreviousTabBar(current);
|
|
1807
|
-
}
|
|
1808
|
-
}
|
|
1809
|
-
}
|
|
1810
|
-
return false;
|
|
1811
|
-
}
|
|
1812
|
-
activatePreviousTabBar(current = this.currentTabBar) {
|
|
1813
|
-
const prevBar = this.previousTabBar(current);
|
|
1814
|
-
if (!prevBar) {
|
|
1815
|
-
return false;
|
|
1816
|
-
}
|
|
1817
|
-
if (!prevBar.currentTitle) {
|
|
1818
|
-
prevBar.currentIndex = prevBar.titles.length - 1;
|
|
1819
|
-
}
|
|
1820
|
-
if (prevBar.currentTitle) {
|
|
1821
|
-
this.activateWidget(prevBar.currentTitle.owner.id);
|
|
1822
|
-
}
|
|
1823
|
-
return true;
|
|
1824
|
-
}
|
|
1825
|
-
/**
|
|
1826
|
-
* Return the tab bar previous to the given tab bar; return the given tab bar if there is no adjacent one.
|
|
1827
|
-
*/
|
|
1828
|
-
previousTabBar(current = this.currentTabBar) {
|
|
1829
|
-
const bars = (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1830
|
-
const len = bars.length;
|
|
1831
|
-
const ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1832
|
-
if (ci > 0) {
|
|
1833
|
-
return bars[ci - 1];
|
|
1834
|
-
}
|
|
1835
|
-
else if (ci === 0) {
|
|
1836
|
-
return bars[len - 1];
|
|
1837
|
-
}
|
|
1838
|
-
else {
|
|
1839
|
-
return current;
|
|
1840
|
-
}
|
|
1841
|
-
}
|
|
1842
|
-
/**
|
|
1843
|
-
* Test whether the current widget is dirty.
|
|
1844
|
-
*/
|
|
1845
|
-
canSave() {
|
|
1846
|
-
return this.saveResourceService.canSave(this.currentWidget);
|
|
1847
|
-
}
|
|
1848
|
-
/**
|
|
1849
|
-
* Save the current widget if it is dirty.
|
|
1850
|
-
*/
|
|
1851
|
-
async save(options) {
|
|
1852
|
-
await this.saveResourceService.save(this.currentWidget, options);
|
|
1853
|
-
}
|
|
1854
|
-
/**
|
|
1855
|
-
* Test whether there is a dirty widget.
|
|
1856
|
-
*/
|
|
1857
|
-
canSaveAll() {
|
|
1858
|
-
return this.tracker.widgets.some(widget => this.saveResourceService.canSave(widget));
|
|
1859
|
-
}
|
|
1860
|
-
/**
|
|
1861
|
-
* Save all dirty widgets.
|
|
1862
|
-
*/
|
|
1863
|
-
async saveAll(options) {
|
|
1864
|
-
for (const widget of this.widgets) {
|
|
1865
|
-
if (this.saveResourceService.canSaveNotSaveAs(widget)) {
|
|
1866
|
-
await this.saveResourceService.save(widget, options);
|
|
1867
|
-
}
|
|
1868
|
-
}
|
|
1869
|
-
}
|
|
1870
|
-
/**
|
|
1871
|
-
* Returns a snapshot of all tracked widgets to allow async modifications.
|
|
1872
|
-
*/
|
|
1873
|
-
get widgets() {
|
|
1874
|
-
return [...this.tracker.widgets];
|
|
1875
|
-
}
|
|
1876
|
-
getWidgetById(id) {
|
|
1877
|
-
for (const widget of this.tracker.widgets) {
|
|
1878
|
-
if (widget.id === id) {
|
|
1879
|
-
return widget;
|
|
1880
|
-
}
|
|
1881
|
-
}
|
|
1882
|
-
return undefined;
|
|
1883
|
-
}
|
|
1884
|
-
canToggleMaximized(widget = this.currentWidget) {
|
|
1885
|
-
const area = widget && this.getAreaFor(widget);
|
|
1886
|
-
return area === 'main' || area === 'bottom';
|
|
1887
|
-
}
|
|
1888
|
-
toggleMaximized(widget = this.currentWidget) {
|
|
1889
|
-
const area = widget && this.getAreaPanelFor(widget);
|
|
1890
|
-
if (area instanceof theia_dock_panel_1.TheiaDockPanel && (area === this.mainPanel || area === this.bottomPanel)) {
|
|
1891
|
-
area.toggleMaximized();
|
|
1892
|
-
this.revealWidget(widget.id);
|
|
1893
|
-
}
|
|
1894
|
-
}
|
|
1895
|
-
};
|
|
1896
|
-
(0, tslib_1.__decorate)([
|
|
1897
|
-
(0, inversify_1.inject)(context_key_service_1.ContextKeyService),
|
|
1898
|
-
(0, tslib_1.__metadata)("design:type", Object)
|
|
1899
|
-
], ApplicationShell.prototype, "contextKeyService", void 0);
|
|
1900
|
-
(0, tslib_1.__decorate)([
|
|
1901
|
-
(0, inversify_1.inject)(opener_service_1.OpenerService),
|
|
1902
|
-
(0, tslib_1.__metadata)("design:type", Object)
|
|
1903
|
-
], ApplicationShell.prototype, "openerService", void 0);
|
|
1904
|
-
(0, tslib_1.__decorate)([
|
|
1905
|
-
(0, inversify_1.inject)(theia_dock_panel_1.TheiaDockPanel.Factory),
|
|
1906
|
-
(0, tslib_1.__metadata)("design:type", Function)
|
|
1907
|
-
], ApplicationShell.prototype, "dockPanelFactory", void 0);
|
|
1908
|
-
(0, tslib_1.__decorate)([
|
|
1909
|
-
(0, inversify_1.postConstruct)(),
|
|
1910
|
-
(0, tslib_1.__metadata)("design:type", Function),
|
|
1911
|
-
(0, tslib_1.__metadata)("design:paramtypes", []),
|
|
1912
|
-
(0, tslib_1.__metadata)("design:returntype", void 0)
|
|
1913
|
-
], ApplicationShell.prototype, "init", null);
|
|
1914
|
-
ApplicationShell = ApplicationShell_1 = (0, tslib_1.__decorate)([
|
|
1915
|
-
(0, inversify_1.injectable)(),
|
|
1916
|
-
(0, tslib_1.__param)(0, (0, inversify_1.inject)(exports.DockPanelRendererFactory)),
|
|
1917
|
-
(0, tslib_1.__param)(1, (0, inversify_1.inject)(status_bar_1.StatusBarImpl)),
|
|
1918
|
-
(0, tslib_1.__param)(2, (0, inversify_1.inject)(side_panel_handler_1.SidePanelHandlerFactory)),
|
|
1919
|
-
(0, tslib_1.__param)(3, (0, inversify_1.inject)(split_panels_1.SplitPositionHandler)),
|
|
1920
|
-
(0, tslib_1.__param)(4, (0, inversify_1.inject)(frontend_application_state_1.FrontendApplicationStateService)),
|
|
1921
|
-
(0, tslib_1.__param)(5, (0, inversify_1.inject)(exports.ApplicationShellOptions)),
|
|
1922
|
-
(0, tslib_1.__param)(5, (0, inversify_1.optional)()),
|
|
1923
|
-
(0, tslib_1.__param)(6, (0, inversify_1.inject)(core_preferences_1.CorePreferences)),
|
|
1924
|
-
(0, tslib_1.__param)(7, (0, inversify_1.inject)(save_resource_service_1.SaveResourceService)),
|
|
1925
|
-
(0, tslib_1.__param)(8, (0, inversify_1.inject)(secondary_window_handler_1.SecondaryWindowHandler)),
|
|
1926
|
-
(0, tslib_1.__param)(9, (0, inversify_1.inject)(window_service_1.WindowService)),
|
|
1927
|
-
(0, tslib_1.__metadata)("design:paramtypes", [Function, status_bar_1.StatusBarImpl, Function, split_panels_1.SplitPositionHandler,
|
|
1928
|
-
frontend_application_state_1.FrontendApplicationStateService, Object, Object, save_resource_service_1.SaveResourceService,
|
|
1929
|
-
secondary_window_handler_1.SecondaryWindowHandler, Object])
|
|
1930
|
-
], ApplicationShell);
|
|
1931
|
-
exports.ApplicationShell = ApplicationShell;
|
|
1932
|
-
/**
|
|
1933
|
-
* The namespace for `ApplicationShell` class statics.
|
|
1934
|
-
*/
|
|
1935
|
-
(function (ApplicationShell) {
|
|
1936
|
-
ApplicationShell.areaLabels = {
|
|
1937
|
-
main: nls_1.nls.localizeByDefault('Main'),
|
|
1938
|
-
top: nls_1.nls.localizeByDefault('Top'),
|
|
1939
|
-
left: nls_1.nls.localizeByDefault('Left'),
|
|
1940
|
-
right: nls_1.nls.localizeByDefault('Right'),
|
|
1941
|
-
bottom: nls_1.nls.localizeByDefault('Bottom'),
|
|
1942
|
-
secondaryWindow: nls_1.nls.localize('theia/shell-area/secondary', 'Secondary Window'),
|
|
1943
|
-
};
|
|
1944
|
-
/**
|
|
1945
|
-
* The _side areas_ are those shell areas that can be collapsed and expanded,
|
|
1946
|
-
* i.e. `left`, `right`, and `bottom`.
|
|
1947
|
-
*/
|
|
1948
|
-
function isSideArea(area) {
|
|
1949
|
-
return area === 'left' || area === 'right' || area === 'bottom';
|
|
1950
|
-
}
|
|
1951
|
-
ApplicationShell.isSideArea = isSideArea;
|
|
1952
|
-
function isValidArea(area) {
|
|
1953
|
-
const areas = ['main', 'top', 'left', 'right', 'bottom', 'secondaryWindow'];
|
|
1954
|
-
return typeof area === 'string' && areas.includes(area);
|
|
1955
|
-
}
|
|
1956
|
-
ApplicationShell.isValidArea = isValidArea;
|
|
1957
|
-
/**
|
|
1958
|
-
* The default values for application shell options.
|
|
1959
|
-
*/
|
|
1960
|
-
ApplicationShell.DEFAULT_OPTIONS = Object.freeze({
|
|
1961
|
-
bottomPanel: Object.freeze({
|
|
1962
|
-
emptySize: 140,
|
|
1963
|
-
expandThreshold: 160,
|
|
1964
|
-
expandDuration: 0,
|
|
1965
|
-
initialSizeRatio: 0.382
|
|
1966
|
-
}),
|
|
1967
|
-
leftPanel: Object.freeze({
|
|
1968
|
-
emptySize: 140,
|
|
1969
|
-
expandThreshold: 140,
|
|
1970
|
-
expandDuration: 0,
|
|
1971
|
-
initialSizeRatio: 0.191
|
|
1972
|
-
}),
|
|
1973
|
-
rightPanel: Object.freeze({
|
|
1974
|
-
emptySize: 140,
|
|
1975
|
-
expandThreshold: 140,
|
|
1976
|
-
expandDuration: 0,
|
|
1977
|
-
initialSizeRatio: 0.191
|
|
1978
|
-
})
|
|
1979
|
-
});
|
|
1980
|
-
function isOpenToSideMode(mode) {
|
|
1981
|
-
return mode === 'open-to-left' || mode === 'open-to-right';
|
|
1982
|
-
}
|
|
1983
|
-
ApplicationShell.isOpenToSideMode = isOpenToSideMode;
|
|
1984
|
-
let TrackableWidgetProvider;
|
|
1985
|
-
(function (TrackableWidgetProvider) {
|
|
1986
|
-
function is(widget) {
|
|
1987
|
-
return (0, common_1.isObject)(widget) && 'getTrackableWidgets' in widget;
|
|
1988
|
-
}
|
|
1989
|
-
TrackableWidgetProvider.is = is;
|
|
1990
|
-
})(TrackableWidgetProvider = ApplicationShell.TrackableWidgetProvider || (ApplicationShell.TrackableWidgetProvider = {}));
|
|
1991
|
-
})(ApplicationShell = exports.ApplicationShell || (exports.ApplicationShell = {}));
|
|
1992
|
-
exports.ApplicationShell = ApplicationShell;
|
|
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
|
+
var ApplicationShell_1;
|
|
18
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
exports.ApplicationShell = exports.DockPanelRenderer = exports.DockPanelRendererFactory = exports.ApplicationShellOptions = exports.applicationShellLayoutVersion = void 0;
|
|
20
|
+
const tslib_1 = require("tslib");
|
|
21
|
+
const inversify_1 = require("inversify");
|
|
22
|
+
const algorithm_1 = require("@phosphor/algorithm");
|
|
23
|
+
const widgets_1 = require("@phosphor/widgets");
|
|
24
|
+
const common_1 = require("../../common");
|
|
25
|
+
const browser_1 = require("../browser");
|
|
26
|
+
const saveable_1 = require("../saveable");
|
|
27
|
+
const status_bar_1 = require("../status-bar/status-bar");
|
|
28
|
+
const theia_dock_panel_1 = require("./theia-dock-panel");
|
|
29
|
+
const side_panel_handler_1 = require("./side-panel-handler");
|
|
30
|
+
const tab_bars_1 = require("./tab-bars");
|
|
31
|
+
const split_panels_1 = require("./split-panels");
|
|
32
|
+
const frontend_application_state_1 = require("../frontend-application-state");
|
|
33
|
+
const tab_bar_toolbar_1 = require("./tab-bar-toolbar");
|
|
34
|
+
const context_key_service_1 = require("../context-key-service");
|
|
35
|
+
const event_1 = require("../../common/event");
|
|
36
|
+
const widgets_2 = require("../widgets");
|
|
37
|
+
const core_preferences_1 = require("../core-preferences");
|
|
38
|
+
const breadcrumbs_renderer_1 = require("../breadcrumbs/breadcrumbs-renderer");
|
|
39
|
+
const promise_util_1 = require("../../common/promise-util");
|
|
40
|
+
const save_resource_service_1 = require("../save-resource-service");
|
|
41
|
+
const nls_1 = require("../../common/nls");
|
|
42
|
+
const secondary_window_handler_1 = require("../secondary-window-handler");
|
|
43
|
+
const uri_1 = require("../../common/uri");
|
|
44
|
+
const opener_service_1 = require("../opener-service");
|
|
45
|
+
const previewable_widget_1 = require("../widgets/previewable-widget");
|
|
46
|
+
const window_service_1 = require("../window/window-service");
|
|
47
|
+
/** The class name added to ApplicationShell instances. */
|
|
48
|
+
const APPLICATION_SHELL_CLASS = 'theia-ApplicationShell';
|
|
49
|
+
/** The class name added to the main and bottom area panels. */
|
|
50
|
+
const MAIN_BOTTOM_AREA_CLASS = 'theia-app-centers';
|
|
51
|
+
/** Status bar entry identifier for the bottom panel toggle button. */
|
|
52
|
+
const BOTTOM_PANEL_TOGGLE_ID = 'bottom-panel-toggle';
|
|
53
|
+
/** The class name added to the main area panel. */
|
|
54
|
+
const MAIN_AREA_CLASS = 'theia-app-main';
|
|
55
|
+
/** The class name added to the bottom area panel. */
|
|
56
|
+
const BOTTOM_AREA_CLASS = 'theia-app-bottom';
|
|
57
|
+
/**
|
|
58
|
+
* When a version is increased, make sure to introduce a migration (ApplicationShellLayoutMigration) to this version.
|
|
59
|
+
*/
|
|
60
|
+
exports.applicationShellLayoutVersion = 5.0;
|
|
61
|
+
exports.ApplicationShellOptions = Symbol('ApplicationShellOptions');
|
|
62
|
+
exports.DockPanelRendererFactory = Symbol('DockPanelRendererFactory');
|
|
63
|
+
/**
|
|
64
|
+
* A renderer for dock panels that supports context menus on tabs.
|
|
65
|
+
*/
|
|
66
|
+
let DockPanelRenderer = class DockPanelRenderer {
|
|
67
|
+
constructor(tabBarRendererFactory, tabBarToolbarRegistry, tabBarToolbarFactory, breadcrumbsRendererFactory, corePreferences) {
|
|
68
|
+
this.tabBarRendererFactory = tabBarRendererFactory;
|
|
69
|
+
this.tabBarToolbarRegistry = tabBarToolbarRegistry;
|
|
70
|
+
this.tabBarToolbarFactory = tabBarToolbarFactory;
|
|
71
|
+
this.breadcrumbsRendererFactory = breadcrumbsRendererFactory;
|
|
72
|
+
this.corePreferences = corePreferences;
|
|
73
|
+
this.tabBarClasses = [];
|
|
74
|
+
this.onDidCreateTabBarEmitter = new event_1.Emitter();
|
|
75
|
+
}
|
|
76
|
+
get onDidCreateTabBar() {
|
|
77
|
+
return this.onDidCreateTabBarEmitter.event;
|
|
78
|
+
}
|
|
79
|
+
createTabBar() {
|
|
80
|
+
const getDynamicTabOptions = () => {
|
|
81
|
+
if (this.corePreferences.get('workbench.tab.shrinkToFit.enabled')) {
|
|
82
|
+
return {
|
|
83
|
+
minimumTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.minimumSize'),
|
|
84
|
+
defaultTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.defaultSize')
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
return undefined;
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
const renderer = this.tabBarRendererFactory();
|
|
92
|
+
const tabBar = new tab_bars_1.ToolbarAwareTabBar(this.tabBarToolbarRegistry, this.tabBarToolbarFactory, this.breadcrumbsRendererFactory, {
|
|
93
|
+
renderer,
|
|
94
|
+
// Scroll bar options
|
|
95
|
+
handlers: ['drag-thumb', 'keyboard', 'wheel', 'touch'],
|
|
96
|
+
useBothWheelAxes: true,
|
|
97
|
+
scrollXMarginOffset: 4,
|
|
98
|
+
suppressScrollY: true
|
|
99
|
+
}, getDynamicTabOptions());
|
|
100
|
+
this.tabBarClasses.forEach(c => tabBar.addClass(c));
|
|
101
|
+
renderer.tabBar = tabBar;
|
|
102
|
+
renderer.contextMenuPath = tab_bars_1.SHELL_TABBAR_CONTEXT_MENU;
|
|
103
|
+
tabBar.currentChanged.connect(this.onCurrentTabChanged, this);
|
|
104
|
+
const prefChangeDisposable = this.corePreferences.onPreferenceChanged(change => {
|
|
105
|
+
if (change.preferenceName === 'workbench.tab.shrinkToFit.enabled' ||
|
|
106
|
+
change.preferenceName === 'workbench.tab.shrinkToFit.minimumSize' ||
|
|
107
|
+
change.preferenceName === 'workbench.tab.shrinkToFit.defaultSize') {
|
|
108
|
+
tabBar.dynamicTabOptions = getDynamicTabOptions();
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
tabBar.disposed.connect(() => {
|
|
112
|
+
prefChangeDisposable.dispose();
|
|
113
|
+
renderer.dispose();
|
|
114
|
+
});
|
|
115
|
+
this.onDidCreateTabBarEmitter.fire(tabBar);
|
|
116
|
+
return tabBar;
|
|
117
|
+
}
|
|
118
|
+
createHandle() {
|
|
119
|
+
return widgets_1.DockPanel.defaultRenderer.createHandle();
|
|
120
|
+
}
|
|
121
|
+
onCurrentTabChanged(sender, { currentIndex }) {
|
|
122
|
+
if (currentIndex >= 0) {
|
|
123
|
+
sender.revealTab(currentIndex);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
(0, tslib_1.__decorate)([
|
|
128
|
+
(0, inversify_1.inject)(theia_dock_panel_1.TheiaDockPanel.Factory),
|
|
129
|
+
(0, tslib_1.__metadata)("design:type", Function)
|
|
130
|
+
], DockPanelRenderer.prototype, "dockPanelFactory", void 0);
|
|
131
|
+
DockPanelRenderer = (0, tslib_1.__decorate)([
|
|
132
|
+
(0, inversify_1.injectable)(),
|
|
133
|
+
(0, tslib_1.__param)(0, (0, inversify_1.inject)(tab_bars_1.TabBarRendererFactory)),
|
|
134
|
+
(0, tslib_1.__param)(1, (0, inversify_1.inject)(tab_bar_toolbar_1.TabBarToolbarRegistry)),
|
|
135
|
+
(0, tslib_1.__param)(2, (0, inversify_1.inject)(tab_bar_toolbar_1.TabBarToolbarFactory)),
|
|
136
|
+
(0, tslib_1.__param)(3, (0, inversify_1.inject)(breadcrumbs_renderer_1.BreadcrumbsRendererFactory)),
|
|
137
|
+
(0, tslib_1.__param)(4, (0, inversify_1.inject)(core_preferences_1.CorePreferences)),
|
|
138
|
+
(0, tslib_1.__metadata)("design:paramtypes", [Function, tab_bar_toolbar_1.TabBarToolbarRegistry, Function, Function, Object])
|
|
139
|
+
], DockPanelRenderer);
|
|
140
|
+
exports.DockPanelRenderer = DockPanelRenderer;
|
|
141
|
+
/**
|
|
142
|
+
* The application shell manages the top-level widgets of the application. Use this class to
|
|
143
|
+
* add, remove, or activate a widget.
|
|
144
|
+
*/
|
|
145
|
+
let ApplicationShell = ApplicationShell_1 = class ApplicationShell extends widgets_1.Widget {
|
|
146
|
+
/**
|
|
147
|
+
* Construct a new application shell.
|
|
148
|
+
*/
|
|
149
|
+
constructor(dockPanelRendererFactory, statusBar, sidePanelHandlerFactory, splitPositionHandler, applicationStateService, options = {}, corePreferences, saveResourceService, secondaryWindowHandler, windowService) {
|
|
150
|
+
super(options);
|
|
151
|
+
this.dockPanelRendererFactory = dockPanelRendererFactory;
|
|
152
|
+
this.statusBar = statusBar;
|
|
153
|
+
this.sidePanelHandlerFactory = sidePanelHandlerFactory;
|
|
154
|
+
this.splitPositionHandler = splitPositionHandler;
|
|
155
|
+
this.applicationStateService = applicationStateService;
|
|
156
|
+
this.corePreferences = corePreferences;
|
|
157
|
+
this.saveResourceService = saveResourceService;
|
|
158
|
+
this.secondaryWindowHandler = secondaryWindowHandler;
|
|
159
|
+
this.windowService = windowService;
|
|
160
|
+
/**
|
|
161
|
+
* The current state of the bottom panel.
|
|
162
|
+
*/
|
|
163
|
+
this.bottomPanelState = {
|
|
164
|
+
empty: true,
|
|
165
|
+
expansion: side_panel_handler_1.SidePanel.ExpansionState.collapsed,
|
|
166
|
+
pendingUpdate: Promise.resolve()
|
|
167
|
+
};
|
|
168
|
+
this.tracker = new widgets_1.FocusTracker();
|
|
169
|
+
this.onDidAddWidgetEmitter = new event_1.Emitter();
|
|
170
|
+
this.onDidAddWidget = this.onDidAddWidgetEmitter.event;
|
|
171
|
+
this.onDidRemoveWidgetEmitter = new event_1.Emitter();
|
|
172
|
+
this.onDidRemoveWidget = this.onDidRemoveWidgetEmitter.event;
|
|
173
|
+
this.onDidChangeActiveWidgetEmitter = new event_1.Emitter();
|
|
174
|
+
this.onDidChangeActiveWidget = this.onDidChangeActiveWidgetEmitter.event;
|
|
175
|
+
this.onDidChangeCurrentWidgetEmitter = new event_1.Emitter();
|
|
176
|
+
this.onDidChangeCurrentWidget = this.onDidChangeCurrentWidgetEmitter.event;
|
|
177
|
+
this.onDidDoubleClickMainAreaEmitter = new event_1.Emitter();
|
|
178
|
+
this.onDidDoubleClickMainArea = this.onDidDoubleClickMainAreaEmitter.event;
|
|
179
|
+
this.toDisposeOnActiveChanged = new common_1.DisposableCollection();
|
|
180
|
+
this.activationTimeout = 2000;
|
|
181
|
+
this.toDisposeOnActivationCheck = new common_1.DisposableCollection();
|
|
182
|
+
// Merge the user-defined application options with the default options
|
|
183
|
+
this.options = {
|
|
184
|
+
bottomPanel: {
|
|
185
|
+
...ApplicationShell_1.DEFAULT_OPTIONS.bottomPanel,
|
|
186
|
+
...(options === null || options === void 0 ? void 0 : options.bottomPanel) || {}
|
|
187
|
+
},
|
|
188
|
+
leftPanel: {
|
|
189
|
+
...ApplicationShell_1.DEFAULT_OPTIONS.leftPanel,
|
|
190
|
+
...(options === null || options === void 0 ? void 0 : options.leftPanel) || {}
|
|
191
|
+
},
|
|
192
|
+
rightPanel: {
|
|
193
|
+
...ApplicationShell_1.DEFAULT_OPTIONS.rightPanel,
|
|
194
|
+
...(options === null || options === void 0 ? void 0 : options.rightPanel) || {}
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
fireDidAddWidget(widget) {
|
|
199
|
+
this.onDidAddWidgetEmitter.fire(widget);
|
|
200
|
+
}
|
|
201
|
+
fireDidRemoveWidget(widget) {
|
|
202
|
+
this.onDidRemoveWidgetEmitter.fire(widget);
|
|
203
|
+
}
|
|
204
|
+
get mainPanelRenderer() {
|
|
205
|
+
return this._mainPanelRenderer;
|
|
206
|
+
}
|
|
207
|
+
init() {
|
|
208
|
+
this.initializeShell();
|
|
209
|
+
this.initSidebarVisibleKeyContext();
|
|
210
|
+
this.initFocusKeyContexts();
|
|
211
|
+
if (!common_1.environment.electron.is()) {
|
|
212
|
+
this.corePreferences.ready.then(() => {
|
|
213
|
+
this.setTopPanelVisibility(this.corePreferences['window.menuBarVisibility']);
|
|
214
|
+
});
|
|
215
|
+
this.corePreferences.onPreferenceChanged(preference => {
|
|
216
|
+
if (preference.preferenceName === 'window.menuBarVisibility') {
|
|
217
|
+
this.setTopPanelVisibility(preference.newValue);
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
this.corePreferences.onPreferenceChanged(preference => {
|
|
222
|
+
if (preference.preferenceName === 'window.tabbar.enhancedPreview') {
|
|
223
|
+
this.allTabBars.forEach(tabBar => {
|
|
224
|
+
tabBar.update();
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
initializeShell() {
|
|
230
|
+
this.addClass(APPLICATION_SHELL_CLASS);
|
|
231
|
+
this.id = 'theia-app-shell';
|
|
232
|
+
this.mainPanel = this.createMainPanel();
|
|
233
|
+
this.topPanel = this.createTopPanel();
|
|
234
|
+
this.bottomPanel = this.createBottomPanel();
|
|
235
|
+
this.leftPanelHandler = this.sidePanelHandlerFactory();
|
|
236
|
+
this.leftPanelHandler.create('left', this.options.leftPanel);
|
|
237
|
+
this.leftPanelHandler.dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
238
|
+
this.leftPanelHandler.dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
239
|
+
this.rightPanelHandler = this.sidePanelHandlerFactory();
|
|
240
|
+
this.rightPanelHandler.create('right', this.options.rightPanel);
|
|
241
|
+
this.rightPanelHandler.dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
242
|
+
this.rightPanelHandler.dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
243
|
+
this.secondaryWindowHandler.init(this);
|
|
244
|
+
this.secondaryWindowHandler.onDidAddWidget(([widget, window]) => this.fireDidAddWidget(widget));
|
|
245
|
+
this.secondaryWindowHandler.onDidRemoveWidget(([widget, window]) => this.fireDidRemoveWidget(widget));
|
|
246
|
+
this.layout = this.createLayout();
|
|
247
|
+
this.tracker.currentChanged.connect(this.onCurrentChanged, this);
|
|
248
|
+
this.tracker.activeChanged.connect(this.onActiveChanged, this);
|
|
249
|
+
}
|
|
250
|
+
initSidebarVisibleKeyContext() {
|
|
251
|
+
const leftSideBarPanel = this.leftPanelHandler.dockPanel;
|
|
252
|
+
const sidebarVisibleKey = this.contextKeyService.createKey('sidebarVisible', leftSideBarPanel.isVisible);
|
|
253
|
+
const onAfterShow = leftSideBarPanel['onAfterShow'].bind(leftSideBarPanel);
|
|
254
|
+
leftSideBarPanel['onAfterShow'] = (msg) => {
|
|
255
|
+
onAfterShow(msg);
|
|
256
|
+
sidebarVisibleKey.set(true);
|
|
257
|
+
};
|
|
258
|
+
const onAfterHide = leftSideBarPanel['onAfterHide'].bind(leftSideBarPanel);
|
|
259
|
+
leftSideBarPanel['onAfterHide'] = (msg) => {
|
|
260
|
+
onAfterHide(msg);
|
|
261
|
+
sidebarVisibleKey.set(false);
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
initFocusKeyContexts() {
|
|
265
|
+
const sideBarFocus = this.contextKeyService.createKey('sideBarFocus', false);
|
|
266
|
+
const panelFocus = this.contextKeyService.createKey('panelFocus', false);
|
|
267
|
+
const updateFocusContextKeys = () => {
|
|
268
|
+
const area = this.activeWidget && this.getAreaFor(this.activeWidget);
|
|
269
|
+
sideBarFocus.set(area === 'left');
|
|
270
|
+
panelFocus.set(area === 'main');
|
|
271
|
+
};
|
|
272
|
+
updateFocusContextKeys();
|
|
273
|
+
this.onDidChangeActiveWidget(updateFocusContextKeys);
|
|
274
|
+
}
|
|
275
|
+
setTopPanelVisibility(preference) {
|
|
276
|
+
const hiddenPreferences = ['compact', 'hidden'];
|
|
277
|
+
this.topPanel.setHidden(hiddenPreferences.includes(preference));
|
|
278
|
+
}
|
|
279
|
+
onBeforeAttach(msg) {
|
|
280
|
+
document.addEventListener('p-dragenter', this, true);
|
|
281
|
+
document.addEventListener('p-dragover', this, true);
|
|
282
|
+
document.addEventListener('p-dragleave', this, true);
|
|
283
|
+
document.addEventListener('p-drop', this, true);
|
|
284
|
+
}
|
|
285
|
+
onAfterDetach(msg) {
|
|
286
|
+
document.removeEventListener('p-dragenter', this, true);
|
|
287
|
+
document.removeEventListener('p-dragover', this, true);
|
|
288
|
+
document.removeEventListener('p-dragleave', this, true);
|
|
289
|
+
document.removeEventListener('p-drop', this, true);
|
|
290
|
+
}
|
|
291
|
+
handleEvent(event) {
|
|
292
|
+
switch (event.type) {
|
|
293
|
+
case 'p-dragenter':
|
|
294
|
+
this.onDragEnter(event);
|
|
295
|
+
break;
|
|
296
|
+
case 'p-dragover':
|
|
297
|
+
this.onDragOver(event);
|
|
298
|
+
break;
|
|
299
|
+
case 'p-drop':
|
|
300
|
+
this.onDrop(event);
|
|
301
|
+
break;
|
|
302
|
+
case 'p-dragleave':
|
|
303
|
+
this.onDragLeave(event);
|
|
304
|
+
break;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
onDragEnter({ mimeData }) {
|
|
308
|
+
if (!this.dragState) {
|
|
309
|
+
if (mimeData && mimeData.hasData('application/vnd.phosphor.widget-factory')) {
|
|
310
|
+
// The drag contains a widget, so we'll track it and expand side panels as needed
|
|
311
|
+
this.dragState = {
|
|
312
|
+
startTime: performance.now(),
|
|
313
|
+
leftExpanded: false,
|
|
314
|
+
rightExpanded: false,
|
|
315
|
+
bottomExpanded: false
|
|
316
|
+
};
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
onDragOver(event) {
|
|
321
|
+
const state = this.dragState;
|
|
322
|
+
if (state) {
|
|
323
|
+
state.lastDragOver = event;
|
|
324
|
+
if (state.leaveTimeout) {
|
|
325
|
+
window.clearTimeout(state.leaveTimeout);
|
|
326
|
+
state.leaveTimeout = undefined;
|
|
327
|
+
}
|
|
328
|
+
const { clientX, clientY } = event;
|
|
329
|
+
const { offsetLeft, offsetTop, clientWidth, clientHeight } = this.node;
|
|
330
|
+
// Don't expand any side panels right after the drag has started
|
|
331
|
+
const allowExpansion = performance.now() - state.startTime >= 500;
|
|
332
|
+
const expLeft = allowExpansion && clientX >= offsetLeft
|
|
333
|
+
&& clientX <= offsetLeft + this.options.leftPanel.expandThreshold;
|
|
334
|
+
const expRight = allowExpansion && clientX <= offsetLeft + clientWidth
|
|
335
|
+
&& clientX >= offsetLeft + clientWidth - this.options.rightPanel.expandThreshold;
|
|
336
|
+
const expBottom = allowExpansion && !expLeft && !expRight && clientY <= offsetTop + clientHeight
|
|
337
|
+
&& clientY >= offsetTop + clientHeight - this.options.bottomPanel.expandThreshold;
|
|
338
|
+
// eslint-disable-next-line no-null/no-null
|
|
339
|
+
if (expLeft && !state.leftExpanded && this.leftPanelHandler.tabBar.currentTitle === null) {
|
|
340
|
+
// The mouse cursor is moved close to the left border
|
|
341
|
+
this.leftPanelHandler.expand();
|
|
342
|
+
this.leftPanelHandler.state.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
343
|
+
state.leftExpanded = true;
|
|
344
|
+
}
|
|
345
|
+
else if (!expLeft && state.leftExpanded) {
|
|
346
|
+
// The mouse cursor is moved away from the left border
|
|
347
|
+
this.leftPanelHandler.collapse();
|
|
348
|
+
state.leftExpanded = false;
|
|
349
|
+
}
|
|
350
|
+
// eslint-disable-next-line no-null/no-null
|
|
351
|
+
if (expRight && !state.rightExpanded && this.rightPanelHandler.tabBar.currentTitle === null) {
|
|
352
|
+
// The mouse cursor is moved close to the right border
|
|
353
|
+
this.rightPanelHandler.expand();
|
|
354
|
+
this.rightPanelHandler.state.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
355
|
+
state.rightExpanded = true;
|
|
356
|
+
}
|
|
357
|
+
else if (!expRight && state.rightExpanded) {
|
|
358
|
+
// The mouse cursor is moved away from the right border
|
|
359
|
+
this.rightPanelHandler.collapse();
|
|
360
|
+
state.rightExpanded = false;
|
|
361
|
+
}
|
|
362
|
+
if (expBottom && !state.bottomExpanded && this.bottomPanel.isHidden) {
|
|
363
|
+
// The mouse cursor is moved close to the bottom border
|
|
364
|
+
this.expandBottomPanel();
|
|
365
|
+
this.bottomPanelState.pendingUpdate.then(() => this.dispatchMouseMove());
|
|
366
|
+
state.bottomExpanded = true;
|
|
367
|
+
}
|
|
368
|
+
else if (!expBottom && state.bottomExpanded) {
|
|
369
|
+
// The mouse cursor is moved away from the bottom border
|
|
370
|
+
this.collapseBottomPanel();
|
|
371
|
+
state.bottomExpanded = false;
|
|
372
|
+
}
|
|
373
|
+
}
|
|
374
|
+
}
|
|
375
|
+
/**
|
|
376
|
+
* This method is called after a side panel has been expanded while dragging a widget. It fires
|
|
377
|
+
* a `mousemove` event so that the drag overlay markers are updated correctly in all dock panels.
|
|
378
|
+
*/
|
|
379
|
+
dispatchMouseMove() {
|
|
380
|
+
if (this.dragState && this.dragState.lastDragOver) {
|
|
381
|
+
const { clientX, clientY } = this.dragState.lastDragOver;
|
|
382
|
+
const event = document.createEvent('MouseEvent');
|
|
383
|
+
event.initMouseEvent('mousemove', true, true, window, 0, 0, 0,
|
|
384
|
+
// eslint-disable-next-line no-null/no-null
|
|
385
|
+
clientX, clientY, false, false, false, false, 0, null);
|
|
386
|
+
document.dispatchEvent(event);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
onDrop(event) {
|
|
390
|
+
const state = this.dragState;
|
|
391
|
+
if (state) {
|
|
392
|
+
if (state.leaveTimeout) {
|
|
393
|
+
window.clearTimeout(state.leaveTimeout);
|
|
394
|
+
}
|
|
395
|
+
this.dragState = undefined;
|
|
396
|
+
window.requestAnimationFrame(() => {
|
|
397
|
+
// Clean up the side panel state in the next frame
|
|
398
|
+
if (this.leftPanelHandler.dockPanel.isEmpty) {
|
|
399
|
+
this.leftPanelHandler.collapse();
|
|
400
|
+
}
|
|
401
|
+
if (this.rightPanelHandler.dockPanel.isEmpty) {
|
|
402
|
+
this.rightPanelHandler.collapse();
|
|
403
|
+
}
|
|
404
|
+
if (this.bottomPanel.isEmpty) {
|
|
405
|
+
this.collapseBottomPanel();
|
|
406
|
+
}
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
onDragLeave(event) {
|
|
411
|
+
const state = this.dragState;
|
|
412
|
+
if (state) {
|
|
413
|
+
state.lastDragOver = undefined;
|
|
414
|
+
if (state.leaveTimeout) {
|
|
415
|
+
window.clearTimeout(state.leaveTimeout);
|
|
416
|
+
}
|
|
417
|
+
state.leaveTimeout = window.setTimeout(() => {
|
|
418
|
+
this.dragState = undefined;
|
|
419
|
+
if (state.leftExpanded || this.leftPanelHandler.dockPanel.isEmpty) {
|
|
420
|
+
this.leftPanelHandler.collapse();
|
|
421
|
+
}
|
|
422
|
+
if (state.rightExpanded || this.rightPanelHandler.dockPanel.isEmpty) {
|
|
423
|
+
this.rightPanelHandler.collapse();
|
|
424
|
+
}
|
|
425
|
+
if (state.bottomExpanded || this.bottomPanel.isEmpty) {
|
|
426
|
+
this.collapseBottomPanel();
|
|
427
|
+
}
|
|
428
|
+
}, 100);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
/**
|
|
432
|
+
* Create the dock panel in the main shell area.
|
|
433
|
+
*/
|
|
434
|
+
createMainPanel() {
|
|
435
|
+
const renderer = this.dockPanelRendererFactory();
|
|
436
|
+
renderer.tabBarClasses.push(MAIN_BOTTOM_AREA_CLASS);
|
|
437
|
+
renderer.tabBarClasses.push(MAIN_AREA_CLASS);
|
|
438
|
+
this._mainPanelRenderer = renderer;
|
|
439
|
+
const dockPanel = this.dockPanelFactory({
|
|
440
|
+
mode: 'multiple-document',
|
|
441
|
+
renderer,
|
|
442
|
+
spacing: 0
|
|
443
|
+
});
|
|
444
|
+
dockPanel.id = theia_dock_panel_1.MAIN_AREA_ID;
|
|
445
|
+
dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
446
|
+
dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
447
|
+
const openUri = async (fileUri) => {
|
|
448
|
+
try {
|
|
449
|
+
const opener = await this.openerService.getOpener(fileUri);
|
|
450
|
+
opener.open(fileUri);
|
|
451
|
+
}
|
|
452
|
+
catch (e) {
|
|
453
|
+
console.info(`no opener found for '${fileUri}'`);
|
|
454
|
+
}
|
|
455
|
+
};
|
|
456
|
+
dockPanel.node.addEventListener('drop', event => {
|
|
457
|
+
var _a;
|
|
458
|
+
if (event.dataTransfer) {
|
|
459
|
+
const uris = this.additionalDraggedUris || ApplicationShell_1.getDraggedEditorUris(event.dataTransfer);
|
|
460
|
+
if (uris.length > 0) {
|
|
461
|
+
uris.forEach(openUri);
|
|
462
|
+
}
|
|
463
|
+
else if (((_a = event.dataTransfer.files) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
464
|
+
// the files were dragged from the outside the workspace
|
|
465
|
+
Array.from(event.dataTransfer.files).forEach(file => {
|
|
466
|
+
if (file.path) {
|
|
467
|
+
const fileUri = uri_1.default.fromComponents({
|
|
468
|
+
scheme: 'file',
|
|
469
|
+
path: file.path,
|
|
470
|
+
authority: '',
|
|
471
|
+
query: '',
|
|
472
|
+
fragment: ''
|
|
473
|
+
});
|
|
474
|
+
openUri(fileUri);
|
|
475
|
+
}
|
|
476
|
+
});
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
});
|
|
480
|
+
dockPanel.node.addEventListener('dblclick', event => {
|
|
481
|
+
const el = event.target;
|
|
482
|
+
if (el.id === theia_dock_panel_1.MAIN_AREA_ID || el.classList.contains('p-TabBar-content')) {
|
|
483
|
+
this.onDidDoubleClickMainAreaEmitter.fire();
|
|
484
|
+
}
|
|
485
|
+
});
|
|
486
|
+
const handler = (e) => {
|
|
487
|
+
if (e.dataTransfer) {
|
|
488
|
+
e.dataTransfer.dropEffect = 'link';
|
|
489
|
+
e.preventDefault();
|
|
490
|
+
e.stopPropagation();
|
|
491
|
+
}
|
|
492
|
+
};
|
|
493
|
+
dockPanel.node.addEventListener('dragover', handler);
|
|
494
|
+
dockPanel.node.addEventListener('dragenter', handler);
|
|
495
|
+
return dockPanel;
|
|
496
|
+
}
|
|
497
|
+
addAdditionalDraggedEditorUris(uris) {
|
|
498
|
+
this.additionalDraggedUris = uris;
|
|
499
|
+
}
|
|
500
|
+
clearAdditionalDraggedEditorUris() {
|
|
501
|
+
this.additionalDraggedUris = undefined;
|
|
502
|
+
}
|
|
503
|
+
static getDraggedEditorUris(dataTransfer) {
|
|
504
|
+
const data = dataTransfer.getData('theia-editor-dnd');
|
|
505
|
+
return data ? data.split('\n').map(entry => new uri_1.default(entry)) : [];
|
|
506
|
+
}
|
|
507
|
+
static setDraggedEditorUris(dataTransfer, uris) {
|
|
508
|
+
dataTransfer.setData('theia-editor-dnd', uris.map(uri => uri.toString()).join('\n'));
|
|
509
|
+
}
|
|
510
|
+
/**
|
|
511
|
+
* Create the dock panel in the bottom shell area.
|
|
512
|
+
*/
|
|
513
|
+
createBottomPanel() {
|
|
514
|
+
const renderer = this.dockPanelRendererFactory();
|
|
515
|
+
renderer.tabBarClasses.push(MAIN_BOTTOM_AREA_CLASS);
|
|
516
|
+
renderer.tabBarClasses.push(BOTTOM_AREA_CLASS);
|
|
517
|
+
const dockPanel = this.dockPanelFactory({
|
|
518
|
+
mode: 'multiple-document',
|
|
519
|
+
renderer,
|
|
520
|
+
spacing: 0
|
|
521
|
+
});
|
|
522
|
+
dockPanel.id = theia_dock_panel_1.BOTTOM_AREA_ID;
|
|
523
|
+
dockPanel.widgetAdded.connect((sender, widget) => {
|
|
524
|
+
this.refreshBottomPanelToggleButton();
|
|
525
|
+
});
|
|
526
|
+
dockPanel.widgetRemoved.connect((sender, widget) => {
|
|
527
|
+
if (sender.isEmpty) {
|
|
528
|
+
this.collapseBottomPanel();
|
|
529
|
+
}
|
|
530
|
+
this.refreshBottomPanelToggleButton();
|
|
531
|
+
}, this);
|
|
532
|
+
dockPanel.node.addEventListener('p-dragenter', event => {
|
|
533
|
+
// Make sure that the main panel hides its overlay when the bottom panel is expanded
|
|
534
|
+
this.mainPanel.overlay.hide(0);
|
|
535
|
+
});
|
|
536
|
+
dockPanel.hide();
|
|
537
|
+
dockPanel.widgetAdded.connect((_, widget) => this.fireDidAddWidget(widget));
|
|
538
|
+
dockPanel.widgetRemoved.connect((_, widget) => this.fireDidRemoveWidget(widget));
|
|
539
|
+
return dockPanel;
|
|
540
|
+
}
|
|
541
|
+
/**
|
|
542
|
+
* Create the top panel, which is used to hold the main menu.
|
|
543
|
+
*/
|
|
544
|
+
createTopPanel() {
|
|
545
|
+
const topPanel = new widgets_1.Panel();
|
|
546
|
+
topPanel.id = 'theia-top-panel';
|
|
547
|
+
topPanel.hide();
|
|
548
|
+
return topPanel;
|
|
549
|
+
}
|
|
550
|
+
/**
|
|
551
|
+
* Create a box layout to assemble the application shell layout.
|
|
552
|
+
*/
|
|
553
|
+
createBoxLayout(widgets, stretch, options) {
|
|
554
|
+
const boxLayout = new widgets_1.BoxLayout(options);
|
|
555
|
+
for (let i = 0; i < widgets.length; i++) {
|
|
556
|
+
if (stretch !== undefined && i < stretch.length) {
|
|
557
|
+
widgets_1.BoxPanel.setStretch(widgets[i], stretch[i]);
|
|
558
|
+
}
|
|
559
|
+
boxLayout.addWidget(widgets[i]);
|
|
560
|
+
}
|
|
561
|
+
return boxLayout;
|
|
562
|
+
}
|
|
563
|
+
/**
|
|
564
|
+
* Create a split layout to assemble the application shell layout.
|
|
565
|
+
*/
|
|
566
|
+
createSplitLayout(widgets, stretch, options) {
|
|
567
|
+
let optParam = { renderer: widgets_1.SplitPanel.defaultRenderer, };
|
|
568
|
+
if (options) {
|
|
569
|
+
optParam = { ...optParam, ...options };
|
|
570
|
+
}
|
|
571
|
+
const splitLayout = new widgets_1.SplitLayout(optParam);
|
|
572
|
+
for (let i = 0; i < widgets.length; i++) {
|
|
573
|
+
if (stretch !== undefined && i < stretch.length) {
|
|
574
|
+
widgets_1.SplitPanel.setStretch(widgets[i], stretch[i]);
|
|
575
|
+
}
|
|
576
|
+
splitLayout.addWidget(widgets[i]);
|
|
577
|
+
}
|
|
578
|
+
return splitLayout;
|
|
579
|
+
}
|
|
580
|
+
/**
|
|
581
|
+
* Assemble the application shell layout. Override this method in order to change the arrangement
|
|
582
|
+
* of the main area and the side panels.
|
|
583
|
+
*/
|
|
584
|
+
createLayout() {
|
|
585
|
+
const bottomSplitLayout = this.createSplitLayout([this.mainPanel, this.bottomPanel], [1, 0], { orientation: 'vertical', spacing: 0 });
|
|
586
|
+
const panelForBottomArea = new widgets_1.SplitPanel({ layout: bottomSplitLayout });
|
|
587
|
+
panelForBottomArea.id = 'theia-bottom-split-panel';
|
|
588
|
+
const leftRightSplitLayout = this.createSplitLayout([this.leftPanelHandler.container, panelForBottomArea, this.rightPanelHandler.container], [0, 1, 0], { orientation: 'horizontal', spacing: 0 });
|
|
589
|
+
const panelForSideAreas = new widgets_1.SplitPanel({ layout: leftRightSplitLayout });
|
|
590
|
+
panelForSideAreas.id = 'theia-left-right-split-panel';
|
|
591
|
+
return this.createBoxLayout([this.topPanel, panelForSideAreas, this.statusBar], [0, 1, 0], { direction: 'top-to-bottom', spacing: 0 });
|
|
592
|
+
}
|
|
593
|
+
/**
|
|
594
|
+
* Create an object that describes the current shell layout. This object may contain references
|
|
595
|
+
* to widgets; these need to be transformed before the layout can be serialized.
|
|
596
|
+
*/
|
|
597
|
+
getLayoutData() {
|
|
598
|
+
return {
|
|
599
|
+
version: exports.applicationShellLayoutVersion,
|
|
600
|
+
mainPanel: this.mainPanel.saveLayout(),
|
|
601
|
+
mainPanelPinned: this.getPinnedMainWidgets(),
|
|
602
|
+
bottomPanel: {
|
|
603
|
+
config: this.bottomPanel.saveLayout(),
|
|
604
|
+
pinned: this.getPinnedBottomWidgets(),
|
|
605
|
+
size: this.bottomPanel.isVisible ? this.getBottomPanelSize() : this.bottomPanelState.lastPanelSize,
|
|
606
|
+
expanded: this.isExpanded('bottom')
|
|
607
|
+
},
|
|
608
|
+
leftPanel: this.leftPanelHandler.getLayoutData(),
|
|
609
|
+
rightPanel: this.rightPanelHandler.getLayoutData(),
|
|
610
|
+
activeWidgetId: this.activeWidget ? this.activeWidget.id : undefined
|
|
611
|
+
};
|
|
612
|
+
}
|
|
613
|
+
// Get an array corresponding to main panel widgets' pinned state.
|
|
614
|
+
getPinnedMainWidgets() {
|
|
615
|
+
const pinned = [];
|
|
616
|
+
(0, algorithm_1.toArray)(this.mainPanel.widgets()).forEach((a, i) => {
|
|
617
|
+
pinned[i] = a.title.className.includes(widgets_2.PINNED_CLASS);
|
|
618
|
+
});
|
|
619
|
+
return pinned;
|
|
620
|
+
}
|
|
621
|
+
// Get an array corresponding to bottom panel widgets' pinned state.
|
|
622
|
+
getPinnedBottomWidgets() {
|
|
623
|
+
const pinned = [];
|
|
624
|
+
(0, algorithm_1.toArray)(this.bottomPanel.widgets()).forEach((a, i) => {
|
|
625
|
+
pinned[i] = a.title.className.includes(widgets_2.PINNED_CLASS);
|
|
626
|
+
});
|
|
627
|
+
return pinned;
|
|
628
|
+
}
|
|
629
|
+
/**
|
|
630
|
+
* Compute the current height of the bottom panel. This implementation assumes that the container
|
|
631
|
+
* of the bottom panel is a `SplitPanel`.
|
|
632
|
+
*/
|
|
633
|
+
getBottomPanelSize() {
|
|
634
|
+
const parent = this.bottomPanel.parent;
|
|
635
|
+
if (parent instanceof widgets_1.SplitPanel && parent.isVisible) {
|
|
636
|
+
const index = parent.widgets.indexOf(this.bottomPanel) - 1;
|
|
637
|
+
if (index >= 0) {
|
|
638
|
+
const handle = parent.handles[index];
|
|
639
|
+
if (!handle.classList.contains('p-mod-hidden')) {
|
|
640
|
+
const parentHeight = parent.node.clientHeight;
|
|
641
|
+
return parentHeight - handle.offsetTop;
|
|
642
|
+
}
|
|
643
|
+
}
|
|
644
|
+
}
|
|
645
|
+
}
|
|
646
|
+
/**
|
|
647
|
+
* Determine the default size to apply when the bottom panel is expanded for the first time.
|
|
648
|
+
*/
|
|
649
|
+
getDefaultBottomPanelSize() {
|
|
650
|
+
const parent = this.bottomPanel.parent;
|
|
651
|
+
if (parent && parent.isVisible) {
|
|
652
|
+
return parent.node.clientHeight * this.options.bottomPanel.initialSizeRatio;
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
/**
|
|
656
|
+
* Apply a shell layout that has been previously created with `getLayoutData`.
|
|
657
|
+
*/
|
|
658
|
+
async setLayoutData(layoutData) {
|
|
659
|
+
var _a, _b;
|
|
660
|
+
const { mainPanel, mainPanelPinned, bottomPanel, leftPanel, rightPanel, activeWidgetId } = layoutData;
|
|
661
|
+
if (leftPanel) {
|
|
662
|
+
this.leftPanelHandler.setLayoutData(leftPanel);
|
|
663
|
+
this.registerWithFocusTracker(leftPanel);
|
|
664
|
+
}
|
|
665
|
+
if (rightPanel) {
|
|
666
|
+
this.rightPanelHandler.setLayoutData(rightPanel);
|
|
667
|
+
this.registerWithFocusTracker(rightPanel);
|
|
668
|
+
}
|
|
669
|
+
// Proceed with the bottom panel once the side panels are set up
|
|
670
|
+
await Promise.all([this.leftPanelHandler.state.pendingUpdate, this.rightPanelHandler.state.pendingUpdate]);
|
|
671
|
+
if (bottomPanel) {
|
|
672
|
+
if (bottomPanel.config) {
|
|
673
|
+
this.bottomPanel.restoreLayout(bottomPanel.config);
|
|
674
|
+
this.registerWithFocusTracker(bottomPanel.config.main);
|
|
675
|
+
}
|
|
676
|
+
if (bottomPanel.size) {
|
|
677
|
+
this.bottomPanelState.lastPanelSize = bottomPanel.size;
|
|
678
|
+
}
|
|
679
|
+
if (bottomPanel.expanded) {
|
|
680
|
+
this.expandBottomPanel();
|
|
681
|
+
}
|
|
682
|
+
else {
|
|
683
|
+
this.collapseBottomPanel();
|
|
684
|
+
}
|
|
685
|
+
const widgets = (0, algorithm_1.toArray)(this.bottomPanel.widgets());
|
|
686
|
+
this.bottomPanel.markActiveTabBar((_a = widgets[0]) === null || _a === void 0 ? void 0 : _a.title);
|
|
687
|
+
if (bottomPanel.pinned && bottomPanel.pinned.length === widgets.length) {
|
|
688
|
+
widgets.forEach((a, i) => {
|
|
689
|
+
if (bottomPanel.pinned[i]) {
|
|
690
|
+
a.title.className += ` ${widgets_2.PINNED_CLASS}`;
|
|
691
|
+
a.title.closable = false;
|
|
692
|
+
}
|
|
693
|
+
});
|
|
694
|
+
}
|
|
695
|
+
this.refreshBottomPanelToggleButton();
|
|
696
|
+
}
|
|
697
|
+
// Proceed with the main panel once all others are set up
|
|
698
|
+
await this.bottomPanelState.pendingUpdate;
|
|
699
|
+
if (mainPanel) {
|
|
700
|
+
this.mainPanel.restoreLayout(mainPanel);
|
|
701
|
+
this.registerWithFocusTracker(mainPanel.main);
|
|
702
|
+
const widgets = (0, algorithm_1.toArray)(this.mainPanel.widgets());
|
|
703
|
+
// We don't store information about the last active tabbar
|
|
704
|
+
// So we simply mark the first as being active
|
|
705
|
+
this.mainPanel.markActiveTabBar((_b = widgets[0]) === null || _b === void 0 ? void 0 : _b.title);
|
|
706
|
+
if (mainPanelPinned && mainPanelPinned.length === widgets.length) {
|
|
707
|
+
widgets.forEach((a, i) => {
|
|
708
|
+
if (mainPanelPinned[i]) {
|
|
709
|
+
a.title.className += ` ${widgets_2.PINNED_CLASS}`;
|
|
710
|
+
a.title.closable = false;
|
|
711
|
+
}
|
|
712
|
+
});
|
|
713
|
+
}
|
|
714
|
+
}
|
|
715
|
+
if (activeWidgetId) {
|
|
716
|
+
this.activateWidget(activeWidgetId);
|
|
717
|
+
}
|
|
718
|
+
}
|
|
719
|
+
/**
|
|
720
|
+
* Modify the height of the bottom panel. This implementation assumes that the container of the
|
|
721
|
+
* bottom panel is a `SplitPanel`.
|
|
722
|
+
*/
|
|
723
|
+
setBottomPanelSize(size) {
|
|
724
|
+
const enableAnimation = this.applicationStateService.state === 'ready';
|
|
725
|
+
const options = {
|
|
726
|
+
side: 'bottom',
|
|
727
|
+
duration: enableAnimation ? this.options.bottomPanel.expandDuration : 0,
|
|
728
|
+
referenceWidget: this.bottomPanel
|
|
729
|
+
};
|
|
730
|
+
const promise = this.splitPositionHandler.setSidePanelSize(this.bottomPanel, size, options);
|
|
731
|
+
const result = new Promise(resolve => {
|
|
732
|
+
// Resolve the resulting promise in any case, regardless of whether resizing was successful
|
|
733
|
+
promise.then(() => resolve(), () => resolve());
|
|
734
|
+
});
|
|
735
|
+
this.bottomPanelState.pendingUpdate = this.bottomPanelState.pendingUpdate.then(() => result);
|
|
736
|
+
return result;
|
|
737
|
+
}
|
|
738
|
+
/**
|
|
739
|
+
* A promise that is resolved when all currently pending updates are done.
|
|
740
|
+
*/
|
|
741
|
+
get pendingUpdates() {
|
|
742
|
+
return Promise.all([
|
|
743
|
+
this.bottomPanelState.pendingUpdate,
|
|
744
|
+
this.leftPanelHandler.state.pendingUpdate,
|
|
745
|
+
this.rightPanelHandler.state.pendingUpdate
|
|
746
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
747
|
+
]);
|
|
748
|
+
}
|
|
749
|
+
/**
|
|
750
|
+
* Track all widgets that are referenced by the given layout data.
|
|
751
|
+
*/
|
|
752
|
+
registerWithFocusTracker(data) {
|
|
753
|
+
if (data) {
|
|
754
|
+
if (data.type === 'tab-area') {
|
|
755
|
+
for (const widget of data.widgets) {
|
|
756
|
+
if (widget) {
|
|
757
|
+
this.track(widget);
|
|
758
|
+
}
|
|
759
|
+
}
|
|
760
|
+
}
|
|
761
|
+
else if (data.type === 'split-area') {
|
|
762
|
+
for (const child of data.children) {
|
|
763
|
+
this.registerWithFocusTracker(child);
|
|
764
|
+
}
|
|
765
|
+
}
|
|
766
|
+
else if (data.type === 'sidepanel' && data.items) {
|
|
767
|
+
for (const item of data.items) {
|
|
768
|
+
if (item.widget) {
|
|
769
|
+
this.track(item.widget);
|
|
770
|
+
}
|
|
771
|
+
}
|
|
772
|
+
}
|
|
773
|
+
}
|
|
774
|
+
}
|
|
775
|
+
/**
|
|
776
|
+
* Add a widget to the application shell. The given widget must have a unique `id` property,
|
|
777
|
+
* which will be used as the DOM id.
|
|
778
|
+
*
|
|
779
|
+
* Widgets are removed from the shell by calling their `close` or `dispose` methods.
|
|
780
|
+
*
|
|
781
|
+
* Widgets added to the top area are not tracked regarding the _current_ and _active_ states.
|
|
782
|
+
*/
|
|
783
|
+
async addWidget(widget, options) {
|
|
784
|
+
if (!widget.id) {
|
|
785
|
+
console.error('Widgets added to the application shell must have a unique id property.');
|
|
786
|
+
return;
|
|
787
|
+
}
|
|
788
|
+
const { area, addOptions } = this.getInsertionOptions(options);
|
|
789
|
+
const sidePanelOptions = { rank: options === null || options === void 0 ? void 0 : options.rank };
|
|
790
|
+
switch (area) {
|
|
791
|
+
case 'main':
|
|
792
|
+
this.mainPanel.addWidget(widget, addOptions);
|
|
793
|
+
break;
|
|
794
|
+
case 'top':
|
|
795
|
+
this.topPanel.addWidget(widget);
|
|
796
|
+
break;
|
|
797
|
+
case 'bottom':
|
|
798
|
+
this.bottomPanel.addWidget(widget, addOptions);
|
|
799
|
+
break;
|
|
800
|
+
case 'left':
|
|
801
|
+
this.leftPanelHandler.addWidget(widget, sidePanelOptions);
|
|
802
|
+
break;
|
|
803
|
+
case 'right':
|
|
804
|
+
this.rightPanelHandler.addWidget(widget, sidePanelOptions);
|
|
805
|
+
break;
|
|
806
|
+
case 'secondaryWindow':
|
|
807
|
+
/** At the moment, widgets are only moved to this area (i.e. a secondary window) by moving them from one of the other areas. */
|
|
808
|
+
throw new Error('Widgets cannot be added directly to a secondary window');
|
|
809
|
+
default:
|
|
810
|
+
throw new Error('Unexpected area: ' + (options === null || options === void 0 ? void 0 : options.area));
|
|
811
|
+
}
|
|
812
|
+
if (area !== 'top') {
|
|
813
|
+
this.track(widget);
|
|
814
|
+
}
|
|
815
|
+
}
|
|
816
|
+
getInsertionOptions(options) {
|
|
817
|
+
let ref = options === null || options === void 0 ? void 0 : options.ref;
|
|
818
|
+
let area = (options === null || options === void 0 ? void 0 : options.area) || 'main';
|
|
819
|
+
if (!ref && (area === 'main' || area === 'bottom')) {
|
|
820
|
+
const tabBar = this.getTabBarFor(area);
|
|
821
|
+
ref = tabBar && tabBar.currentTitle && tabBar.currentTitle.owner || undefined;
|
|
822
|
+
}
|
|
823
|
+
// make sure that ref belongs to area
|
|
824
|
+
area = ref && this.getAreaFor(ref) || area;
|
|
825
|
+
const addOptions = {};
|
|
826
|
+
if (ApplicationShell_1.isOpenToSideMode(options === null || options === void 0 ? void 0 : options.mode)) {
|
|
827
|
+
const areaPanel = area === 'main' ? this.mainPanel : area === 'bottom' ? this.bottomPanel : undefined;
|
|
828
|
+
const sideRef = areaPanel && ref && ((options === null || options === void 0 ? void 0 : options.mode) === 'open-to-left' ?
|
|
829
|
+
areaPanel.previousTabBarWidget(ref) :
|
|
830
|
+
areaPanel.nextTabBarWidget(ref));
|
|
831
|
+
if (sideRef) {
|
|
832
|
+
addOptions.ref = sideRef;
|
|
833
|
+
}
|
|
834
|
+
else {
|
|
835
|
+
addOptions.ref = ref;
|
|
836
|
+
addOptions.mode = (options === null || options === void 0 ? void 0 : options.mode) === 'open-to-left' ? 'split-left' : 'split-right';
|
|
837
|
+
}
|
|
838
|
+
}
|
|
839
|
+
else {
|
|
840
|
+
addOptions.ref = ref;
|
|
841
|
+
addOptions.mode = options === null || options === void 0 ? void 0 : options.mode;
|
|
842
|
+
}
|
|
843
|
+
return { area, addOptions };
|
|
844
|
+
}
|
|
845
|
+
/**
|
|
846
|
+
* The widgets contained in the given shell area.
|
|
847
|
+
*/
|
|
848
|
+
getWidgets(area) {
|
|
849
|
+
switch (area) {
|
|
850
|
+
case 'main':
|
|
851
|
+
return (0, algorithm_1.toArray)(this.mainPanel.widgets());
|
|
852
|
+
case 'top':
|
|
853
|
+
return (0, algorithm_1.toArray)(this.topPanel.widgets);
|
|
854
|
+
case 'bottom':
|
|
855
|
+
return (0, algorithm_1.toArray)(this.bottomPanel.widgets());
|
|
856
|
+
case 'left':
|
|
857
|
+
return (0, algorithm_1.toArray)(this.leftPanelHandler.dockPanel.widgets());
|
|
858
|
+
case 'right':
|
|
859
|
+
return (0, algorithm_1.toArray)(this.rightPanelHandler.dockPanel.widgets());
|
|
860
|
+
case 'secondaryWindow':
|
|
861
|
+
return (0, algorithm_1.toArray)(this.secondaryWindowHandler.widgets);
|
|
862
|
+
default:
|
|
863
|
+
throw new Error('Illegal argument: ' + area);
|
|
864
|
+
}
|
|
865
|
+
}
|
|
866
|
+
/**
|
|
867
|
+
* Find the widget that contains the given HTML element. The returned widget may be one
|
|
868
|
+
* that is managed by the application shell, or one that is embedded in another widget and
|
|
869
|
+
* not directly managed by the shell, or a tab bar.
|
|
870
|
+
*/
|
|
871
|
+
findWidgetForElement(element) {
|
|
872
|
+
let widgetNode = element;
|
|
873
|
+
while (widgetNode && !widgetNode.classList.contains('p-Widget')) {
|
|
874
|
+
widgetNode = widgetNode.parentElement;
|
|
875
|
+
}
|
|
876
|
+
if (widgetNode) {
|
|
877
|
+
return this.findWidgetForNode(widgetNode, this);
|
|
878
|
+
}
|
|
879
|
+
return undefined;
|
|
880
|
+
}
|
|
881
|
+
findWidgetForNode(widgetNode, widget) {
|
|
882
|
+
if (widget.node === widgetNode) {
|
|
883
|
+
return widget;
|
|
884
|
+
}
|
|
885
|
+
let result;
|
|
886
|
+
(0, algorithm_1.each)(widget.children(), child => {
|
|
887
|
+
result = this.findWidgetForNode(widgetNode, child);
|
|
888
|
+
return !result;
|
|
889
|
+
});
|
|
890
|
+
return result;
|
|
891
|
+
}
|
|
892
|
+
/**
|
|
893
|
+
* Finds the title widget from the tab-bar.
|
|
894
|
+
* @param tabBar used for providing an array of titles.
|
|
895
|
+
* @returns the selected title widget, else returns the currentTitle or undefined.
|
|
896
|
+
*/
|
|
897
|
+
findTitle(tabBar, event) {
|
|
898
|
+
if ((event === null || event === void 0 ? void 0 : event.target) instanceof HTMLElement) {
|
|
899
|
+
const tabNode = event.target;
|
|
900
|
+
const titleIndex = Array.from(tabBar.contentNode.getElementsByClassName('p-TabBar-tab'))
|
|
901
|
+
.findIndex(node => node.contains(tabNode));
|
|
902
|
+
if (titleIndex !== -1) {
|
|
903
|
+
return tabBar.titles[titleIndex];
|
|
904
|
+
}
|
|
905
|
+
}
|
|
906
|
+
return tabBar.currentTitle || undefined;
|
|
907
|
+
}
|
|
908
|
+
/**
|
|
909
|
+
* Finds the tab-bar widget.
|
|
910
|
+
* @returns the selected tab-bar, else returns the currentTabBar.
|
|
911
|
+
*/
|
|
912
|
+
findTabBar(event) {
|
|
913
|
+
if ((event === null || event === void 0 ? void 0 : event.target) instanceof HTMLElement) {
|
|
914
|
+
const tabBar = this.findWidgetForElement(event.target);
|
|
915
|
+
if (tabBar instanceof widgets_1.TabBar) {
|
|
916
|
+
return tabBar;
|
|
917
|
+
}
|
|
918
|
+
}
|
|
919
|
+
return this.currentTabBar;
|
|
920
|
+
}
|
|
921
|
+
/**
|
|
922
|
+
* @returns the widget whose title has been targeted by a DOM event on a tabbar, or undefined if none can be found.
|
|
923
|
+
*/
|
|
924
|
+
findTargetedWidget(event) {
|
|
925
|
+
if (event) {
|
|
926
|
+
const tab = this.findTabBar(event);
|
|
927
|
+
const title = tab && this.findTitle(tab, event);
|
|
928
|
+
return title && title.owner;
|
|
929
|
+
}
|
|
930
|
+
}
|
|
931
|
+
/**
|
|
932
|
+
* The current widget in the application shell. The current widget is the last widget that
|
|
933
|
+
* was active and not yet closed. See the remarks to `activeWidget` on what _active_ means.
|
|
934
|
+
*/
|
|
935
|
+
get currentWidget() {
|
|
936
|
+
return this.tracker.currentWidget || undefined;
|
|
937
|
+
}
|
|
938
|
+
/**
|
|
939
|
+
* The active widget in the application shell. The active widget is the one that has focus
|
|
940
|
+
* (either the widget itself or any of its contents).
|
|
941
|
+
*
|
|
942
|
+
* _Note:_ Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
943
|
+
* widget implementation which DOM element will get the focus. The default implementation
|
|
944
|
+
* does not take any focus; in that case the widget is never returned by this property.
|
|
945
|
+
*/
|
|
946
|
+
get activeWidget() {
|
|
947
|
+
return this.tracker.activeWidget || undefined;
|
|
948
|
+
}
|
|
949
|
+
/**
|
|
950
|
+
* Returns the last active widget in the given shell area.
|
|
951
|
+
*/
|
|
952
|
+
getCurrentWidget(area) {
|
|
953
|
+
let title;
|
|
954
|
+
switch (area) {
|
|
955
|
+
case 'main':
|
|
956
|
+
title = this.mainPanel.currentTitle;
|
|
957
|
+
break;
|
|
958
|
+
case 'bottom':
|
|
959
|
+
title = this.bottomPanel.currentTitle;
|
|
960
|
+
break;
|
|
961
|
+
case 'left':
|
|
962
|
+
title = this.leftPanelHandler.tabBar.currentTitle;
|
|
963
|
+
break;
|
|
964
|
+
case 'right':
|
|
965
|
+
title = this.rightPanelHandler.tabBar.currentTitle;
|
|
966
|
+
break;
|
|
967
|
+
case 'secondaryWindow':
|
|
968
|
+
// The current widget in a secondary window is not tracked.
|
|
969
|
+
return undefined;
|
|
970
|
+
default:
|
|
971
|
+
throw new Error('Illegal argument: ' + area);
|
|
972
|
+
}
|
|
973
|
+
return title ? title.owner : undefined;
|
|
974
|
+
}
|
|
975
|
+
/**
|
|
976
|
+
* Handle a change to the current widget.
|
|
977
|
+
*/
|
|
978
|
+
onCurrentChanged(sender, args) {
|
|
979
|
+
this.onDidChangeCurrentWidgetEmitter.fire(args);
|
|
980
|
+
}
|
|
981
|
+
/**
|
|
982
|
+
* Handle a change to the active widget.
|
|
983
|
+
*/
|
|
984
|
+
onActiveChanged(sender, args) {
|
|
985
|
+
this.toDisposeOnActiveChanged.dispose();
|
|
986
|
+
const { newValue, oldValue } = args;
|
|
987
|
+
if (oldValue) {
|
|
988
|
+
let w = oldValue;
|
|
989
|
+
while (w) {
|
|
990
|
+
// Remove the mark of the previously active widget
|
|
991
|
+
w.title.className = w.title.className.replace(' theia-mod-active', '');
|
|
992
|
+
w = w.parent;
|
|
993
|
+
}
|
|
994
|
+
// Reset the z-index to the default
|
|
995
|
+
// eslint-disable-next-line no-null/no-null
|
|
996
|
+
this.setZIndex(oldValue.node, null);
|
|
997
|
+
}
|
|
998
|
+
if (newValue) {
|
|
999
|
+
let w = newValue;
|
|
1000
|
+
while (w) {
|
|
1001
|
+
// Mark the tab of the active widget
|
|
1002
|
+
w.title.className += ' theia-mod-active';
|
|
1003
|
+
w = w.parent;
|
|
1004
|
+
}
|
|
1005
|
+
// Reveal the title of the active widget in its tab bar
|
|
1006
|
+
const tabBar = this.getTabBarFor(newValue);
|
|
1007
|
+
if (tabBar instanceof tab_bars_1.ScrollableTabBar) {
|
|
1008
|
+
const index = tabBar.titles.indexOf(newValue.title);
|
|
1009
|
+
if (index >= 0) {
|
|
1010
|
+
tabBar.revealTab(index);
|
|
1011
|
+
}
|
|
1012
|
+
}
|
|
1013
|
+
const widget = this.toTrackedStack(newValue.id).pop();
|
|
1014
|
+
const panel = this.findPanel(widget);
|
|
1015
|
+
if (panel) {
|
|
1016
|
+
// if widget was undefined, we wouldn't have gotten a panel back before
|
|
1017
|
+
panel.markAsCurrent(widget.title);
|
|
1018
|
+
}
|
|
1019
|
+
// Add checks to ensure that the 'sash' for left panel is displayed correctly
|
|
1020
|
+
if (newValue.node.className === 'p-Widget theia-view-container p-DockPanel-widget') {
|
|
1021
|
+
// Set the z-index so elements with `position: fixed` contained in the active widget are displayed correctly
|
|
1022
|
+
this.setZIndex(newValue.node, '1');
|
|
1023
|
+
}
|
|
1024
|
+
// activate another widget if an active widget will be closed
|
|
1025
|
+
const onCloseRequest = newValue['onCloseRequest'];
|
|
1026
|
+
newValue['onCloseRequest'] = msg => {
|
|
1027
|
+
const currentTabBar = this.currentTabBar;
|
|
1028
|
+
if (currentTabBar) {
|
|
1029
|
+
const recentlyUsedInTabBar = currentTabBar['_previousTitle'];
|
|
1030
|
+
if (recentlyUsedInTabBar && recentlyUsedInTabBar.owner !== newValue) {
|
|
1031
|
+
currentTabBar.currentIndex = algorithm_1.ArrayExt.firstIndexOf(currentTabBar.titles, recentlyUsedInTabBar);
|
|
1032
|
+
if (currentTabBar.currentTitle) {
|
|
1033
|
+
this.activateWidget(currentTabBar.currentTitle.owner.id);
|
|
1034
|
+
}
|
|
1035
|
+
}
|
|
1036
|
+
else if (!this.activateNextTabInTabBar(currentTabBar)) {
|
|
1037
|
+
if (!this.activatePreviousTabBar(currentTabBar)) {
|
|
1038
|
+
this.activateNextTabBar(currentTabBar);
|
|
1039
|
+
}
|
|
1040
|
+
}
|
|
1041
|
+
}
|
|
1042
|
+
newValue['onCloseRequest'] = onCloseRequest;
|
|
1043
|
+
newValue['onCloseRequest'](msg);
|
|
1044
|
+
};
|
|
1045
|
+
this.toDisposeOnActiveChanged.push(common_1.Disposable.create(() => newValue['onCloseRequest'] = onCloseRequest));
|
|
1046
|
+
if (previewable_widget_1.PreviewableWidget.is(newValue)) {
|
|
1047
|
+
newValue.loaded = true;
|
|
1048
|
+
}
|
|
1049
|
+
}
|
|
1050
|
+
this.onDidChangeActiveWidgetEmitter.fire(args);
|
|
1051
|
+
}
|
|
1052
|
+
/**
|
|
1053
|
+
* Set the z-index of the given element and its ancestors to the value `z`.
|
|
1054
|
+
*/
|
|
1055
|
+
setZIndex(element, z) {
|
|
1056
|
+
element.style.zIndex = z || '';
|
|
1057
|
+
const parent = element.parentElement;
|
|
1058
|
+
if (parent && parent !== this.node) {
|
|
1059
|
+
this.setZIndex(parent, z);
|
|
1060
|
+
}
|
|
1061
|
+
}
|
|
1062
|
+
/**
|
|
1063
|
+
* Track the given widget so it is considered in the `current` and `active` state of the shell.
|
|
1064
|
+
*/
|
|
1065
|
+
track(widget) {
|
|
1066
|
+
if (this.tracker.widgets.indexOf(widget) !== -1) {
|
|
1067
|
+
return;
|
|
1068
|
+
}
|
|
1069
|
+
this.tracker.add(widget);
|
|
1070
|
+
this.checkActivation(widget);
|
|
1071
|
+
saveable_1.Saveable.apply(widget, () => this.widgets.filter((maybeSaveable) => !!saveable_1.Saveable.get(maybeSaveable)), async (toSave, options) => {
|
|
1072
|
+
await this.saveResourceService.save(toSave, options);
|
|
1073
|
+
});
|
|
1074
|
+
if (ApplicationShell_1.TrackableWidgetProvider.is(widget)) {
|
|
1075
|
+
for (const toTrack of widget.getTrackableWidgets()) {
|
|
1076
|
+
this.track(toTrack);
|
|
1077
|
+
}
|
|
1078
|
+
if (widget.onDidChangeTrackableWidgets) {
|
|
1079
|
+
widget.onDidChangeTrackableWidgets(widgets => widgets.forEach(w => this.track(w)));
|
|
1080
|
+
}
|
|
1081
|
+
}
|
|
1082
|
+
}
|
|
1083
|
+
/**
|
|
1084
|
+
* @returns an array of Widgets, all of which are tracked by the focus tracker
|
|
1085
|
+
* The first member of the array is the widget whose id is passed in, and the other widgets
|
|
1086
|
+
* are its tracked parents in ascending order
|
|
1087
|
+
*/
|
|
1088
|
+
toTrackedStack(id) {
|
|
1089
|
+
const tracked = new Map(this.tracker.widgets.map(w => [w.id, w]));
|
|
1090
|
+
let current = tracked.get(id);
|
|
1091
|
+
const stack = [];
|
|
1092
|
+
while (current) {
|
|
1093
|
+
if (tracked.has(current.id)) {
|
|
1094
|
+
stack.push(current);
|
|
1095
|
+
}
|
|
1096
|
+
current = current.parent || undefined;
|
|
1097
|
+
}
|
|
1098
|
+
return stack;
|
|
1099
|
+
}
|
|
1100
|
+
/**
|
|
1101
|
+
* Activate a widget in the application shell. This makes the widget visible and usually
|
|
1102
|
+
* also assigns focus to it.
|
|
1103
|
+
*
|
|
1104
|
+
* _Note:_ Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
1105
|
+
* widget implementation which DOM element will get the focus. The default implementation
|
|
1106
|
+
* does not take any focus.
|
|
1107
|
+
*
|
|
1108
|
+
* @returns the activated widget if it was found
|
|
1109
|
+
*/
|
|
1110
|
+
async activateWidget(id) {
|
|
1111
|
+
const stack = this.toTrackedStack(id);
|
|
1112
|
+
let current = stack.pop();
|
|
1113
|
+
if (current && !this.doActivateWidget(current.id)) {
|
|
1114
|
+
return undefined;
|
|
1115
|
+
}
|
|
1116
|
+
while (current && stack.length) {
|
|
1117
|
+
const child = stack.pop();
|
|
1118
|
+
if (ApplicationShell_1.TrackableWidgetProvider.is(current) && current.activateWidget) {
|
|
1119
|
+
current = current.activateWidget(child.id);
|
|
1120
|
+
}
|
|
1121
|
+
else {
|
|
1122
|
+
child.activate();
|
|
1123
|
+
current = child;
|
|
1124
|
+
}
|
|
1125
|
+
}
|
|
1126
|
+
if (!current) {
|
|
1127
|
+
return undefined;
|
|
1128
|
+
}
|
|
1129
|
+
return Promise.all([
|
|
1130
|
+
this.waitForActivation(current.id),
|
|
1131
|
+
(0, widgets_2.waitForRevealed)(current),
|
|
1132
|
+
this.pendingUpdates
|
|
1133
|
+
]).then(() => current, () => undefined);
|
|
1134
|
+
}
|
|
1135
|
+
waitForActivation(id) {
|
|
1136
|
+
if (this.activeWidget && this.activeWidget.id === id) {
|
|
1137
|
+
return Promise.resolve();
|
|
1138
|
+
}
|
|
1139
|
+
const activation = new promise_util_1.Deferred();
|
|
1140
|
+
const success = this.onDidChangeActiveWidget(() => {
|
|
1141
|
+
if (this.activeWidget && this.activeWidget.id === id) {
|
|
1142
|
+
activation.resolve();
|
|
1143
|
+
}
|
|
1144
|
+
});
|
|
1145
|
+
const failure = setTimeout(() => activation.reject(new Error(`Widget with id '${id}' failed to activate.`)), this.activationTimeout + 250);
|
|
1146
|
+
return activation.promise.finally(() => {
|
|
1147
|
+
success.dispose();
|
|
1148
|
+
clearTimeout(failure);
|
|
1149
|
+
});
|
|
1150
|
+
}
|
|
1151
|
+
/**
|
|
1152
|
+
* Activate top-level area widget.
|
|
1153
|
+
*/
|
|
1154
|
+
doActivateWidget(id) {
|
|
1155
|
+
let widget = (0, algorithm_1.find)(this.mainPanel.widgets(), w => w.id === id);
|
|
1156
|
+
if (widget) {
|
|
1157
|
+
this.mainPanel.activateWidget(widget);
|
|
1158
|
+
}
|
|
1159
|
+
if (!widget) {
|
|
1160
|
+
widget = (0, algorithm_1.find)(this.bottomPanel.widgets(), w => w.id === id);
|
|
1161
|
+
if (widget) {
|
|
1162
|
+
this.expandBottomPanel();
|
|
1163
|
+
this.bottomPanel.activateWidget(widget);
|
|
1164
|
+
}
|
|
1165
|
+
}
|
|
1166
|
+
if (!widget) {
|
|
1167
|
+
widget = this.leftPanelHandler.activate(id);
|
|
1168
|
+
}
|
|
1169
|
+
if (!widget) {
|
|
1170
|
+
widget = this.rightPanelHandler.activate(id);
|
|
1171
|
+
}
|
|
1172
|
+
if (widget) {
|
|
1173
|
+
this.windowService.focus();
|
|
1174
|
+
return widget;
|
|
1175
|
+
}
|
|
1176
|
+
return this.secondaryWindowHandler.activateWidget(id);
|
|
1177
|
+
}
|
|
1178
|
+
/**
|
|
1179
|
+
* Focus is taken by a widget through the `onActivateRequest` method. It is up to the
|
|
1180
|
+
* widget implementation which DOM element will get the focus. The default implementation
|
|
1181
|
+
* of Widget does not take any focus. This method can help finding such problems by logging
|
|
1182
|
+
* a warning in case a widget was explicitly activated, but did not trigger a change of the
|
|
1183
|
+
* `activeWidget` property.
|
|
1184
|
+
*/
|
|
1185
|
+
checkActivation(widget) {
|
|
1186
|
+
const onActivateRequest = widget['onActivateRequest'].bind(widget);
|
|
1187
|
+
widget['onActivateRequest'] = (msg) => {
|
|
1188
|
+
onActivateRequest(msg);
|
|
1189
|
+
this.assertActivated(widget);
|
|
1190
|
+
};
|
|
1191
|
+
return widget;
|
|
1192
|
+
}
|
|
1193
|
+
assertActivated(widget) {
|
|
1194
|
+
this.toDisposeOnActivationCheck.dispose();
|
|
1195
|
+
const onDispose = () => this.toDisposeOnActivationCheck.dispose();
|
|
1196
|
+
widget.disposed.connect(onDispose);
|
|
1197
|
+
this.toDisposeOnActivationCheck.push(common_1.Disposable.create(() => widget.disposed.disconnect(onDispose)));
|
|
1198
|
+
let start = 0;
|
|
1199
|
+
const step = timestamp => {
|
|
1200
|
+
const activeElement = widget.node.ownerDocument.activeElement;
|
|
1201
|
+
if (activeElement && widget.node.contains(activeElement)) {
|
|
1202
|
+
return;
|
|
1203
|
+
}
|
|
1204
|
+
if (!start) {
|
|
1205
|
+
start = timestamp;
|
|
1206
|
+
}
|
|
1207
|
+
const delta = timestamp - start;
|
|
1208
|
+
if (delta < this.activationTimeout) {
|
|
1209
|
+
request = window.requestAnimationFrame(step);
|
|
1210
|
+
}
|
|
1211
|
+
else {
|
|
1212
|
+
console.warn(`Widget was activated, but did not accept focus after ${this.activationTimeout}ms: ${widget.id}`);
|
|
1213
|
+
}
|
|
1214
|
+
};
|
|
1215
|
+
let request = window.requestAnimationFrame(step);
|
|
1216
|
+
this.toDisposeOnActivationCheck.push(common_1.Disposable.create(() => window.cancelAnimationFrame(request)));
|
|
1217
|
+
}
|
|
1218
|
+
/**
|
|
1219
|
+
* Reveal a widget in the application shell. This makes the widget visible,
|
|
1220
|
+
* but does not activate it.
|
|
1221
|
+
*
|
|
1222
|
+
* @returns the revealed widget if it was found
|
|
1223
|
+
*/
|
|
1224
|
+
async revealWidget(id) {
|
|
1225
|
+
const stack = this.toTrackedStack(id);
|
|
1226
|
+
let current = stack.pop();
|
|
1227
|
+
if (current && !this.doRevealWidget(current.id)) {
|
|
1228
|
+
return undefined;
|
|
1229
|
+
}
|
|
1230
|
+
while (current && stack.length) {
|
|
1231
|
+
const child = stack.pop();
|
|
1232
|
+
if (ApplicationShell_1.TrackableWidgetProvider.is(current) && current.revealWidget) {
|
|
1233
|
+
current = current.revealWidget(child.id);
|
|
1234
|
+
}
|
|
1235
|
+
else {
|
|
1236
|
+
current = child;
|
|
1237
|
+
}
|
|
1238
|
+
}
|
|
1239
|
+
if (!current) {
|
|
1240
|
+
return undefined;
|
|
1241
|
+
}
|
|
1242
|
+
await Promise.all([
|
|
1243
|
+
(0, widgets_2.waitForRevealed)(current),
|
|
1244
|
+
this.pendingUpdates
|
|
1245
|
+
]);
|
|
1246
|
+
return current;
|
|
1247
|
+
}
|
|
1248
|
+
/**
|
|
1249
|
+
* Reveal top-level area widget.
|
|
1250
|
+
*/
|
|
1251
|
+
doRevealWidget(id) {
|
|
1252
|
+
let widget = (0, algorithm_1.find)(this.mainPanel.widgets(), w => w.id === id);
|
|
1253
|
+
if (!widget) {
|
|
1254
|
+
widget = (0, algorithm_1.find)(this.bottomPanel.widgets(), w => w.id === id);
|
|
1255
|
+
if (widget) {
|
|
1256
|
+
this.expandBottomPanel();
|
|
1257
|
+
}
|
|
1258
|
+
}
|
|
1259
|
+
if (widget) {
|
|
1260
|
+
const tabBar = this.getTabBarFor(widget);
|
|
1261
|
+
if (tabBar) {
|
|
1262
|
+
tabBar.currentTitle = widget.title;
|
|
1263
|
+
}
|
|
1264
|
+
}
|
|
1265
|
+
if (!widget) {
|
|
1266
|
+
widget = this.leftPanelHandler.expand(id);
|
|
1267
|
+
}
|
|
1268
|
+
if (!widget) {
|
|
1269
|
+
widget = this.rightPanelHandler.expand(id);
|
|
1270
|
+
}
|
|
1271
|
+
if (widget) {
|
|
1272
|
+
this.windowService.focus();
|
|
1273
|
+
return widget;
|
|
1274
|
+
}
|
|
1275
|
+
else {
|
|
1276
|
+
return this.secondaryWindowHandler.revealWidget(id);
|
|
1277
|
+
}
|
|
1278
|
+
}
|
|
1279
|
+
/**
|
|
1280
|
+
* Expand the named side panel area. This makes sure that the panel is visible, even if there
|
|
1281
|
+
* are no widgets in it. If the panel is already visible, nothing happens. If the panel is currently
|
|
1282
|
+
* collapsed (see `collapsePanel`) and it contains widgets, the widgets are revealed that were
|
|
1283
|
+
* visible before it was collapsed.
|
|
1284
|
+
*/
|
|
1285
|
+
expandPanel(area) {
|
|
1286
|
+
switch (area) {
|
|
1287
|
+
case 'bottom':
|
|
1288
|
+
this.expandBottomPanel();
|
|
1289
|
+
break;
|
|
1290
|
+
case 'left':
|
|
1291
|
+
this.leftPanelHandler.expand();
|
|
1292
|
+
break;
|
|
1293
|
+
case 'right':
|
|
1294
|
+
this.rightPanelHandler.expand();
|
|
1295
|
+
break;
|
|
1296
|
+
default:
|
|
1297
|
+
throw new Error('Area cannot be expanded: ' + area);
|
|
1298
|
+
}
|
|
1299
|
+
}
|
|
1300
|
+
/**
|
|
1301
|
+
* Adjusts the size of the given area in the application shell.
|
|
1302
|
+
*
|
|
1303
|
+
* @param size the desired size of the panel in pixels.
|
|
1304
|
+
* @param area the area to resize.
|
|
1305
|
+
*/
|
|
1306
|
+
resize(size, area) {
|
|
1307
|
+
switch (area) {
|
|
1308
|
+
case 'bottom':
|
|
1309
|
+
if (this.bottomPanel.isHidden) {
|
|
1310
|
+
this.bottomPanelState.lastPanelSize = size;
|
|
1311
|
+
}
|
|
1312
|
+
else {
|
|
1313
|
+
this.setBottomPanelSize(size);
|
|
1314
|
+
}
|
|
1315
|
+
break;
|
|
1316
|
+
case 'left':
|
|
1317
|
+
this.leftPanelHandler.resize(size);
|
|
1318
|
+
break;
|
|
1319
|
+
case 'right':
|
|
1320
|
+
this.rightPanelHandler.resize(size);
|
|
1321
|
+
break;
|
|
1322
|
+
default:
|
|
1323
|
+
throw new Error('Area cannot be resized: ' + area);
|
|
1324
|
+
}
|
|
1325
|
+
}
|
|
1326
|
+
/**
|
|
1327
|
+
* Expand the bottom panel. See `expandPanel` regarding the exact behavior.
|
|
1328
|
+
*/
|
|
1329
|
+
expandBottomPanel() {
|
|
1330
|
+
const bottomPanel = this.bottomPanel;
|
|
1331
|
+
if (bottomPanel.isHidden) {
|
|
1332
|
+
let relativeSizes;
|
|
1333
|
+
const parent = bottomPanel.parent;
|
|
1334
|
+
if (parent instanceof widgets_1.SplitPanel) {
|
|
1335
|
+
relativeSizes = parent.relativeSizes();
|
|
1336
|
+
}
|
|
1337
|
+
bottomPanel.show();
|
|
1338
|
+
if (relativeSizes && parent instanceof widgets_1.SplitPanel) {
|
|
1339
|
+
// Make sure that the expansion animation starts at the smallest possible size
|
|
1340
|
+
parent.setRelativeSizes(relativeSizes);
|
|
1341
|
+
}
|
|
1342
|
+
let size;
|
|
1343
|
+
if (bottomPanel.isEmpty) {
|
|
1344
|
+
bottomPanel.node.style.minHeight = '0';
|
|
1345
|
+
size = this.options.bottomPanel.emptySize;
|
|
1346
|
+
}
|
|
1347
|
+
else if (this.bottomPanelState.lastPanelSize) {
|
|
1348
|
+
size = this.bottomPanelState.lastPanelSize;
|
|
1349
|
+
}
|
|
1350
|
+
else {
|
|
1351
|
+
size = this.getDefaultBottomPanelSize();
|
|
1352
|
+
}
|
|
1353
|
+
if (size) {
|
|
1354
|
+
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanding;
|
|
1355
|
+
this.setBottomPanelSize(size).then(() => {
|
|
1356
|
+
if (this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanding) {
|
|
1357
|
+
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1358
|
+
}
|
|
1359
|
+
});
|
|
1360
|
+
}
|
|
1361
|
+
else {
|
|
1362
|
+
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1363
|
+
}
|
|
1364
|
+
}
|
|
1365
|
+
}
|
|
1366
|
+
/**
|
|
1367
|
+
* Collapse the named side panel area. This makes sure that the panel is hidden,
|
|
1368
|
+
* increasing the space that is available for other shell areas.
|
|
1369
|
+
*/
|
|
1370
|
+
collapsePanel(area) {
|
|
1371
|
+
switch (area) {
|
|
1372
|
+
case 'bottom':
|
|
1373
|
+
return this.collapseBottomPanel();
|
|
1374
|
+
case 'left':
|
|
1375
|
+
return this.leftPanelHandler.collapse();
|
|
1376
|
+
case 'right':
|
|
1377
|
+
return this.rightPanelHandler.collapse();
|
|
1378
|
+
default:
|
|
1379
|
+
throw new Error('Area cannot be collapsed: ' + area);
|
|
1380
|
+
}
|
|
1381
|
+
}
|
|
1382
|
+
/**
|
|
1383
|
+
* Collapse the bottom panel. All contained widgets are hidden, but not closed.
|
|
1384
|
+
* They can be restored by calling `expandBottomPanel`.
|
|
1385
|
+
*/
|
|
1386
|
+
collapseBottomPanel() {
|
|
1387
|
+
const bottomPanel = this.bottomPanel;
|
|
1388
|
+
if (bottomPanel.isHidden) {
|
|
1389
|
+
return Promise.resolve();
|
|
1390
|
+
}
|
|
1391
|
+
if (this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded) {
|
|
1392
|
+
const size = this.getBottomPanelSize();
|
|
1393
|
+
if (size) {
|
|
1394
|
+
this.bottomPanelState.lastPanelSize = size;
|
|
1395
|
+
}
|
|
1396
|
+
}
|
|
1397
|
+
this.bottomPanelState.expansion = side_panel_handler_1.SidePanel.ExpansionState.collapsed;
|
|
1398
|
+
bottomPanel.hide();
|
|
1399
|
+
return (0, browser_1.animationFrame)();
|
|
1400
|
+
}
|
|
1401
|
+
/**
|
|
1402
|
+
* Refresh the toggle button for the bottom panel. This implementation creates a status bar entry
|
|
1403
|
+
* and refers to the command `core.toggle.bottom.panel`.
|
|
1404
|
+
*/
|
|
1405
|
+
refreshBottomPanelToggleButton() {
|
|
1406
|
+
if (this.bottomPanel.isEmpty) {
|
|
1407
|
+
this.statusBar.removeElement(BOTTOM_PANEL_TOGGLE_ID);
|
|
1408
|
+
}
|
|
1409
|
+
else {
|
|
1410
|
+
const label = nls_1.nls.localize('theia/core/common/collapseBottomPanel', 'Toggle Bottom Panel');
|
|
1411
|
+
const element = {
|
|
1412
|
+
name: label,
|
|
1413
|
+
text: '$(codicon-window)',
|
|
1414
|
+
alignment: status_bar_1.StatusBarAlignment.RIGHT,
|
|
1415
|
+
tooltip: label,
|
|
1416
|
+
command: 'core.toggle.bottom.panel',
|
|
1417
|
+
accessibilityInformation: {
|
|
1418
|
+
label: label,
|
|
1419
|
+
role: 'button'
|
|
1420
|
+
},
|
|
1421
|
+
priority: -1000
|
|
1422
|
+
};
|
|
1423
|
+
this.statusBar.setElement(BOTTOM_PANEL_TOGGLE_ID, element);
|
|
1424
|
+
}
|
|
1425
|
+
}
|
|
1426
|
+
/**
|
|
1427
|
+
* Check whether the named side panel area is expanded (returns `true`) or collapsed (returns `false`).
|
|
1428
|
+
*/
|
|
1429
|
+
isExpanded(area) {
|
|
1430
|
+
switch (area) {
|
|
1431
|
+
case 'bottom':
|
|
1432
|
+
return this.bottomPanelState.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1433
|
+
case 'left':
|
|
1434
|
+
return this.leftPanelHandler.state.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1435
|
+
case 'right':
|
|
1436
|
+
return this.rightPanelHandler.state.expansion === side_panel_handler_1.SidePanel.ExpansionState.expanded;
|
|
1437
|
+
default:
|
|
1438
|
+
return true;
|
|
1439
|
+
}
|
|
1440
|
+
}
|
|
1441
|
+
/**
|
|
1442
|
+
* Close all tabs or a selection of tabs in a specific part of the application shell.
|
|
1443
|
+
*
|
|
1444
|
+
* @param tabBarOrArea
|
|
1445
|
+
* Either the name of a shell area or a `TabBar` that is contained in such an area.
|
|
1446
|
+
* @param filter
|
|
1447
|
+
* If undefined, all tabs are closed; otherwise only those tabs that match the filter are closed.
|
|
1448
|
+
*/
|
|
1449
|
+
async closeTabs(tabBarOrArea, filter) {
|
|
1450
|
+
const titles = this.getWidgetTitles(tabBarOrArea, filter);
|
|
1451
|
+
if (titles.length) {
|
|
1452
|
+
await this.closeMany(titles.map(title => title.owner));
|
|
1453
|
+
}
|
|
1454
|
+
}
|
|
1455
|
+
saveTabs(tabBarOrArea, filter) {
|
|
1456
|
+
const titles = this.getWidgetTitles(tabBarOrArea, filter);
|
|
1457
|
+
for (let i = 0; i < titles.length; i++) {
|
|
1458
|
+
const widget = titles[i].owner;
|
|
1459
|
+
const saveable = saveable_1.Saveable.get(widget);
|
|
1460
|
+
saveable === null || saveable === void 0 ? void 0 : saveable.save();
|
|
1461
|
+
}
|
|
1462
|
+
}
|
|
1463
|
+
/**
|
|
1464
|
+
* Collects all widget titles for the given tab bar or area and optionally filters them.
|
|
1465
|
+
*
|
|
1466
|
+
* @param tabBarOrArea The tab bar or area to retrieve the widget titles for
|
|
1467
|
+
* @param filter The filter to apply to the result
|
|
1468
|
+
* @returns The filtered array of widget titles or an empty array
|
|
1469
|
+
*/
|
|
1470
|
+
getWidgetTitles(tabBarOrArea, filter) {
|
|
1471
|
+
const titles = [];
|
|
1472
|
+
if (tabBarOrArea === 'main') {
|
|
1473
|
+
this.mainAreaTabBars.forEach(tabbar => titles.push(...(0, algorithm_1.toArray)(tabbar.titles)));
|
|
1474
|
+
}
|
|
1475
|
+
else if (tabBarOrArea === 'bottom') {
|
|
1476
|
+
this.bottomAreaTabBars.forEach(tabbar => titles.push(...(0, algorithm_1.toArray)(tabbar.titles)));
|
|
1477
|
+
}
|
|
1478
|
+
else if (tabBarOrArea === 'secondaryWindow') {
|
|
1479
|
+
titles.push(...this.secondaryWindowHandler.widgets.map(w => w.title));
|
|
1480
|
+
}
|
|
1481
|
+
else if (typeof tabBarOrArea === 'string') {
|
|
1482
|
+
const tabbar = this.getTabBarFor(tabBarOrArea);
|
|
1483
|
+
if (tabbar) {
|
|
1484
|
+
titles.push(...(0, algorithm_1.toArray)(tabbar.titles));
|
|
1485
|
+
}
|
|
1486
|
+
}
|
|
1487
|
+
else if (tabBarOrArea) {
|
|
1488
|
+
titles.push(...(0, algorithm_1.toArray)(tabBarOrArea.titles));
|
|
1489
|
+
}
|
|
1490
|
+
return filter ? titles.filter(filter) : titles;
|
|
1491
|
+
}
|
|
1492
|
+
/**
|
|
1493
|
+
* @param targets the widgets to be closed
|
|
1494
|
+
* @return an array of all the widgets that were actually closed.
|
|
1495
|
+
*/
|
|
1496
|
+
async closeMany(targets, options) {
|
|
1497
|
+
if ((options === null || options === void 0 ? void 0 : options.save) === false || await saveable_1.Saveable.confirmSaveBeforeClose(targets, this.widgets.filter(widget => !targets.includes(widget)))) {
|
|
1498
|
+
return (await Promise.all(targets.map(target => this.closeWidget(target.id, options)))).filter((widget) => widget !== undefined);
|
|
1499
|
+
}
|
|
1500
|
+
return [];
|
|
1501
|
+
}
|
|
1502
|
+
/**
|
|
1503
|
+
* @returns the widget that was closed, if any, `undefined` otherwise.
|
|
1504
|
+
*
|
|
1505
|
+
* If your use case requires closing multiple widgets, use {@link ApplicationShell#closeMany} instead. That method handles closing saveable widgets more reliably.
|
|
1506
|
+
*/
|
|
1507
|
+
async closeWidget(id, options) {
|
|
1508
|
+
// TODO handle save for composite widgets, i.e. the preference widget has 2 editors
|
|
1509
|
+
const stack = this.toTrackedStack(id);
|
|
1510
|
+
const current = stack.pop();
|
|
1511
|
+
if (!current) {
|
|
1512
|
+
return undefined;
|
|
1513
|
+
}
|
|
1514
|
+
const saveableOptions = options && { shouldSave: () => options.save };
|
|
1515
|
+
const pendingClose = saveable_1.SaveableWidget.is(current)
|
|
1516
|
+
? current.closeWithSaving(saveableOptions)
|
|
1517
|
+
: (current.close(), (0, widgets_2.waitForClosed)(current));
|
|
1518
|
+
await Promise.all([
|
|
1519
|
+
pendingClose,
|
|
1520
|
+
this.pendingUpdates
|
|
1521
|
+
]);
|
|
1522
|
+
return stack[0] || current;
|
|
1523
|
+
}
|
|
1524
|
+
/**
|
|
1525
|
+
* The shell area name of the currently active tab, or undefined.
|
|
1526
|
+
*/
|
|
1527
|
+
get currentTabArea() {
|
|
1528
|
+
const currentWidget = this.currentWidget;
|
|
1529
|
+
if (currentWidget) {
|
|
1530
|
+
return this.getAreaFor(currentWidget);
|
|
1531
|
+
}
|
|
1532
|
+
}
|
|
1533
|
+
/**
|
|
1534
|
+
* Determine the name of the shell area where the given widget resides. The result is
|
|
1535
|
+
* undefined if the widget does not reside directly in the shell.
|
|
1536
|
+
*/
|
|
1537
|
+
getAreaFor(input) {
|
|
1538
|
+
if (input instanceof widgets_1.TabBar) {
|
|
1539
|
+
if ((0, algorithm_1.find)(this.mainPanel.tabBars(), tb => tb === input)) {
|
|
1540
|
+
return 'main';
|
|
1541
|
+
}
|
|
1542
|
+
if ((0, algorithm_1.find)(this.bottomPanel.tabBars(), tb => tb === input)) {
|
|
1543
|
+
return 'bottom';
|
|
1544
|
+
}
|
|
1545
|
+
if (this.leftPanelHandler.tabBar === input) {
|
|
1546
|
+
return 'left';
|
|
1547
|
+
}
|
|
1548
|
+
if (this.rightPanelHandler.tabBar === input) {
|
|
1549
|
+
return 'right';
|
|
1550
|
+
}
|
|
1551
|
+
}
|
|
1552
|
+
const widget = this.toTrackedStack(input.id).pop();
|
|
1553
|
+
if (!widget) {
|
|
1554
|
+
return undefined;
|
|
1555
|
+
}
|
|
1556
|
+
const title = widget.title;
|
|
1557
|
+
const mainPanelTabBar = this.mainPanel.findTabBar(title);
|
|
1558
|
+
if (mainPanelTabBar) {
|
|
1559
|
+
return 'main';
|
|
1560
|
+
}
|
|
1561
|
+
const bottomPanelTabBar = this.bottomPanel.findTabBar(title);
|
|
1562
|
+
if (bottomPanelTabBar) {
|
|
1563
|
+
return 'bottom';
|
|
1564
|
+
}
|
|
1565
|
+
if (algorithm_1.ArrayExt.firstIndexOf(this.leftPanelHandler.tabBar.titles, title) > -1) {
|
|
1566
|
+
return 'left';
|
|
1567
|
+
}
|
|
1568
|
+
if (algorithm_1.ArrayExt.firstIndexOf(this.rightPanelHandler.tabBar.titles, title) > -1) {
|
|
1569
|
+
return 'right';
|
|
1570
|
+
}
|
|
1571
|
+
if (this.secondaryWindowHandler.widgets.includes(widget)) {
|
|
1572
|
+
return 'secondaryWindow';
|
|
1573
|
+
}
|
|
1574
|
+
return undefined;
|
|
1575
|
+
}
|
|
1576
|
+
getAreaPanelFor(input) {
|
|
1577
|
+
const widget = this.toTrackedStack(input.id).pop();
|
|
1578
|
+
if (!widget) {
|
|
1579
|
+
return undefined;
|
|
1580
|
+
}
|
|
1581
|
+
return this.findPanel(widget);
|
|
1582
|
+
}
|
|
1583
|
+
/**
|
|
1584
|
+
* Find the shell panel this top-level widget is part of
|
|
1585
|
+
*/
|
|
1586
|
+
findPanel(widget) {
|
|
1587
|
+
if (!widget) {
|
|
1588
|
+
return undefined;
|
|
1589
|
+
}
|
|
1590
|
+
const title = widget.title;
|
|
1591
|
+
const mainPanelTabBar = this.mainPanel.findTabBar(title);
|
|
1592
|
+
if (mainPanelTabBar) {
|
|
1593
|
+
return this.mainPanel;
|
|
1594
|
+
}
|
|
1595
|
+
const bottomPanelTabBar = this.bottomPanel.findTabBar(title);
|
|
1596
|
+
if (bottomPanelTabBar) {
|
|
1597
|
+
return this.bottomPanel;
|
|
1598
|
+
}
|
|
1599
|
+
if (algorithm_1.ArrayExt.firstIndexOf(this.leftPanelHandler.tabBar.titles, title) > -1) {
|
|
1600
|
+
return this.leftPanelHandler.dockPanel;
|
|
1601
|
+
}
|
|
1602
|
+
if (algorithm_1.ArrayExt.firstIndexOf(this.rightPanelHandler.tabBar.titles, title) > -1) {
|
|
1603
|
+
return this.rightPanelHandler.dockPanel;
|
|
1604
|
+
}
|
|
1605
|
+
return undefined;
|
|
1606
|
+
}
|
|
1607
|
+
/**
|
|
1608
|
+
* Return the tab bar that has the currently active widget, or undefined.
|
|
1609
|
+
*/
|
|
1610
|
+
get currentTabBar() {
|
|
1611
|
+
const currentWidget = this.currentWidget;
|
|
1612
|
+
if (currentWidget) {
|
|
1613
|
+
return this.getTabBarFor(currentWidget);
|
|
1614
|
+
}
|
|
1615
|
+
}
|
|
1616
|
+
/**
|
|
1617
|
+
* Return the tab bar in the given shell area, or the tab bar that has the given widget, or undefined.
|
|
1618
|
+
*/
|
|
1619
|
+
getTabBarFor(widgetOrArea) {
|
|
1620
|
+
if (typeof widgetOrArea === 'string') {
|
|
1621
|
+
switch (widgetOrArea) {
|
|
1622
|
+
case 'main':
|
|
1623
|
+
return this.mainPanel.currentTabBar;
|
|
1624
|
+
case 'bottom':
|
|
1625
|
+
return this.bottomPanel.currentTabBar;
|
|
1626
|
+
case 'left':
|
|
1627
|
+
return this.leftPanelHandler.tabBar;
|
|
1628
|
+
case 'right':
|
|
1629
|
+
return this.rightPanelHandler.tabBar;
|
|
1630
|
+
case 'secondaryWindow':
|
|
1631
|
+
// Secondary windows don't have a tab bar
|
|
1632
|
+
return undefined;
|
|
1633
|
+
default:
|
|
1634
|
+
throw new Error('Illegal argument: ' + widgetOrArea);
|
|
1635
|
+
}
|
|
1636
|
+
}
|
|
1637
|
+
const widget = this.toTrackedStack(widgetOrArea.id).pop();
|
|
1638
|
+
if (!widget) {
|
|
1639
|
+
return undefined;
|
|
1640
|
+
}
|
|
1641
|
+
const widgetTitle = widget.title;
|
|
1642
|
+
const mainPanelTabBar = this.mainPanel.findTabBar(widgetTitle);
|
|
1643
|
+
if (mainPanelTabBar) {
|
|
1644
|
+
return mainPanelTabBar;
|
|
1645
|
+
}
|
|
1646
|
+
const bottomPanelTabBar = this.bottomPanel.findTabBar(widgetTitle);
|
|
1647
|
+
if (bottomPanelTabBar) {
|
|
1648
|
+
return bottomPanelTabBar;
|
|
1649
|
+
}
|
|
1650
|
+
const leftPanelTabBar = this.leftPanelHandler.tabBar;
|
|
1651
|
+
if (algorithm_1.ArrayExt.firstIndexOf(leftPanelTabBar.titles, widgetTitle) > -1) {
|
|
1652
|
+
return leftPanelTabBar;
|
|
1653
|
+
}
|
|
1654
|
+
const rightPanelTabBar = this.rightPanelHandler.tabBar;
|
|
1655
|
+
if (algorithm_1.ArrayExt.firstIndexOf(rightPanelTabBar.titles, widgetTitle) > -1) {
|
|
1656
|
+
return rightPanelTabBar;
|
|
1657
|
+
}
|
|
1658
|
+
return undefined;
|
|
1659
|
+
}
|
|
1660
|
+
/**
|
|
1661
|
+
* The tab bars contained in the main shell area. If there is no widget in the main area, the
|
|
1662
|
+
* returned array is empty.
|
|
1663
|
+
*/
|
|
1664
|
+
get mainAreaTabBars() {
|
|
1665
|
+
return (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1666
|
+
}
|
|
1667
|
+
/**
|
|
1668
|
+
* The tab bars contained in the bottom shell area. If there is no widget in the bottom area,
|
|
1669
|
+
* the returned array is empty.
|
|
1670
|
+
*/
|
|
1671
|
+
get bottomAreaTabBars() {
|
|
1672
|
+
return (0, algorithm_1.toArray)(this.bottomPanel.tabBars());
|
|
1673
|
+
}
|
|
1674
|
+
/**
|
|
1675
|
+
* The tab bars contained in all shell areas.
|
|
1676
|
+
*/
|
|
1677
|
+
get allTabBars() {
|
|
1678
|
+
return [...this.mainAreaTabBars, ...this.bottomAreaTabBars, this.leftPanelHandler.tabBar, this.rightPanelHandler.tabBar];
|
|
1679
|
+
}
|
|
1680
|
+
/*
|
|
1681
|
+
* Activate the next tab in the current tab bar.
|
|
1682
|
+
*/
|
|
1683
|
+
activateNextTabInTabBar(current = this.currentTabBar) {
|
|
1684
|
+
const index = this.nextTabIndexInTabBar(current);
|
|
1685
|
+
if (!current || index === -1) {
|
|
1686
|
+
return false;
|
|
1687
|
+
}
|
|
1688
|
+
current.currentIndex = index;
|
|
1689
|
+
if (current.currentTitle) {
|
|
1690
|
+
this.activateWidget(current.currentTitle.owner.id);
|
|
1691
|
+
}
|
|
1692
|
+
return true;
|
|
1693
|
+
}
|
|
1694
|
+
nextTabIndexInTabBar(current = this.currentTabBar) {
|
|
1695
|
+
if (!current || current.titles.length <= 1) {
|
|
1696
|
+
return -1;
|
|
1697
|
+
}
|
|
1698
|
+
const index = current.currentIndex;
|
|
1699
|
+
if (index === -1) {
|
|
1700
|
+
return -1;
|
|
1701
|
+
}
|
|
1702
|
+
if (index < current.titles.length - 1) {
|
|
1703
|
+
return index + 1;
|
|
1704
|
+
}
|
|
1705
|
+
return 0;
|
|
1706
|
+
}
|
|
1707
|
+
activateNextTab() {
|
|
1708
|
+
const current = this.currentTabBar;
|
|
1709
|
+
if (current) {
|
|
1710
|
+
const ci = current.currentIndex;
|
|
1711
|
+
if (ci !== -1) {
|
|
1712
|
+
if (ci < current.titles.length - 1) {
|
|
1713
|
+
current.currentIndex += 1;
|
|
1714
|
+
if (current.currentTitle) {
|
|
1715
|
+
this.activateWidget(current.currentTitle.owner.id);
|
|
1716
|
+
}
|
|
1717
|
+
return true;
|
|
1718
|
+
}
|
|
1719
|
+
else if (ci === current.titles.length - 1) {
|
|
1720
|
+
return this.activateNextTabBar(current);
|
|
1721
|
+
}
|
|
1722
|
+
}
|
|
1723
|
+
}
|
|
1724
|
+
return false;
|
|
1725
|
+
}
|
|
1726
|
+
activateNextTabBar(current = this.currentTabBar) {
|
|
1727
|
+
const nextBar = this.nextTabBar(current);
|
|
1728
|
+
if (nextBar) {
|
|
1729
|
+
nextBar.currentIndex = 0;
|
|
1730
|
+
if (nextBar.currentTitle) {
|
|
1731
|
+
this.activateWidget(nextBar.currentTitle.owner.id);
|
|
1732
|
+
}
|
|
1733
|
+
return true;
|
|
1734
|
+
}
|
|
1735
|
+
return false;
|
|
1736
|
+
}
|
|
1737
|
+
/**
|
|
1738
|
+
* Return the tab bar next to the given tab bar; return the given tab bar if there is no adjacent one.
|
|
1739
|
+
*/
|
|
1740
|
+
nextTabBar(current = this.currentTabBar) {
|
|
1741
|
+
let bars = (0, algorithm_1.toArray)(this.bottomPanel.tabBars());
|
|
1742
|
+
let len = bars.length;
|
|
1743
|
+
let ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1744
|
+
if (ci < 0) {
|
|
1745
|
+
bars = (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1746
|
+
len = bars.length;
|
|
1747
|
+
ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1748
|
+
}
|
|
1749
|
+
if (ci >= 0 && ci < len - 1) {
|
|
1750
|
+
return bars[ci + 1];
|
|
1751
|
+
}
|
|
1752
|
+
else if (ci >= 0 && ci === len - 1) {
|
|
1753
|
+
return bars[0];
|
|
1754
|
+
}
|
|
1755
|
+
else {
|
|
1756
|
+
return current;
|
|
1757
|
+
}
|
|
1758
|
+
}
|
|
1759
|
+
/*
|
|
1760
|
+
* Activate the previous tab in the current tab bar.
|
|
1761
|
+
*/
|
|
1762
|
+
activatePreviousTabInTabBar(current = this.currentTabBar) {
|
|
1763
|
+
const index = this.previousTabIndexInTabBar(current);
|
|
1764
|
+
if (!current || index === -1) {
|
|
1765
|
+
return false;
|
|
1766
|
+
}
|
|
1767
|
+
current.currentIndex = index;
|
|
1768
|
+
if (current.currentTitle) {
|
|
1769
|
+
this.activateWidget(current.currentTitle.owner.id);
|
|
1770
|
+
}
|
|
1771
|
+
return true;
|
|
1772
|
+
}
|
|
1773
|
+
previousTabIndexInTabBar(current = this.currentTabBar) {
|
|
1774
|
+
if (!current || current.titles.length <= 1) {
|
|
1775
|
+
return -1;
|
|
1776
|
+
}
|
|
1777
|
+
const index = current.currentIndex;
|
|
1778
|
+
if (index === -1) {
|
|
1779
|
+
return -1;
|
|
1780
|
+
}
|
|
1781
|
+
if (index > 0) {
|
|
1782
|
+
return index - 1;
|
|
1783
|
+
}
|
|
1784
|
+
return current.titles.length - 1;
|
|
1785
|
+
}
|
|
1786
|
+
activatePreviousTab() {
|
|
1787
|
+
const current = this.currentTabBar;
|
|
1788
|
+
if (current) {
|
|
1789
|
+
const ci = current.currentIndex;
|
|
1790
|
+
if (ci !== -1) {
|
|
1791
|
+
if (ci > 0) {
|
|
1792
|
+
current.currentIndex -= 1;
|
|
1793
|
+
if (current.currentTitle) {
|
|
1794
|
+
this.activateWidget(current.currentTitle.owner.id);
|
|
1795
|
+
}
|
|
1796
|
+
return true;
|
|
1797
|
+
}
|
|
1798
|
+
else if (ci === 0) {
|
|
1799
|
+
if (current && current.titles.length > 0) {
|
|
1800
|
+
current.currentIndex = current.titles.length - 1;
|
|
1801
|
+
if (current.currentTitle) {
|
|
1802
|
+
this.activateWidget(current.currentTitle.owner.id);
|
|
1803
|
+
}
|
|
1804
|
+
return true;
|
|
1805
|
+
}
|
|
1806
|
+
return this.activatePreviousTabBar(current);
|
|
1807
|
+
}
|
|
1808
|
+
}
|
|
1809
|
+
}
|
|
1810
|
+
return false;
|
|
1811
|
+
}
|
|
1812
|
+
activatePreviousTabBar(current = this.currentTabBar) {
|
|
1813
|
+
const prevBar = this.previousTabBar(current);
|
|
1814
|
+
if (!prevBar) {
|
|
1815
|
+
return false;
|
|
1816
|
+
}
|
|
1817
|
+
if (!prevBar.currentTitle) {
|
|
1818
|
+
prevBar.currentIndex = prevBar.titles.length - 1;
|
|
1819
|
+
}
|
|
1820
|
+
if (prevBar.currentTitle) {
|
|
1821
|
+
this.activateWidget(prevBar.currentTitle.owner.id);
|
|
1822
|
+
}
|
|
1823
|
+
return true;
|
|
1824
|
+
}
|
|
1825
|
+
/**
|
|
1826
|
+
* Return the tab bar previous to the given tab bar; return the given tab bar if there is no adjacent one.
|
|
1827
|
+
*/
|
|
1828
|
+
previousTabBar(current = this.currentTabBar) {
|
|
1829
|
+
const bars = (0, algorithm_1.toArray)(this.mainPanel.tabBars());
|
|
1830
|
+
const len = bars.length;
|
|
1831
|
+
const ci = algorithm_1.ArrayExt.firstIndexOf(bars, current);
|
|
1832
|
+
if (ci > 0) {
|
|
1833
|
+
return bars[ci - 1];
|
|
1834
|
+
}
|
|
1835
|
+
else if (ci === 0) {
|
|
1836
|
+
return bars[len - 1];
|
|
1837
|
+
}
|
|
1838
|
+
else {
|
|
1839
|
+
return current;
|
|
1840
|
+
}
|
|
1841
|
+
}
|
|
1842
|
+
/**
|
|
1843
|
+
* Test whether the current widget is dirty.
|
|
1844
|
+
*/
|
|
1845
|
+
canSave() {
|
|
1846
|
+
return this.saveResourceService.canSave(this.currentWidget);
|
|
1847
|
+
}
|
|
1848
|
+
/**
|
|
1849
|
+
* Save the current widget if it is dirty.
|
|
1850
|
+
*/
|
|
1851
|
+
async save(options) {
|
|
1852
|
+
await this.saveResourceService.save(this.currentWidget, options);
|
|
1853
|
+
}
|
|
1854
|
+
/**
|
|
1855
|
+
* Test whether there is a dirty widget.
|
|
1856
|
+
*/
|
|
1857
|
+
canSaveAll() {
|
|
1858
|
+
return this.tracker.widgets.some(widget => this.saveResourceService.canSave(widget));
|
|
1859
|
+
}
|
|
1860
|
+
/**
|
|
1861
|
+
* Save all dirty widgets.
|
|
1862
|
+
*/
|
|
1863
|
+
async saveAll(options) {
|
|
1864
|
+
for (const widget of this.widgets) {
|
|
1865
|
+
if (this.saveResourceService.canSaveNotSaveAs(widget)) {
|
|
1866
|
+
await this.saveResourceService.save(widget, options);
|
|
1867
|
+
}
|
|
1868
|
+
}
|
|
1869
|
+
}
|
|
1870
|
+
/**
|
|
1871
|
+
* Returns a snapshot of all tracked widgets to allow async modifications.
|
|
1872
|
+
*/
|
|
1873
|
+
get widgets() {
|
|
1874
|
+
return [...this.tracker.widgets];
|
|
1875
|
+
}
|
|
1876
|
+
getWidgetById(id) {
|
|
1877
|
+
for (const widget of this.tracker.widgets) {
|
|
1878
|
+
if (widget.id === id) {
|
|
1879
|
+
return widget;
|
|
1880
|
+
}
|
|
1881
|
+
}
|
|
1882
|
+
return undefined;
|
|
1883
|
+
}
|
|
1884
|
+
canToggleMaximized(widget = this.currentWidget) {
|
|
1885
|
+
const area = widget && this.getAreaFor(widget);
|
|
1886
|
+
return area === 'main' || area === 'bottom';
|
|
1887
|
+
}
|
|
1888
|
+
toggleMaximized(widget = this.currentWidget) {
|
|
1889
|
+
const area = widget && this.getAreaPanelFor(widget);
|
|
1890
|
+
if (area instanceof theia_dock_panel_1.TheiaDockPanel && (area === this.mainPanel || area === this.bottomPanel)) {
|
|
1891
|
+
area.toggleMaximized();
|
|
1892
|
+
this.revealWidget(widget.id);
|
|
1893
|
+
}
|
|
1894
|
+
}
|
|
1895
|
+
};
|
|
1896
|
+
(0, tslib_1.__decorate)([
|
|
1897
|
+
(0, inversify_1.inject)(context_key_service_1.ContextKeyService),
|
|
1898
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
1899
|
+
], ApplicationShell.prototype, "contextKeyService", void 0);
|
|
1900
|
+
(0, tslib_1.__decorate)([
|
|
1901
|
+
(0, inversify_1.inject)(opener_service_1.OpenerService),
|
|
1902
|
+
(0, tslib_1.__metadata)("design:type", Object)
|
|
1903
|
+
], ApplicationShell.prototype, "openerService", void 0);
|
|
1904
|
+
(0, tslib_1.__decorate)([
|
|
1905
|
+
(0, inversify_1.inject)(theia_dock_panel_1.TheiaDockPanel.Factory),
|
|
1906
|
+
(0, tslib_1.__metadata)("design:type", Function)
|
|
1907
|
+
], ApplicationShell.prototype, "dockPanelFactory", void 0);
|
|
1908
|
+
(0, tslib_1.__decorate)([
|
|
1909
|
+
(0, inversify_1.postConstruct)(),
|
|
1910
|
+
(0, tslib_1.__metadata)("design:type", Function),
|
|
1911
|
+
(0, tslib_1.__metadata)("design:paramtypes", []),
|
|
1912
|
+
(0, tslib_1.__metadata)("design:returntype", void 0)
|
|
1913
|
+
], ApplicationShell.prototype, "init", null);
|
|
1914
|
+
ApplicationShell = ApplicationShell_1 = (0, tslib_1.__decorate)([
|
|
1915
|
+
(0, inversify_1.injectable)(),
|
|
1916
|
+
(0, tslib_1.__param)(0, (0, inversify_1.inject)(exports.DockPanelRendererFactory)),
|
|
1917
|
+
(0, tslib_1.__param)(1, (0, inversify_1.inject)(status_bar_1.StatusBarImpl)),
|
|
1918
|
+
(0, tslib_1.__param)(2, (0, inversify_1.inject)(side_panel_handler_1.SidePanelHandlerFactory)),
|
|
1919
|
+
(0, tslib_1.__param)(3, (0, inversify_1.inject)(split_panels_1.SplitPositionHandler)),
|
|
1920
|
+
(0, tslib_1.__param)(4, (0, inversify_1.inject)(frontend_application_state_1.FrontendApplicationStateService)),
|
|
1921
|
+
(0, tslib_1.__param)(5, (0, inversify_1.inject)(exports.ApplicationShellOptions)),
|
|
1922
|
+
(0, tslib_1.__param)(5, (0, inversify_1.optional)()),
|
|
1923
|
+
(0, tslib_1.__param)(6, (0, inversify_1.inject)(core_preferences_1.CorePreferences)),
|
|
1924
|
+
(0, tslib_1.__param)(7, (0, inversify_1.inject)(save_resource_service_1.SaveResourceService)),
|
|
1925
|
+
(0, tslib_1.__param)(8, (0, inversify_1.inject)(secondary_window_handler_1.SecondaryWindowHandler)),
|
|
1926
|
+
(0, tslib_1.__param)(9, (0, inversify_1.inject)(window_service_1.WindowService)),
|
|
1927
|
+
(0, tslib_1.__metadata)("design:paramtypes", [Function, status_bar_1.StatusBarImpl, Function, split_panels_1.SplitPositionHandler,
|
|
1928
|
+
frontend_application_state_1.FrontendApplicationStateService, Object, Object, save_resource_service_1.SaveResourceService,
|
|
1929
|
+
secondary_window_handler_1.SecondaryWindowHandler, Object])
|
|
1930
|
+
], ApplicationShell);
|
|
1931
|
+
exports.ApplicationShell = ApplicationShell;
|
|
1932
|
+
/**
|
|
1933
|
+
* The namespace for `ApplicationShell` class statics.
|
|
1934
|
+
*/
|
|
1935
|
+
(function (ApplicationShell) {
|
|
1936
|
+
ApplicationShell.areaLabels = {
|
|
1937
|
+
main: nls_1.nls.localizeByDefault('Main'),
|
|
1938
|
+
top: nls_1.nls.localizeByDefault('Top'),
|
|
1939
|
+
left: nls_1.nls.localizeByDefault('Left'),
|
|
1940
|
+
right: nls_1.nls.localizeByDefault('Right'),
|
|
1941
|
+
bottom: nls_1.nls.localizeByDefault('Bottom'),
|
|
1942
|
+
secondaryWindow: nls_1.nls.localize('theia/shell-area/secondary', 'Secondary Window'),
|
|
1943
|
+
};
|
|
1944
|
+
/**
|
|
1945
|
+
* The _side areas_ are those shell areas that can be collapsed and expanded,
|
|
1946
|
+
* i.e. `left`, `right`, and `bottom`.
|
|
1947
|
+
*/
|
|
1948
|
+
function isSideArea(area) {
|
|
1949
|
+
return area === 'left' || area === 'right' || area === 'bottom';
|
|
1950
|
+
}
|
|
1951
|
+
ApplicationShell.isSideArea = isSideArea;
|
|
1952
|
+
function isValidArea(area) {
|
|
1953
|
+
const areas = ['main', 'top', 'left', 'right', 'bottom', 'secondaryWindow'];
|
|
1954
|
+
return typeof area === 'string' && areas.includes(area);
|
|
1955
|
+
}
|
|
1956
|
+
ApplicationShell.isValidArea = isValidArea;
|
|
1957
|
+
/**
|
|
1958
|
+
* The default values for application shell options.
|
|
1959
|
+
*/
|
|
1960
|
+
ApplicationShell.DEFAULT_OPTIONS = Object.freeze({
|
|
1961
|
+
bottomPanel: Object.freeze({
|
|
1962
|
+
emptySize: 140,
|
|
1963
|
+
expandThreshold: 160,
|
|
1964
|
+
expandDuration: 0,
|
|
1965
|
+
initialSizeRatio: 0.382
|
|
1966
|
+
}),
|
|
1967
|
+
leftPanel: Object.freeze({
|
|
1968
|
+
emptySize: 140,
|
|
1969
|
+
expandThreshold: 140,
|
|
1970
|
+
expandDuration: 0,
|
|
1971
|
+
initialSizeRatio: 0.191
|
|
1972
|
+
}),
|
|
1973
|
+
rightPanel: Object.freeze({
|
|
1974
|
+
emptySize: 140,
|
|
1975
|
+
expandThreshold: 140,
|
|
1976
|
+
expandDuration: 0,
|
|
1977
|
+
initialSizeRatio: 0.191
|
|
1978
|
+
})
|
|
1979
|
+
});
|
|
1980
|
+
function isOpenToSideMode(mode) {
|
|
1981
|
+
return mode === 'open-to-left' || mode === 'open-to-right';
|
|
1982
|
+
}
|
|
1983
|
+
ApplicationShell.isOpenToSideMode = isOpenToSideMode;
|
|
1984
|
+
let TrackableWidgetProvider;
|
|
1985
|
+
(function (TrackableWidgetProvider) {
|
|
1986
|
+
function is(widget) {
|
|
1987
|
+
return (0, common_1.isObject)(widget) && 'getTrackableWidgets' in widget;
|
|
1988
|
+
}
|
|
1989
|
+
TrackableWidgetProvider.is = is;
|
|
1990
|
+
})(TrackableWidgetProvider = ApplicationShell.TrackableWidgetProvider || (ApplicationShell.TrackableWidgetProvider = {}));
|
|
1991
|
+
})(ApplicationShell = exports.ApplicationShell || (exports.ApplicationShell = {}));
|
|
1992
|
+
exports.ApplicationShell = ApplicationShell;
|
|
1993
1993
|
//# sourceMappingURL=application-shell.js.map
|