@theia/plugin-ext 1.34.3 → 1.34.4
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/LICENSE +641 -641
- package/README.md +54 -54
- package/lib/common/arrays.d.ts +19 -19
- package/lib/common/arrays.js +46 -46
- package/lib/common/assert.d.ts +1 -1
- package/lib/common/assert.js +25 -25
- package/lib/common/cache.d.ts +11 -11
- package/lib/common/cache.js +47 -47
- package/lib/common/character-classifier.d.ts +18 -18
- package/lib/common/character-classifier.js +60 -60
- package/lib/common/collections.d.ts +4 -4
- package/lib/common/collections.js +39 -39
- package/lib/common/connection.d.ts +54 -54
- package/lib/common/connection.js +107 -107
- package/lib/common/disposable-util.d.ts +6 -6
- package/lib/common/disposable-util.js +37 -37
- package/lib/common/editor-options.d.ts +30 -30
- package/lib/common/editor-options.js +72 -72
- package/lib/common/env.d.ts +3 -3
- package/lib/common/env.js +17 -17
- package/lib/common/errors.d.ts +3 -3
- package/lib/common/errors.js +42 -42
- package/lib/common/id-generator.d.ts +6 -6
- package/lib/common/id-generator.js +28 -28
- package/lib/common/index.d.ts +3 -3
- package/lib/common/index.js +33 -33
- package/lib/common/link-computer.d.ts +41 -41
- package/lib/common/link-computer.js +275 -275
- package/lib/common/object-identifier.d.ts +8 -8
- package/lib/common/object-identifier.js +32 -32
- package/lib/common/objects.d.ts +1 -1
- package/lib/common/objects.js +46 -46
- package/lib/common/paths-util.d.ts +3 -3
- package/lib/common/paths-util.js +144 -144
- package/lib/common/plugin-api-rpc-model.d.ts +728 -728
- package/lib/common/plugin-api-rpc-model.js +173 -173
- package/lib/common/plugin-api-rpc.d.ts +1710 -1710
- package/lib/common/plugin-api-rpc.js +279 -279
- package/lib/common/plugin-ext-api-contribution.d.ts +58 -58
- package/lib/common/plugin-ext-api-contribution.js +5 -5
- package/lib/common/plugin-identifiers.d.ts +40 -40
- package/lib/common/plugin-identifiers.js +80 -80
- package/lib/common/plugin-protocol.d.ts +840 -840
- package/lib/common/plugin-protocol.js +67 -67
- package/lib/common/proxy-handler.d.ts +65 -65
- package/lib/common/proxy-handler.js +97 -97
- package/lib/common/reference-map.d.ts +7 -7
- package/lib/common/reference-map.js +39 -39
- package/lib/common/rpc-protocol.d.ts +65 -65
- package/lib/common/rpc-protocol.js +229 -229
- package/lib/common/semantic-tokens-dto.d.ts +18 -18
- package/lib/common/semantic-tokens-dto.js +162 -162
- package/lib/common/types.d.ts +37 -37
- package/lib/common/types.js +121 -121
- package/lib/common/uint.d.ts +7 -7
- package/lib/common/uint.js +33 -33
- package/lib/common/uri-components.d.ts +39 -39
- package/lib/common/uri-components.js +66 -66
- package/lib/hosted/browser/hosted-plugin-watcher.d.ts +15 -15
- package/lib/hosted/browser/hosted-plugin-watcher.js +59 -59
- package/lib/hosted/browser/hosted-plugin.d.ts +145 -145
- package/lib/hosted/browser/hosted-plugin.js +787 -787
- package/lib/hosted/browser/plugin-worker.d.ts +6 -6
- package/lib/hosted/browser/plugin-worker.js +57 -57
- package/lib/hosted/browser/worker/debug-stub.d.ts +3 -3
- package/lib/hosted/browser/worker/debug-stub.js +29 -29
- package/lib/hosted/browser/worker/plugin-manifest-loader.d.ts +2 -2
- package/lib/hosted/browser/worker/plugin-manifest-loader.js +107 -107
- package/lib/hosted/browser/worker/worker-env-ext.d.ts +14 -14
- package/lib/hosted/browser/worker/worker-env-ext.js +38 -38
- package/lib/hosted/browser/worker/worker-main.d.ts +1 -1
- package/lib/hosted/browser/worker/worker-main.js +192 -192
- package/lib/hosted/node/hosted-plugin-cli-contribution.d.ts +16 -16
- package/lib/hosted/node/hosted-plugin-cli-contribution.js +76 -76
- package/lib/hosted/node/hosted-plugin-deployer-handler.d.ts +42 -42
- package/lib/hosted/node/hosted-plugin-deployer-handler.js +264 -264
- package/lib/hosted/node/hosted-plugin-localization-service.d.ts +34 -34
- package/lib/hosted/node/hosted-plugin-localization-service.js +239 -239
- package/lib/hosted/node/hosted-plugin-process.d.ts +47 -47
- package/lib/hosted/node/hosted-plugin-process.js +224 -224
- package/lib/hosted/node/hosted-plugin-protocol.d.ts +21 -21
- package/lib/hosted/node/hosted-plugin-protocol.js +36 -36
- package/lib/hosted/node/hosted-plugin.d.ts +36 -36
- package/lib/hosted/node/hosted-plugin.js +118 -118
- package/lib/hosted/node/metadata-scanner.d.ts +17 -17
- package/lib/hosted/node/metadata-scanner.js +82 -82
- package/lib/hosted/node/plugin-ext-hosted-backend-module.d.ts +3 -3
- package/lib/hosted/node/plugin-ext-hosted-backend-module.js +73 -73
- package/lib/hosted/node/plugin-host-proxy.d.ts +17 -17
- package/lib/hosted/node/plugin-host-proxy.js +69 -69
- package/lib/hosted/node/plugin-host-rpc.d.ts +21 -21
- package/lib/hosted/node/plugin-host-rpc.js +216 -216
- package/lib/hosted/node/plugin-host.d.ts +1 -1
- package/lib/hosted/node/plugin-host.js +101 -101
- package/lib/hosted/node/plugin-manifest-loader.d.ts +1 -1
- package/lib/hosted/node/plugin-manifest-loader.js +34 -34
- package/lib/hosted/node/plugin-reader.d.ts +25 -25
- package/lib/hosted/node/plugin-reader.js +141 -141
- package/lib/hosted/node/plugin-service.d.ts +39 -39
- package/lib/hosted/node/plugin-service.js +193 -193
- package/lib/hosted/node/scanners/backend-init-theia.d.ts +2 -2
- package/lib/hosted/node/scanners/backend-init-theia.js +60 -60
- package/lib/hosted/node/scanners/file-plugin-uri-factory.d.ts +10 -10
- package/lib/hosted/node/scanners/file-plugin-uri-factory.js +40 -40
- package/lib/hosted/node/scanners/grammars-reader.d.ts +5 -5
- package/lib/hosted/node/scanners/grammars-reader.js +63 -63
- package/lib/hosted/node/scanners/plugin-uri-factory.d.ts +16 -16
- package/lib/hosted/node/scanners/plugin-uri-factory.js +19 -19
- package/lib/hosted/node/scanners/scanner-theia.d.ts +56 -56
- package/lib/hosted/node/scanners/scanner-theia.js +842 -842
- package/lib/hosted/node-electron/plugin-ext-hosted-electron-backend-module.d.ts +2 -2
- package/lib/hosted/node-electron/plugin-ext-hosted-electron-backend-module.js +26 -26
- package/lib/hosted/node-electron/scanner-theia-electron.d.ts +5 -5
- package/lib/hosted/node-electron/scanner-theia-electron.js +40 -40
- package/lib/main/browser/authentication-main.d.ts +51 -51
- package/lib/main/browser/authentication-main.js +299 -299
- package/lib/main/browser/clipboard-main.d.ts +9 -9
- package/lib/main/browser/clipboard-main.js +32 -32
- package/lib/main/browser/command-registry-main.d.ts +23 -23
- package/lib/main/browser/command-registry-main.js +97 -97
- package/lib/main/browser/commands.d.ts +12 -12
- package/lib/main/browser/commands.js +102 -102
- package/lib/main/browser/comments/comment-glyph-widget.d.ts +12 -12
- package/lib/main/browser/comments/comment-glyph-widget.js +42 -42
- package/lib/main/browser/comments/comment-thread-widget.d.ts +153 -153
- package/lib/main/browser/comments/comment-thread-widget.js +466 -466
- package/lib/main/browser/comments/comments-context-key-service.d.ts +17 -17
- package/lib/main/browser/comments/comments-context-key-service.js +80 -80
- package/lib/main/browser/comments/comments-contribution.d.ts +31 -31
- package/lib/main/browser/comments/comments-contribution.js +264 -264
- package/lib/main/browser/comments/comments-decorator.d.ts +15 -15
- package/lib/main/browser/comments/comments-decorator.js +107 -107
- package/lib/main/browser/comments/comments-main.d.ts +106 -106
- package/lib/main/browser/comments/comments-main.js +341 -341
- package/lib/main/browser/comments/comments-service.d.ts +75 -75
- package/lib/main/browser/comments/comments-service.js +120 -120
- package/lib/main/browser/custom-editors/custom-editor-contribution.d.ts +6 -6
- package/lib/main/browser/custom-editors/custom-editor-contribution.js +50 -50
- package/lib/main/browser/custom-editors/custom-editor-opener.d.ts +21 -21
- package/lib/main/browser/custom-editors/custom-editor-opener.js +111 -111
- package/lib/main/browser/custom-editors/custom-editor-service.d.ts +16 -16
- package/lib/main/browser/custom-editors/custom-editor-service.js +102 -102
- package/lib/main/browser/custom-editors/custom-editor-widget-factory.d.ts +9 -9
- package/lib/main/browser/custom-editors/custom-editor-widget-factory.js +39 -39
- package/lib/main/browser/custom-editors/custom-editor-widget.d.ts +36 -36
- package/lib/main/browser/custom-editors/custom-editor-widget.js +115 -115
- package/lib/main/browser/custom-editors/custom-editors-main.d.ts +120 -120
- package/lib/main/browser/custom-editors/custom-editors-main.js +447 -447
- package/lib/main/browser/custom-editors/plugin-custom-editor-registry.d.ts +23 -23
- package/lib/main/browser/custom-editors/plugin-custom-editor-registry.js +142 -142
- package/lib/main/browser/custom-editors/undo-redo-service.d.ts +23 -23
- package/lib/main/browser/custom-editors/undo-redo-service.js +110 -110
- package/lib/main/browser/debug/debug-main.d.ts +48 -48
- package/lib/main/browser/debug/debug-main.js +295 -295
- package/lib/main/browser/debug/plugin-debug-adapter-contribution.d.ts +18 -18
- package/lib/main/browser/debug/plugin-debug-adapter-contribution.js +42 -42
- package/lib/main/browser/debug/plugin-debug-configuration-provider.d.ts +12 -12
- package/lib/main/browser/debug/plugin-debug-configuration-provider.js +38 -38
- package/lib/main/browser/debug/plugin-debug-service.d.ts +52 -52
- package/lib/main/browser/debug/plugin-debug-service.js +283 -283
- package/lib/main/browser/debug/plugin-debug-session-contribution-registry.d.ts +30 -30
- package/lib/main/browser/debug/plugin-debug-session-contribution-registry.js +75 -75
- package/lib/main/browser/debug/plugin-debug-session-factory.d.ts +55 -55
- package/lib/main/browser/debug/plugin-debug-session-factory.js +70 -70
- package/lib/main/browser/decorations/decorations-main.d.ts +15 -15
- package/lib/main/browser/decorations/decorations-main.js +119 -119
- package/lib/main/browser/dialogs/modal-notification.d.ts +18 -18
- package/lib/main/browser/dialogs/modal-notification.js +107 -107
- package/lib/main/browser/dialogs-main.d.ts +16 -16
- package/lib/main/browser/dialogs-main.js +162 -162
- package/lib/main/browser/documents-main.d.ts +50 -50
- package/lib/main/browser/documents-main.js +249 -249
- package/lib/main/browser/editors-and-documents-main.d.ts +32 -32
- package/lib/main/browser/editors-and-documents-main.js +301 -301
- package/lib/main/browser/env-main.d.ts +15 -15
- package/lib/main/browser/env-main.js +82 -82
- package/lib/main/browser/file-system-main-impl.d.ts +27 -27
- package/lib/main/browser/file-system-main-impl.js +199 -199
- package/lib/main/browser/hierarchy/hierarchy-types-converters.d.ts +24 -24
- package/lib/main/browser/hierarchy/hierarchy-types-converters.js +174 -174
- package/lib/main/browser/keybindings/keybindings-contribution-handler.d.ts +9 -9
- package/lib/main/browser/keybindings/keybindings-contribution-handler.js +77 -77
- package/lib/main/browser/label-service-main.d.ts +10 -10
- package/lib/main/browser/label-service-main.js +46 -46
- package/lib/main/browser/languages-main.d.ts +136 -136
- package/lib/main/browser/languages-main.js +1116 -1116
- package/lib/main/browser/main-context.d.ts +3 -3
- package/lib/main/browser/main-context.js +137 -137
- package/lib/main/browser/main-file-system-event-service.d.ts +7 -7
- package/lib/main/browser/main-file-system-event-service.js +65 -65
- package/lib/main/browser/menus/menus-contribution-handler.d.ts +29 -29
- package/lib/main/browser/menus/menus-contribution-handler.js +194 -194
- package/lib/main/browser/menus/plugin-menu-command-adapter.d.ts +43 -43
- package/lib/main/browser/menus/plugin-menu-command-adapter.js +279 -279
- package/lib/main/browser/menus/vscode-theia-menu-mappings.d.ts +17 -17
- package/lib/main/browser/menus/vscode-theia-menu-mappings.js +93 -93
- package/lib/main/browser/message-registry-main.d.ts +8 -8
- package/lib/main/browser/message-registry-main.js +52 -52
- package/lib/main/browser/notification-main.d.ts +18 -18
- package/lib/main/browser/notification-main.js +75 -75
- package/lib/main/browser/output-channel-registry-main.d.ts +10 -10
- package/lib/main/browser/output-channel-registry-main.js +60 -60
- package/lib/main/browser/plugin-authentication-service.d.ts +13 -13
- package/lib/main/browser/plugin-authentication-service.js +80 -80
- package/lib/main/browser/plugin-contribution-handler.d.ts +66 -66
- package/lib/main/browser/plugin-contribution-handler.js +580 -580
- package/lib/main/browser/plugin-ext-frontend-module.d.ts +7 -7
- package/lib/main/browser/plugin-ext-frontend-module.js +216 -216
- package/lib/main/browser/plugin-ext-widget.d.ts +28 -28
- package/lib/main/browser/plugin-ext-widget.js +129 -129
- package/lib/main/browser/plugin-frontend-contribution.d.ts +6 -6
- package/lib/main/browser/plugin-frontend-contribution.js +45 -45
- package/lib/main/browser/plugin-frontend-view-contribution.d.ts +6 -6
- package/lib/main/browser/plugin-frontend-view-contribution.js +50 -50
- package/lib/main/browser/plugin-icon-theme-service.d.ts +135 -135
- package/lib/main/browser/plugin-icon-theme-service.js +519 -519
- package/lib/main/browser/plugin-shared-style.d.ts +36 -36
- package/lib/main/browser/plugin-shared-style.js +126 -126
- package/lib/main/browser/plugin-storage.d.ts +13 -13
- package/lib/main/browser/plugin-storage.js +46 -46
- package/lib/main/browser/plugin-terminal-registry.d.ts +4 -4
- package/lib/main/browser/plugin-terminal-registry.js +34 -34
- package/lib/main/browser/preference-registry-main.d.ts +19 -19
- package/lib/main/browser/preference-registry-main.js +104 -104
- package/lib/main/browser/quick-open-main.d.ts +31 -31
- package/lib/main/browser/quick-open-main.js +274 -274
- package/lib/main/browser/scm-main.d.ts +100 -100
- package/lib/main/browser/scm-main.js +330 -330
- package/lib/main/browser/secrets-main.d.ts +12 -12
- package/lib/main/browser/secrets-main.js +67 -67
- package/lib/main/browser/selection-provider-command.d.ts +12 -12
- package/lib/main/browser/selection-provider-command.js +57 -57
- package/lib/main/browser/status-bar-message-registry-main.d.ts +16 -16
- package/lib/main/browser/status-bar-message-registry-main.js +55 -55
- package/lib/main/browser/tabs/tabs-main.d.ts +40 -40
- package/lib/main/browser/tabs/tabs-main.js +282 -282
- package/lib/main/browser/tasks-main.d.ts +33 -33
- package/lib/main/browser/tasks-main.js +205 -205
- package/lib/main/browser/terminal-main.d.ts +49 -49
- package/lib/main/browser/terminal-main.js +268 -268
- package/lib/main/browser/text-editor-main.d.ts +47 -47
- package/lib/main/browser/text-editor-main.js +374 -374
- package/lib/main/browser/text-editor-model-service.d.ts +28 -28
- package/lib/main/browser/text-editor-model-service.js +108 -108
- package/lib/main/browser/text-editors-main.d.ts +38 -38
- package/lib/main/browser/text-editors-main.js +158 -158
- package/lib/main/browser/theme-icon-override.d.ts +1 -1
- package/lib/main/browser/theme-icon-override.js +247 -247
- package/lib/main/browser/theming-main.d.ts +9 -9
- package/lib/main/browser/theming-main.js +35 -35
- package/lib/main/browser/timeline-main.d.ts +13 -13
- package/lib/main/browser/timeline-main.js +46 -46
- package/lib/main/browser/view/dnd-file-content-store.d.ts +7 -7
- package/lib/main/browser/view/dnd-file-content-store.js +51 -51
- package/lib/main/browser/view/plugin-tree-view-node-label-provider.d.ts +11 -11
- package/lib/main/browser/view/plugin-tree-view-node-label-provider.js +90 -90
- package/lib/main/browser/view/plugin-view-registry.d.ts +106 -106
- package/lib/main/browser/view/plugin-view-registry.js +836 -836
- package/lib/main/browser/view/plugin-view-widget.d.ts +50 -50
- package/lib/main/browser/view/plugin-view-widget.js +166 -166
- package/lib/main/browser/view/tree-view-decorator-service.d.ts +30 -30
- package/lib/main/browser/view/tree-view-decorator-service.js +68 -68
- package/lib/main/browser/view/tree-view-widget.d.ts +160 -160
- package/lib/main/browser/view/tree-view-widget.js +761 -761
- package/lib/main/browser/view/tree-views-main.d.ts +31 -31
- package/lib/main/browser/view/tree-views-main.js +163 -163
- package/lib/main/browser/view/view-context-key-service.d.ts +30 -30
- package/lib/main/browser/view/view-context-key-service.js +84 -84
- package/lib/main/browser/view-column-service.d.ts +23 -23
- package/lib/main/browser/view-column-service.js +129 -129
- package/lib/main/browser/webview/webview-environment.d.ts +15 -15
- package/lib/main/browser/webview/webview-environment.js +93 -93
- package/lib/main/browser/webview/webview-frontend-security-warnings.d.ts +11 -11
- package/lib/main/browser/webview/webview-frontend-security-warnings.js +73 -73
- package/lib/main/browser/webview/webview-preferences.d.ts +12 -12
- package/lib/main/browser/webview/webview-preferences.js +57 -57
- package/lib/main/browser/webview/webview-resource-cache.d.ts +17 -17
- package/lib/main/browser/webview/webview-resource-cache.js +90 -90
- package/lib/main/browser/webview/webview-theme-data-provider.d.ts +30 -30
- package/lib/main/browser/webview/webview-theme-data-provider.js +132 -132
- package/lib/main/browser/webview/webview-widget-factory.d.ts +8 -8
- package/lib/main/browser/webview/webview-widget-factory.js +38 -38
- package/lib/main/browser/webview/webview.d.ts +130 -130
- package/lib/main/browser/webview/webview.js +549 -549
- package/lib/main/browser/webview-views/webview-views-main.d.ts +30 -30
- package/lib/main/browser/webview-views/webview-views-main.js +126 -126
- package/lib/main/browser/webview-views/webview-views.d.ts +14 -14
- package/lib/main/browser/webview-views/webview-views.js +22 -22
- package/lib/main/browser/webviews-main.d.ts +39 -39
- package/lib/main/browser/webviews-main.js +231 -231
- package/lib/main/browser/window-state-main.d.ts +16 -16
- package/lib/main/browser/window-state-main.js +61 -61
- package/lib/main/browser/workspace-main.d.ts +69 -69
- package/lib/main/browser/workspace-main.js +316 -316
- package/lib/main/common/plugin-paths-protocol.d.ts +8 -8
- package/lib/main/common/plugin-paths-protocol.js +21 -21
- package/lib/main/common/plugin-theia-environment.d.ts +7 -7
- package/lib/main/common/plugin-theia-environment.js +47 -47
- package/lib/main/common/webview-protocol.d.ts +12 -12
- package/lib/main/common/webview-protocol.js +31 -31
- package/lib/main/electron-browser/plugin-ext-frontend-electron-module.d.ts +3 -3
- package/lib/main/electron-browser/plugin-ext-frontend-electron-module.js +25 -25
- package/lib/main/electron-browser/webview/electron-webview-widget-factory.d.ts +22 -22
- package/lib/main/electron-browser/webview/electron-webview-widget-factory.js +64 -64
- package/lib/main/node/handlers/plugin-theia-directory-handler.d.ts +10 -10
- package/lib/main/node/handlers/plugin-theia-directory-handler.js +113 -113
- package/lib/main/node/handlers/plugin-theia-file-handler.d.ts +9 -9
- package/lib/main/node/handlers/plugin-theia-file-handler.js +66 -66
- package/lib/main/node/paths/const.d.ts +5 -5
- package/lib/main/node/paths/const.js +24 -24
- package/lib/main/node/paths/plugin-paths-service.d.ts +23 -23
- package/lib/main/node/paths/plugin-paths-service.js +169 -169
- package/lib/main/node/plugin-cli-contribution.d.ts +21 -21
- package/lib/main/node/plugin-cli-contribution.js +84 -84
- package/lib/main/node/plugin-deployer-contribution.d.ts +8 -8
- package/lib/main/node/plugin-deployer-contribution.js +47 -47
- package/lib/main/node/plugin-deployer-directory-handler-context-impl.d.ts +7 -7
- package/lib/main/node/plugin-deployer-directory-handler-context-impl.js +44 -44
- package/lib/main/node/plugin-deployer-entry-impl.d.ts +34 -34
- package/lib/main/node/plugin-deployer-entry-impl.js +109 -109
- package/lib/main/node/plugin-deployer-file-handler-context-impl.d.ts +7 -7
- package/lib/main/node/plugin-deployer-file-handler-context-impl.js +31 -31
- package/lib/main/node/plugin-deployer-impl.d.ts +61 -61
- package/lib/main/node/plugin-deployer-impl.js +341 -341
- package/lib/main/node/plugin-deployer-proxy-entry-impl.d.ts +29 -29
- package/lib/main/node/plugin-deployer-proxy-entry-impl.js +98 -98
- package/lib/main/node/plugin-deployer-resolver-context-impl.d.ts +15 -15
- package/lib/main/node/plugin-deployer-resolver-context-impl.js +42 -42
- package/lib/main/node/plugin-ext-backend-module.d.ts +2 -2
- package/lib/main/node/plugin-ext-backend-module.js +70 -70
- package/lib/main/node/plugin-github-resolver.d.ts +21 -21
- package/lib/main/node/plugin-github-resolver.js +142 -142
- package/lib/main/node/plugin-http-resolver.d.ts +18 -18
- package/lib/main/node/plugin-http-resolver.js +91 -91
- package/lib/main/node/plugin-localization-backend-contribution.d.ts +9 -9
- package/lib/main/node/plugin-localization-backend-contribution.js +58 -58
- package/lib/main/node/plugin-server-handler.d.ts +16 -16
- package/lib/main/node/plugin-server-handler.js +74 -74
- package/lib/main/node/plugin-service.d.ts +19 -19
- package/lib/main/node/plugin-service.js +91 -91
- package/lib/main/node/plugin-theia-deployer-participant.d.ts +6 -6
- package/lib/main/node/plugin-theia-deployer-participant.js +43 -43
- package/lib/main/node/plugin-uninstallation-manager.d.ts +14 -14
- package/lib/main/node/plugin-uninstallation-manager.js +84 -84
- package/lib/main/node/plugins-key-value-storage.d.ts +15 -15
- package/lib/main/node/plugins-key-value-storage.js +128 -128
- package/lib/main/node/resolvers/local-directory-plugin-deployer-resolver.d.ts +7 -7
- package/lib/main/node/resolvers/local-directory-plugin-deployer-resolver.js +43 -43
- package/lib/main/node/resolvers/local-plugin-deployer-resolver.d.ts +8 -8
- package/lib/main/node/resolvers/local-plugin-deployer-resolver.js +59 -59
- package/lib/main/node/temp-dir-util.d.ts +1 -1
- package/lib/main/node/temp-dir-util.js +30 -30
- package/lib/main/node/webview-backend-security-warnings.d.ts +5 -5
- package/lib/main/node/webview-backend-security-warnings.js +51 -51
- package/lib/plugin/authentication-ext.d.ts +34 -34
- package/lib/plugin/authentication-ext.js +94 -94
- package/lib/plugin/clipboard-ext.d.ts +9 -9
- package/lib/plugin/clipboard-ext.js +31 -31
- package/lib/plugin/command-registry.d.ts +43 -43
- package/lib/plugin/command-registry.js +176 -176
- package/lib/plugin/comments.d.ts +89 -89
- package/lib/plugin/comments.js +368 -368
- package/lib/plugin/custom-editors.d.ts +47 -47
- package/lib/plugin/custom-editors.js +255 -255
- package/lib/plugin/debug/debug-ext.d.ts +86 -86
- package/lib/plugin/debug/debug-ext.js +391 -391
- package/lib/plugin/debug/plugin-debug-adapter-creator.d.ts +10 -10
- package/lib/plugin/debug/plugin-debug-adapter-creator.js +41 -41
- package/lib/plugin/debug/plugin-debug-adapter-session.d.ts +26 -26
- package/lib/plugin/debug/plugin-debug-adapter-session.js +96 -96
- package/lib/plugin/debug/plugin-debug-adapter-tracker.d.ts +12 -12
- package/lib/plugin/debug/plugin-debug-adapter-tracker.js +77 -77
- package/lib/plugin/decorations.d.ts +14 -14
- package/lib/plugin/decorations.js +112 -112
- package/lib/plugin/dialogs.d.ts +10 -10
- package/lib/plugin/dialogs.js +91 -91
- package/lib/plugin/document-data.d.ts +38 -38
- package/lib/plugin/document-data.js +309 -309
- package/lib/plugin/documents.d.ts +56 -56
- package/lib/plugin/documents.js +253 -253
- package/lib/plugin/editors-and-documents.d.ts +26 -26
- package/lib/plugin/editors-and-documents.js +137 -137
- package/lib/plugin/env.d.ts +42 -42
- package/lib/plugin/env.js +101 -101
- package/lib/plugin/file-system-event-service-ext-impl.d.ts +40 -40
- package/lib/plugin/file-system-event-service-ext-impl.js +203 -203
- package/lib/plugin/file-system-ext-impl.d.ts +50 -50
- package/lib/plugin/file-system-ext-impl.js +354 -354
- package/lib/plugin/known-commands.d.ts +5 -5
- package/lib/plugin/known-commands.js +386 -386
- package/lib/plugin/known-commands.spec.d.ts +1 -1
- package/lib/plugin/known-commands.spec.js +42 -42
- package/lib/plugin/label-service.d.ts +11 -11
- package/lib/plugin/label-service.js +35 -35
- package/lib/plugin/languages/call-hierarchy.d.ts +20 -20
- package/lib/plugin/languages/call-hierarchy.js +101 -101
- package/lib/plugin/languages/code-action.d.ts +24 -24
- package/lib/plugin/languages/code-action.js +137 -137
- package/lib/plugin/languages/color.d.ts +12 -12
- package/lib/plugin/languages/color.js +58 -58
- package/lib/plugin/languages/completion.d.ts +20 -20
- package/lib/plugin/languages/completion.js +161 -161
- package/lib/plugin/languages/declaration.d.ts +11 -11
- package/lib/plugin/languages/declaration.js +58 -58
- package/lib/plugin/languages/definition.d.ts +11 -11
- package/lib/plugin/languages/definition.js +58 -58
- package/lib/plugin/languages/diagnostics.d.ts +49 -49
- package/lib/plugin/languages/diagnostics.js +281 -281
- package/lib/plugin/languages/document-formatting.d.ts +10 -10
- package/lib/plugin/languages/document-formatting.js +40 -40
- package/lib/plugin/languages/document-highlight.d.ts +12 -12
- package/lib/plugin/languages/document-highlight.js +50 -50
- package/lib/plugin/languages/evaluatable-expression.d.ts +11 -11
- package/lib/plugin/languages/evaluatable-expression.js +40 -40
- package/lib/plugin/languages/folding.d.ts +10 -10
- package/lib/plugin/languages/folding.js +39 -39
- package/lib/plugin/languages/hover.d.ts +11 -11
- package/lib/plugin/languages/hover.js +48 -48
- package/lib/plugin/languages/implementation.d.ts +11 -11
- package/lib/plugin/languages/implementation.js +58 -58
- package/lib/plugin/languages/inlay-hints.d.ts +19 -19
- package/lib/plugin/languages/inlay-hints.js +127 -127
- package/lib/plugin/languages/inline-completion.d.ts +20 -20
- package/lib/plugin/languages/inline-completion.js +93 -93
- package/lib/plugin/languages/inline-values.d.ts +10 -10
- package/lib/plugin/languages/inline-values.js +44 -44
- package/lib/plugin/languages/lens.d.ts +19 -19
- package/lib/plugin/languages/lens.js +89 -89
- package/lib/plugin/languages/link-provider.d.ts +14 -14
- package/lib/plugin/languages/link-provider.js +71 -71
- package/lib/plugin/languages/linked-editing-range.d.ts +11 -11
- package/lib/plugin/languages/linked-editing-range.js +40 -40
- package/lib/plugin/languages/on-type-formatting.d.ts +11 -11
- package/lib/plugin/languages/on-type-formatting.js +41 -41
- package/lib/plugin/languages/outline.d.ts +20 -20
- package/lib/plugin/languages/outline.js +115 -115
- package/lib/plugin/languages/range-formatting.d.ts +10 -10
- package/lib/plugin/languages/range-formatting.js +41 -41
- package/lib/plugin/languages/reference.d.ts +11 -11
- package/lib/plugin/languages/reference.js +47 -47
- package/lib/plugin/languages/rename.d.ts +14 -14
- package/lib/plugin/languages/rename.js +114 -114
- package/lib/plugin/languages/selection-range.d.ts +11 -11
- package/lib/plugin/languages/selection-range.js +65 -65
- package/lib/plugin/languages/semantic-highlighting.d.ts +28 -28
- package/lib/plugin/languages/semantic-highlighting.js +175 -175
- package/lib/plugin/languages/signature.d.ts +15 -15
- package/lib/plugin/languages/signature.js +71 -71
- package/lib/plugin/languages/type-definition.d.ts +11 -11
- package/lib/plugin/languages/type-definition.js +58 -58
- package/lib/plugin/languages/type-hierarchy.d.ts +18 -18
- package/lib/plugin/languages/type-hierarchy.js +95 -95
- package/lib/plugin/languages/util.d.ts +4 -4
- package/lib/plugin/languages/util.js +27 -27
- package/lib/plugin/languages/workspace-symbol.d.ts +8 -8
- package/lib/plugin/languages/workspace-symbol.js +61 -61
- package/lib/plugin/languages-utils.d.ts +5 -5
- package/lib/plugin/languages-utils.js +52 -52
- package/lib/plugin/languages.d.ts +118 -118
- package/lib/plugin/languages.js +679 -679
- package/lib/plugin/markdown-string.d.ts +24 -24
- package/lib/plugin/markdown-string.js +124 -124
- package/lib/plugin/message-registry.d.ts +8 -8
- package/lib/plugin/message-registry.js +60 -60
- package/lib/plugin/node/debug/debug.spec.d.ts +1 -1
- package/lib/plugin/node/debug/debug.spec.js +67 -67
- package/lib/plugin/node/debug/plugin-node-debug-adapter-creator.d.ts +17 -17
- package/lib/plugin/node/debug/plugin-node-debug-adapter-creator.js +154 -154
- package/lib/plugin/node/env-node-ext.d.ts +21 -21
- package/lib/plugin/node/env-node-ext.js +63 -63
- package/lib/plugin/notification.d.ts +17 -17
- package/lib/plugin/notification.js +67 -67
- package/lib/plugin/output-channel/output-channel-item.d.ts +17 -17
- package/lib/plugin/output-channel/output-channel-item.js +51 -51
- package/lib/plugin/output-channel-registry.d.ts +8 -8
- package/lib/plugin/output-channel-registry.js +35 -35
- package/lib/plugin/path.d.ts +2 -2
- package/lib/plugin/path.js +59 -59
- package/lib/plugin/path.spec.d.ts +1 -1
- package/lib/plugin/path.spec.js +34 -34
- package/lib/plugin/plugin-context.d.ts +56 -56
- package/lib/plugin/plugin-context.js +1072 -1072
- package/lib/plugin/plugin-icon-path.d.ts +11 -11
- package/lib/plugin/plugin-icon-path.js +49 -49
- package/lib/plugin/plugin-manager.d.ts +80 -80
- package/lib/plugin/plugin-manager.js +366 -366
- package/lib/plugin/plugin-storage.d.ts +36 -36
- package/lib/plugin/plugin-storage.js +99 -99
- package/lib/plugin/preference-registry.d.ts +36 -36
- package/lib/plugin/preference-registry.js +295 -295
- package/lib/plugin/preference-registry.spec.d.ts +1 -1
- package/lib/plugin/preference-registry.spec.js +251 -251
- package/lib/plugin/prefix-sum-computer.d.ts +30 -30
- package/lib/plugin/prefix-sum-computer.js +172 -172
- package/lib/plugin/quick-open.d.ts +202 -202
- package/lib/plugin/quick-open.js +637 -637
- package/lib/plugin/scm.d.ts +53 -53
- package/lib/plugin/scm.js +713 -713
- package/lib/plugin/secrets-ext.d.ts +30 -30
- package/lib/plugin/secrets-ext.js +68 -68
- package/lib/plugin/status-bar/status-bar-item.d.ts +44 -44
- package/lib/plugin/status-bar/status-bar-item.js +122 -122
- package/lib/plugin/status-bar-message-registry.d.ts +20 -20
- package/lib/plugin/status-bar-message-registry.js +84 -84
- package/lib/plugin/stubs/tests-api.d.ts +22 -22
- package/lib/plugin/stubs/tests-api.js +66 -66
- package/lib/plugin/tabs.d.ts +22 -22
- package/lib/plugin/tabs.js +358 -358
- package/lib/plugin/tasks/task-provider.d.ts +8 -8
- package/lib/plugin/tasks/task-provider.js +56 -56
- package/lib/plugin/tasks/tasks.d.ts +45 -45
- package/lib/plugin/tasks/tasks.js +210 -210
- package/lib/plugin/terminal-ext.d.ts +101 -101
- package/lib/plugin/terminal-ext.js +422 -422
- package/lib/plugin/text-editor.d.ts +100 -100
- package/lib/plugin/text-editor.js +409 -409
- package/lib/plugin/text-editors.d.ts +37 -37
- package/lib/plugin/text-editors.js +126 -126
- package/lib/plugin/theming.d.ts +15 -15
- package/lib/plugin/theming.js +61 -61
- package/lib/plugin/timeline.d.ts +20 -20
- package/lib/plugin/timeline.js +152 -152
- package/lib/plugin/tree/tree-views.d.ts +93 -93
- package/lib/plugin/tree/tree-views.js +523 -523
- package/lib/plugin/type-converters.d.ts +131 -131
- package/lib/plugin/type-converters.js +1292 -1292
- package/lib/plugin/type-converters.spec.d.ts +1 -1
- package/lib/plugin/type-converters.spec.js +391 -391
- package/lib/plugin/types-impl.d.ts +1464 -1464
- package/lib/plugin/types-impl.js +2956 -2956
- package/lib/plugin/types-impl.spec.d.ts +1 -1
- package/lib/plugin/types-impl.spec.js +78 -78
- package/lib/plugin/webview-views.d.ts +52 -52
- package/lib/plugin/webview-views.js +144 -144
- package/lib/plugin/webviews.d.ts +95 -95
- package/lib/plugin/webviews.js +340 -340
- package/lib/plugin/window-state.d.ts +16 -16
- package/lib/plugin/window-state.js +55 -55
- package/lib/plugin/word-helper.d.ts +21 -21
- package/lib/plugin/word-helper.js +125 -125
- package/lib/plugin/workspace.d.ts +53 -53
- package/lib/plugin/workspace.js +371 -371
- package/lib/plugin-ext-backend-electron-module.d.ts +3 -3
- package/lib/plugin-ext-backend-electron-module.js +24 -24
- package/lib/plugin-ext-backend-module.d.ts +3 -3
- package/lib/plugin-ext-backend-module.js +24 -24
- package/lib/plugin-ext-frontend-electron-module.d.ts +2 -2
- package/lib/plugin-ext-frontend-electron-module.js +19 -19
- package/lib/plugin-ext-frontend-module.d.ts +2 -2
- package/lib/plugin-ext-frontend-module.js +19 -19
- package/package.json +27 -27
- package/src/common/arrays.ts +54 -54
- package/src/common/assert.ts +23 -23
- package/src/common/cache.ts +51 -51
- package/src/common/character-classifier.ts +73 -73
- package/src/common/collections.ts +37 -37
- package/src/common/connection.ts +137 -137
- package/src/common/disposable-util.ts +39 -39
- package/src/common/editor-options.ts +74 -74
- package/src/common/env.ts +19 -19
- package/src/common/errors.ts +37 -37
- package/src/common/id-generator.ts +26 -26
- package/src/common/index.ts +24 -24
- package/src/common/link-computer.ts +354 -354
- package/src/common/object-identifier.ts +33 -33
- package/src/common/objects.ts +50 -50
- package/src/common/paths-util.ts +158 -158
- package/src/common/plugin-api-rpc-model.ts +864 -864
- package/src/common/plugin-api-rpc.ts +2202 -2202
- package/src/common/plugin-ext-api-contribution.ts +82 -82
- package/src/common/plugin-identifiers.ts +84 -84
- package/src/common/plugin-protocol.ts +987 -987
- package/src/common/proxy-handler.ts +126 -126
- package/src/common/reference-map.ts +38 -38
- package/src/common/rpc-protocol.ts +272 -272
- package/src/common/semantic-tokens-dto.ts +182 -182
- package/src/common/types.ts +129 -129
- package/src/common/uint.ts +37 -37
- package/src/common/uri-components.ts +85 -85
- package/src/hosted/browser/hosted-plugin-watcher.ts +54 -54
- package/src/hosted/browser/hosted-plugin.ts +830 -830
- package/src/hosted/browser/plugin-worker.ts +52 -52
- package/src/hosted/browser/worker/debug-stub.ts +28 -28
- package/src/hosted/browser/worker/plugin-manifest-loader.ts +114 -114
- package/src/hosted/browser/worker/worker-env-ext.ts +41 -41
- package/src/hosted/browser/worker/worker-main.ts +221 -221
- package/src/hosted/node/hosted-plugin-cli-contribution.ts +75 -75
- package/src/hosted/node/hosted-plugin-deployer-handler.ts +261 -261
- package/src/hosted/node/hosted-plugin-localization-service.ts +254 -254
- package/src/hosted/node/hosted-plugin-process.ts +248 -248
- package/src/hosted/node/hosted-plugin-protocol.ts +49 -49
- package/src/hosted/node/hosted-plugin.ts +116 -116
- package/src/hosted/node/metadata-scanner.ts +64 -64
- package/src/hosted/node/plugin-ext-hosted-backend-module.ts +80 -80
- package/src/hosted/node/plugin-host-proxy.ts +80 -80
- package/src/hosted/node/plugin-host-rpc.ts +245 -245
- package/src/hosted/node/plugin-host.ts +108 -108
- package/src/hosted/node/plugin-manifest-loader.ts +31 -31
- package/src/hosted/node/plugin-reader.ts +131 -131
- package/src/hosted/node/plugin-service.ts +175 -175
- package/src/hosted/node/scanners/backend-init-theia.ts +71 -71
- package/src/hosted/node/scanners/file-plugin-uri-factory.ts +32 -32
- package/src/hosted/node/scanners/grammars-reader.ts +56 -56
- package/src/hosted/node/scanners/plugin-uri-factory.ts +33 -33
- package/src/hosted/node/scanners/scanner-theia.ts +938 -938
- package/src/hosted/node-electron/plugin-ext-hosted-electron-backend-module.ts +26 -26
- package/src/hosted/node-electron/scanner-theia-electron.ts +32 -32
- package/src/main/browser/authentication-main.ts +369 -369
- package/src/main/browser/clipboard-main.ts +38 -38
- package/src/main/browser/command-registry-main.ts +110 -110
- package/src/main/browser/commands.ts +104 -104
- package/src/main/browser/comments/comment-glyph-widget.ts +66 -66
- package/src/main/browser/comments/comment-thread-widget.tsx +691 -691
- package/src/main/browser/comments/comments-context-key-service.ts +68 -68
- package/src/main/browser/comments/comments-contribution.ts +264 -264
- package/src/main/browser/comments/comments-decorator.ts +110 -110
- package/src/main/browser/comments/comments-main.ts +465 -465
- package/src/main/browser/comments/comments-service.ts +205 -205
- package/src/main/browser/custom-editors/custom-editor-contribution.ts +38 -38
- package/src/main/browser/custom-editors/custom-editor-opener.tsx +105 -105
- package/src/main/browser/custom-editors/custom-editor-service.ts +108 -108
- package/src/main/browser/custom-editors/custom-editor-widget-factory.ts +44 -44
- package/src/main/browser/custom-editors/custom-editor-widget.ts +127 -127
- package/src/main/browser/custom-editors/custom-editors-main.ts +606 -606
- package/src/main/browser/custom-editors/plugin-custom-editor-registry.ts +142 -142
- package/src/main/browser/custom-editors/undo-redo-service.ts +120 -120
- package/src/main/browser/debug/debug-main.ts +373 -373
- package/src/main/browser/debug/plugin-debug-adapter-contribution.ts +48 -48
- package/src/main/browser/debug/plugin-debug-configuration-provider.ts +63 -63
- package/src/main/browser/debug/plugin-debug-service.ts +338 -338
- package/src/main/browser/debug/plugin-debug-session-contribution-registry.ts +76 -76
- package/src/main/browser/debug/plugin-debug-session-factory.ts +105 -105
- package/src/main/browser/decorations/decorations-main.ts +146 -146
- package/src/main/browser/dialogs/modal-notification.ts +110 -110
- package/src/main/browser/dialogs/style/modal-notification.css +123 -123
- package/src/main/browser/dialogs-main.ts +185 -185
- package/src/main/browser/documents-main.ts +289 -289
- package/src/main/browser/editors-and-documents-main.ts +394 -394
- package/src/main/browser/env-main.ts +87 -87
- package/src/main/browser/file-system-main-impl.ts +263 -263
- package/src/main/browser/hierarchy/hierarchy-types-converters.ts +189 -189
- package/src/main/browser/keybindings/keybindings-contribution-handler.ts +66 -66
- package/src/main/browser/label-service-main.ts +51 -51
- package/src/main/browser/languages-main.ts +1387 -1387
- package/src/main/browser/main-context.ts +187 -187
- package/src/main/browser/main-file-system-event-service.ts +76 -76
- package/src/main/browser/menus/menus-contribution-handler.ts +162 -162
- package/src/main/browser/menus/plugin-menu-command-adapter.ts +264 -264
- package/src/main/browser/menus/vscode-theia-menu-mappings.ts +91 -91
- package/src/main/browser/message-registry-main.ts +56 -56
- package/src/main/browser/notification-main.ts +86 -86
- package/src/main/browser/output-channel-registry-main.ts +53 -53
- package/src/main/browser/plugin-authentication-service.ts +71 -71
- package/src/main/browser/plugin-contribution-handler.ts +609 -609
- package/src/main/browser/plugin-ext-frontend-module.ts +249 -249
- package/src/main/browser/plugin-ext-widget.tsx +132 -132
- package/src/main/browser/plugin-frontend-contribution.ts +35 -35
- package/src/main/browser/plugin-frontend-view-contribution.ts +38 -38
- package/src/main/browser/plugin-icon-theme-service.ts +585 -585
- package/src/main/browser/plugin-shared-style.ts +133 -133
- package/src/main/browser/plugin-storage.ts +55 -55
- package/src/main/browser/plugin-terminal-registry.ts +27 -27
- package/src/main/browser/preference-registry-main.ts +123 -123
- package/src/main/browser/quick-open-main.ts +324 -324
- package/src/main/browser/scm-main.ts +453 -453
- package/src/main/browser/secrets-main.ts +82 -82
- package/src/main/browser/selection-provider-command.ts +46 -46
- package/src/main/browser/status-bar-message-registry-main.ts +90 -90
- package/src/main/browser/style/comments.css +345 -345
- package/src/main/browser/style/index.css +85 -85
- package/src/main/browser/style/plugin-sidebar.css +73 -73
- package/src/main/browser/style/test.svg +13 -13
- package/src/main/browser/style/tree.css +52 -52
- package/src/main/browser/style/webview.css +53 -53
- package/src/main/browser/tabs/tabs-main.ts +323 -323
- package/src/main/browser/tasks-main.ts +268 -268
- package/src/main/browser/terminal-main.ts +301 -301
- package/src/main/browser/text-editor-main.ts +463 -463
- package/src/main/browser/text-editor-model-service.ts +102 -102
- package/src/main/browser/text-editors-main.ts +206 -206
- package/src/main/browser/theme-icon-override.ts +252 -252
- package/src/main/browser/theming-main.ts +42 -42
- package/src/main/browser/timeline-main.ts +80 -80
- package/src/main/browser/view/dnd-file-content-store.ts +42 -42
- package/src/main/browser/view/plugin-tree-view-node-label-provider.ts +81 -81
- package/src/main/browser/view/plugin-view-registry.ts +885 -885
- package/src/main/browser/view/plugin-view-widget.ts +173 -173
- package/src/main/browser/view/tree-view-decorator-service.ts +51 -51
- package/src/main/browser/view/tree-view-widget.tsx +859 -859
- package/src/main/browser/view/tree-views-main.ts +191 -191
- package/src/main/browser/view/view-context-key-service.ts +77 -77
- package/src/main/browser/view-column-service.ts +125 -125
- package/src/main/browser/webview/pre/fake.html +14 -14
- package/src/main/browser/webview/pre/host.js +130 -130
- package/src/main/browser/webview/pre/index.html +17 -17
- package/src/main/browser/webview/pre/main.js +632 -632
- package/src/main/browser/webview/pre/service-worker.js +295 -295
- package/src/main/browser/webview/webview-environment.ts +83 -83
- package/src/main/browser/webview/webview-frontend-security-warnings.ts +59 -59
- package/src/main/browser/webview/webview-preferences.ts +72 -72
- package/src/main/browser/webview/webview-resource-cache.ts +88 -88
- package/src/main/browser/webview/webview-theme-data-provider.ts +124 -124
- package/src/main/browser/webview/webview-widget-factory.ts +43 -43
- package/src/main/browser/webview/webview.ts +629 -629
- package/src/main/browser/webview-views/webview-views-main.ts +142 -142
- package/src/main/browser/webview-views/webview-views.ts +38 -38
- package/src/main/browser/webviews-main.ts +269 -269
- package/src/main/browser/window-state-main.ts +76 -76
- package/src/main/browser/workspace-main.ts +383 -383
- package/src/main/common/plugin-paths-protocol.ts +26 -26
- package/src/main/common/plugin-theia-environment.ts +36 -36
- package/src/main/common/webview-protocol.ts +28 -28
- package/src/main/electron-browser/plugin-ext-frontend-electron-module.ts +25 -25
- package/src/main/electron-browser/webview/electron-webview-widget-factory.ts +70 -70
- package/src/main/node/handlers/plugin-theia-directory-handler.ts +105 -105
- package/src/main/node/handlers/plugin-theia-file-handler.ts +54 -54
- package/src/main/node/paths/const.ts +21 -21
- package/src/main/node/paths/plugin-paths-service.ts +170 -170
- package/src/main/node/plugin-cli-contribution.ts +85 -85
- package/src/main/node/plugin-deployer-contribution.ts +34 -34
- package/src/main/node/plugin-deployer-directory-handler-context-impl.ts +45 -45
- package/src/main/node/plugin-deployer-entry-impl.ts +130 -130
- package/src/main/node/plugin-deployer-file-handler-context-impl.ts +33 -33
- package/src/main/node/plugin-deployer-impl.ts +367 -367
- package/src/main/node/plugin-deployer-proxy-entry-impl.ts +96 -96
- package/src/main/node/plugin-deployer-resolver-context-impl.ts +55 -55
- package/src/main/node/plugin-ext-backend-module.ts +93 -93
- package/src/main/node/plugin-github-resolver.ts +148 -148
- package/src/main/node/plugin-http-resolver.ts +91 -91
- package/src/main/node/plugin-localization-backend-contribution.ts +42 -42
- package/src/main/node/plugin-server-handler.ts +69 -69
- package/src/main/node/plugin-service.ts +82 -82
- package/src/main/node/plugin-theia-deployer-participant.ts +32 -32
- package/src/main/node/plugin-uninstallation-manager.ts +74 -74
- package/src/main/node/plugins-key-value-storage.ts +117 -117
- package/src/main/node/resolvers/local-directory-plugin-deployer-resolver.ts +37 -37
- package/src/main/node/resolvers/local-plugin-deployer-resolver.ts +56 -56
- package/src/main/node/temp-dir-util.ts +27 -27
- package/src/main/node/webview-backend-security-warnings.ts +45 -45
- package/src/main/style/status-bar.css +35 -35
- package/src/plugin/authentication-ext.ts +125 -125
- package/src/plugin/clipboard-ext.ts +37 -37
- package/src/plugin/command-registry.ts +218 -218
- package/src/plugin/comments.ts +518 -518
- package/src/plugin/custom-editors.ts +336 -336
- package/src/plugin/debug/debug-ext.ts +487 -487
- package/src/plugin/debug/plugin-debug-adapter-creator.ts +50 -50
- package/src/plugin/debug/plugin-debug-adapter-session.ts +106 -106
- package/src/plugin/debug/plugin-debug-adapter-tracker.ts +85 -85
- package/src/plugin/decorations.ts +140 -140
- package/src/plugin/dialogs.ts +96 -96
- package/src/plugin/document-data.ts +366 -366
- package/src/plugin/documents.ts +283 -283
- package/src/plugin/editors-and-documents.ts +170 -170
- package/src/plugin/env.ts +134 -134
- package/src/plugin/file-system-event-service-ext-impl.ts +256 -256
- package/src/plugin/file-system-ext-impl.ts +412 -412
- package/src/plugin/known-commands.spec.ts +50 -50
- package/src/plugin/known-commands.ts +412 -412
- package/src/plugin/label-service.ts +36 -36
- package/src/plugin/languages/call-hierarchy.ts +124 -124
- package/src/plugin/languages/code-action.ts +162 -162
- package/src/plugin/languages/color.ts +75 -75
- package/src/plugin/languages/completion.ts +179 -179
- package/src/plugin/languages/declaration.ts +72 -72
- package/src/plugin/languages/definition.ts +73 -73
- package/src/plugin/languages/diagnostics.ts +325 -325
- package/src/plugin/languages/document-formatting.ts +47 -47
- package/src/plugin/languages/document-highlight.ts +61 -61
- package/src/plugin/languages/evaluatable-expression.ts +47 -47
- package/src/plugin/languages/folding.ts +46 -46
- package/src/plugin/languages/hover.ts +58 -58
- package/src/plugin/languages/implementation.ts +73 -73
- package/src/plugin/languages/inlay-hints.ts +149 -149
- package/src/plugin/languages/inline-completion.ts +126 -126
- package/src/plugin/languages/inline-values.ts +50 -50
- package/src/plugin/languages/lens.ts +102 -102
- package/src/plugin/languages/link-provider.ts +79 -79
- package/src/plugin/languages/linked-editing-range.ts +48 -48
- package/src/plugin/languages/on-type-formatting.ts +50 -50
- package/src/plugin/languages/outline.ts +126 -126
- package/src/plugin/languages/range-formatting.ts +48 -48
- package/src/plugin/languages/reference.ts +58 -58
- package/src/plugin/languages/rename.ts +130 -130
- package/src/plugin/languages/selection-range.ts +80 -80
- package/src/plugin/languages/semantic-highlighting.ts +211 -211
- package/src/plugin/languages/signature.ts +82 -82
- package/src/plugin/languages/type-definition.ts +73 -73
- package/src/plugin/languages/type-hierarchy.ts +117 -117
- package/src/plugin/languages/util.ts +26 -26
- package/src/plugin/languages/workspace-symbol.ts +66 -66
- package/src/plugin/languages-utils.ts +56 -56
- package/src/plugin/languages.ts +969 -969
- package/src/plugin/markdown-string.ts +115 -115
- package/src/plugin/message-registry.ts +65 -65
- package/src/plugin/node/debug/debug.spec.ts +94 -94
- package/src/plugin/node/debug/plugin-node-debug-adapter-creator.ts +167 -167
- package/src/plugin/node/env-node-ext.ts +69 -69
- package/src/plugin/notification.ts +80 -80
- package/src/plugin/output-channel/output-channel-item.ts +73 -73
- package/src/plugin/output-channel-registry.ts +39 -39
- package/src/plugin/path.spec.ts +40 -40
- package/src/plugin/path.ts +68 -68
- package/src/plugin/plugin-context.ts +1387 -1387
- package/src/plugin/plugin-icon-path.ts +50 -50
- package/src/plugin/plugin-manager.ts +446 -446
- package/src/plugin/plugin-storage.ts +120 -120
- package/src/plugin/preference-registry.spec.ts +299 -299
- package/src/plugin/preference-registry.ts +337 -337
- package/src/plugin/prefix-sum-computer.ts +218 -218
- package/src/plugin/quick-open.ts +772 -772
- package/src/plugin/scm.ts +910 -910
- package/src/plugin/secrets-ext.ts +84 -84
- package/src/plugin/status-bar/status-bar-item.ts +193 -193
- package/src/plugin/status-bar-message-registry.ts +103 -103
- package/src/plugin/stubs/tests-api.ts +96 -96
- package/src/plugin/tabs.ts +426 -426
- package/src/plugin/tasks/task-provider.ts +60 -60
- package/src/plugin/tasks/tasks.ts +247 -247
- package/src/plugin/terminal-ext.ts +494 -494
- package/src/plugin/text-editor.ts +522 -522
- package/src/plugin/text-editors.ts +150 -150
- package/src/plugin/theming.ts +73 -73
- package/src/plugin/timeline.ts +186 -186
- package/src/plugin/tree/tree-views.ts +612 -612
- package/src/plugin/type-converters.spec.ts +476 -476
- package/src/plugin/type-converters.ts +1350 -1350
- package/src/plugin/types-impl.spec.ts +85 -85
- package/src/plugin/types-impl.ts +3407 -3407
- package/src/plugin/webview-views.ts +213 -213
- package/src/plugin/webviews.ts +433 -433
- package/src/plugin/window-state.ts +68 -68
- package/src/plugin/word-helper.ts +162 -162
- package/src/plugin/workspace.ts +448 -448
- package/src/plugin-ext-backend-electron-module.ts +24 -24
- package/src/plugin-ext-backend-module.ts +24 -24
- package/src/plugin-ext-frontend-electron-module.ts +19 -19
- package/src/plugin-ext-frontend-module.ts +19 -19
- package/src/typings/index.d.ts +25 -25
|
@@ -1,859 +1,859 @@
|
|
|
1
|
-
// *****************************************************************************
|
|
2
|
-
// Copyright (C) 2018-2019 Red Hat, Inc. and others.
|
|
3
|
-
//
|
|
4
|
-
// This program and the accompanying materials are made available under the
|
|
5
|
-
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
-
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
-
//
|
|
8
|
-
// This Source Code may also be made available under the following Secondary
|
|
9
|
-
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
-
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
-
// with the GNU Classpath Exception which is available at
|
|
12
|
-
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
-
//
|
|
14
|
-
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
|
|
15
|
-
// *****************************************************************************
|
|
16
|
-
|
|
17
|
-
import { injectable, inject, postConstruct } from '@theia/core/shared/inversify';
|
|
18
|
-
import { TreeViewsExt, TreeViewItemCollapsibleState, TreeViewItem, TreeViewItemReference, ThemeIcon, DataTransferFileDTO } from '../../../common/plugin-api-rpc';
|
|
19
|
-
import { Command } from '../../../common/plugin-api-rpc-model';
|
|
20
|
-
import {
|
|
21
|
-
TreeNode,
|
|
22
|
-
NodeProps,
|
|
23
|
-
SelectableTreeNode,
|
|
24
|
-
ExpandableTreeNode,
|
|
25
|
-
CompositeTreeNode,
|
|
26
|
-
TreeImpl,
|
|
27
|
-
TREE_NODE_SEGMENT_CLASS,
|
|
28
|
-
TREE_NODE_SEGMENT_GROW_CLASS,
|
|
29
|
-
TREE_NODE_TAIL_CLASS,
|
|
30
|
-
TreeModelImpl,
|
|
31
|
-
TreeViewWelcomeWidget,
|
|
32
|
-
TooltipAttributes,
|
|
33
|
-
TreeSelection,
|
|
34
|
-
HoverService,
|
|
35
|
-
ApplicationShell
|
|
36
|
-
} from '@theia/core/lib/browser';
|
|
37
|
-
import { MenuPath, MenuModelRegistry, ActionMenuNode } from '@theia/core/lib/common/menu';
|
|
38
|
-
import * as React from '@theia/core/shared/react';
|
|
39
|
-
import { PluginSharedStyle } from '../plugin-shared-style';
|
|
40
|
-
import { ACTION_ITEM, Widget } from '@theia/core/lib/browser/widgets/widget';
|
|
41
|
-
import { Emitter, Event } from '@theia/core/lib/common/event';
|
|
42
|
-
import { MessageService } from '@theia/core/lib/common/message-service';
|
|
43
|
-
import { View } from '../../../common/plugin-protocol';
|
|
44
|
-
import { URI } from '@theia/core/lib/common/uri';
|
|
45
|
-
import { ContextKeyService } from '@theia/core/lib/browser/context-key-service';
|
|
46
|
-
import { MarkdownString } from '@theia/core/lib/common/markdown-rendering';
|
|
47
|
-
import { LabelParser } from '@theia/core/lib/browser/label-parser';
|
|
48
|
-
import { AccessibilityInformation } from '@theia/plugin';
|
|
49
|
-
import { ColorRegistry } from '@theia/core/lib/browser/color-registry';
|
|
50
|
-
import { DecoratedTreeNode } from '@theia/core/lib/browser/tree/tree-decorator';
|
|
51
|
-
import { WidgetDecoration } from '@theia/core/lib/browser/widget-decoration';
|
|
52
|
-
import { CancellationTokenSource, CancellationToken } from '@theia/core/lib/common';
|
|
53
|
-
import { mixin } from '../../../common/types';
|
|
54
|
-
import { Deferred } from '@theia/core/lib/common/promise-util';
|
|
55
|
-
import { DnDFileContentStore } from './dnd-file-content-store';
|
|
56
|
-
|
|
57
|
-
export const TREE_NODE_HYPERLINK = 'theia-TreeNodeHyperlink';
|
|
58
|
-
export const VIEW_ITEM_CONTEXT_MENU: MenuPath = ['view-item-context-menu'];
|
|
59
|
-
export const VIEW_ITEM_INLINE_MENU: MenuPath = ['view-item-context-menu', 'inline'];
|
|
60
|
-
|
|
61
|
-
export interface SelectionEventHandler {
|
|
62
|
-
readonly node: SelectableTreeNode;
|
|
63
|
-
readonly contextSelection: boolean;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
export interface TreeViewNode extends SelectableTreeNode, DecoratedTreeNode {
|
|
67
|
-
contextValue?: string;
|
|
68
|
-
command?: Command;
|
|
69
|
-
resourceUri?: string;
|
|
70
|
-
themeIcon?: ThemeIcon;
|
|
71
|
-
tooltip?: string | MarkdownString;
|
|
72
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
73
|
-
description?: string | boolean | any;
|
|
74
|
-
accessibilityInformation?: AccessibilityInformation;
|
|
75
|
-
}
|
|
76
|
-
export namespace TreeViewNode {
|
|
77
|
-
export function is(arg: TreeNode | undefined): arg is TreeViewNode {
|
|
78
|
-
return !!arg && SelectableTreeNode.is(arg) && DecoratedTreeNode.is(arg);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
export class ResolvableTreeViewNode implements TreeViewNode {
|
|
83
|
-
contextValue?: string;
|
|
84
|
-
command?: Command;
|
|
85
|
-
resourceUri?: string;
|
|
86
|
-
themeIcon?: ThemeIcon;
|
|
87
|
-
tooltip?: string | MarkdownString;
|
|
88
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
89
|
-
description?: string | boolean | any;
|
|
90
|
-
accessibilityInformation?: AccessibilityInformation;
|
|
91
|
-
selected: boolean;
|
|
92
|
-
focus?: boolean;
|
|
93
|
-
id: string;
|
|
94
|
-
name?: string;
|
|
95
|
-
icon?: string;
|
|
96
|
-
visible?: boolean;
|
|
97
|
-
parent: Readonly<CompositeTreeNode>;
|
|
98
|
-
previousSibling?: TreeNode;
|
|
99
|
-
nextSibling?: TreeNode;
|
|
100
|
-
busy?: number;
|
|
101
|
-
decorationData: WidgetDecoration.Data;
|
|
102
|
-
|
|
103
|
-
resolve: ((token: CancellationToken) => Promise<void>);
|
|
104
|
-
|
|
105
|
-
private _resolved = false;
|
|
106
|
-
private resolving: Deferred<void> | undefined;
|
|
107
|
-
|
|
108
|
-
constructor(treeViewNode: Partial<TreeViewNode>, resolve: (token: CancellationToken) => Promise<TreeViewItem | undefined>) {
|
|
109
|
-
mixin(this, treeViewNode);
|
|
110
|
-
this.resolve = async (token: CancellationToken) => {
|
|
111
|
-
if (this.resolving) {
|
|
112
|
-
return this.resolving.promise;
|
|
113
|
-
}
|
|
114
|
-
if (!this._resolved) {
|
|
115
|
-
this.resolving = new Deferred();
|
|
116
|
-
const resolvedTreeItem = await resolve(token);
|
|
117
|
-
if (resolvedTreeItem) {
|
|
118
|
-
this.command = this.command ?? resolvedTreeItem.command;
|
|
119
|
-
this.tooltip = this.tooltip ?? resolvedTreeItem.tooltip;
|
|
120
|
-
}
|
|
121
|
-
this.resolving.resolve();
|
|
122
|
-
this.resolving = undefined;
|
|
123
|
-
}
|
|
124
|
-
if (!token.isCancellationRequested) {
|
|
125
|
-
this._resolved = true;
|
|
126
|
-
}
|
|
127
|
-
};
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
reset(): void {
|
|
131
|
-
this._resolved = false;
|
|
132
|
-
this.resolving = undefined;
|
|
133
|
-
this.command = undefined;
|
|
134
|
-
this.tooltip = undefined;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
get resolved(): boolean {
|
|
138
|
-
return this._resolved;
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
export class ResolvableCompositeTreeViewNode extends ResolvableTreeViewNode implements CompositeTreeViewNode {
|
|
143
|
-
expanded: boolean;
|
|
144
|
-
children: readonly TreeNode[];
|
|
145
|
-
constructor(
|
|
146
|
-
treeViewNode: Pick<CompositeTreeViewNode, 'children' | 'expanded'> & Partial<TreeViewNode>,
|
|
147
|
-
resolve: (token: CancellationToken) => Promise<TreeViewItem | undefined>) {
|
|
148
|
-
super(treeViewNode, resolve);
|
|
149
|
-
this.expanded = treeViewNode.expanded;
|
|
150
|
-
this.children = treeViewNode.children;
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
export interface CompositeTreeViewNode extends TreeViewNode, ExpandableTreeNode, CompositeTreeNode {
|
|
155
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
156
|
-
description?: string | boolean | any;
|
|
157
|
-
}
|
|
158
|
-
export namespace CompositeTreeViewNode {
|
|
159
|
-
export function is(arg: TreeNode | undefined): arg is CompositeTreeViewNode {
|
|
160
|
-
return TreeViewNode.is(arg) && ExpandableTreeNode.is(arg) && CompositeTreeNode.is(arg);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
@injectable()
|
|
165
|
-
export class TreeViewWidgetOptions {
|
|
166
|
-
id: string;
|
|
167
|
-
multiSelect: boolean | undefined;
|
|
168
|
-
dragMimeTypes: string[] | undefined;
|
|
169
|
-
dropMimeTypes: string[] | undefined;
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
@injectable()
|
|
173
|
-
export class PluginTree extends TreeImpl {
|
|
174
|
-
|
|
175
|
-
@inject(PluginSharedStyle)
|
|
176
|
-
protected readonly sharedStyle: PluginSharedStyle;
|
|
177
|
-
|
|
178
|
-
@inject(TreeViewWidgetOptions)
|
|
179
|
-
protected readonly options: TreeViewWidgetOptions;
|
|
180
|
-
|
|
181
|
-
@inject(MessageService)
|
|
182
|
-
protected readonly notification: MessageService;
|
|
183
|
-
|
|
184
|
-
protected readonly onDidChangeWelcomeStateEmitter: Emitter<void> = new Emitter<void>();
|
|
185
|
-
readonly onDidChangeWelcomeState = this.onDidChangeWelcomeStateEmitter.event;
|
|
186
|
-
|
|
187
|
-
private _proxy: TreeViewsExt | undefined;
|
|
188
|
-
private _viewInfo: View | undefined;
|
|
189
|
-
private _isEmpty: boolean;
|
|
190
|
-
private _hasTreeItemResolve: Promise<boolean> = Promise.resolve(false);
|
|
191
|
-
|
|
192
|
-
set proxy(proxy: TreeViewsExt | undefined) {
|
|
193
|
-
this._proxy = proxy;
|
|
194
|
-
if (proxy) {
|
|
195
|
-
this._hasTreeItemResolve = proxy.$hasResolveTreeItem(this.options.id);
|
|
196
|
-
} else {
|
|
197
|
-
this._hasTreeItemResolve = Promise.resolve(false);
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
get proxy(): TreeViewsExt | undefined {
|
|
201
|
-
return this._proxy;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
get hasTreeItemResolve(): Promise<boolean> {
|
|
205
|
-
return this._hasTreeItemResolve;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
set viewInfo(viewInfo: View) {
|
|
209
|
-
this._viewInfo = viewInfo;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
get isEmpty(): boolean {
|
|
213
|
-
return this._isEmpty;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
protected override async resolveChildren(parent: CompositeTreeNode): Promise<TreeNode[]> {
|
|
217
|
-
if (!this._proxy) {
|
|
218
|
-
return super.resolveChildren(parent);
|
|
219
|
-
}
|
|
220
|
-
const children = await this.fetchChildren(this._proxy, parent);
|
|
221
|
-
const hasResolve = await this.hasTreeItemResolve;
|
|
222
|
-
return children.map(value => hasResolve ? this.createResolvableTreeNode(value, parent) : this.createTreeNode(value, parent));
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
protected async fetchChildren(proxy: TreeViewsExt, parent: CompositeTreeNode): Promise<TreeViewItem[]> {
|
|
226
|
-
try {
|
|
227
|
-
const children = await proxy.$getChildren(this.options.id, parent.id);
|
|
228
|
-
const oldEmpty = this._isEmpty;
|
|
229
|
-
this._isEmpty = !parent.id && (!children || children.length === 0);
|
|
230
|
-
if (oldEmpty !== this._isEmpty) {
|
|
231
|
-
this.onDidChangeWelcomeStateEmitter.fire();
|
|
232
|
-
}
|
|
233
|
-
return children || [];
|
|
234
|
-
} catch (e) {
|
|
235
|
-
if (e) {
|
|
236
|
-
console.error(`Failed to fetch children for '${this.options.id}'`, e);
|
|
237
|
-
const label = this._viewInfo ? this._viewInfo.name : this.options.id;
|
|
238
|
-
this.notification.error(`${label}: ${e.message}`);
|
|
239
|
-
}
|
|
240
|
-
return [];
|
|
241
|
-
}
|
|
242
|
-
}
|
|
243
|
-
|
|
244
|
-
protected createTreeNode(item: TreeViewItem, parent: CompositeTreeNode): TreeNode {
|
|
245
|
-
const update: Partial<TreeViewNode> = this.createTreeNodeUpdate(item);
|
|
246
|
-
const node = this.getNode(item.id);
|
|
247
|
-
if (item.collapsibleState !== undefined && item.collapsibleState !== TreeViewItemCollapsibleState.None) {
|
|
248
|
-
if (CompositeTreeViewNode.is(node)) {
|
|
249
|
-
return Object.assign(node, update);
|
|
250
|
-
}
|
|
251
|
-
return Object.assign({
|
|
252
|
-
id: item.id,
|
|
253
|
-
parent,
|
|
254
|
-
visible: true,
|
|
255
|
-
selected: false,
|
|
256
|
-
expanded: TreeViewItemCollapsibleState.Expanded === item.collapsibleState,
|
|
257
|
-
children: [],
|
|
258
|
-
command: item.command
|
|
259
|
-
}, update);
|
|
260
|
-
}
|
|
261
|
-
if (TreeViewNode.is(node) && !ExpandableTreeNode.is(node)) {
|
|
262
|
-
return Object.assign(node, update, { command: item.command });
|
|
263
|
-
}
|
|
264
|
-
return Object.assign({
|
|
265
|
-
id: item.id,
|
|
266
|
-
parent,
|
|
267
|
-
visible: true,
|
|
268
|
-
selected: false,
|
|
269
|
-
command: item.command,
|
|
270
|
-
}, update);
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
/** Creates a resolvable tree node. If a node already exists, reset it because the underlying TreeViewItem might have been disposed in the backend. */
|
|
274
|
-
protected createResolvableTreeNode(item: TreeViewItem, parent: CompositeTreeNode): TreeNode {
|
|
275
|
-
const update: Partial<TreeViewNode> = this.createTreeNodeUpdate(item);
|
|
276
|
-
const node = this.getNode(item.id);
|
|
277
|
-
|
|
278
|
-
// Node is a composite node that might contain children
|
|
279
|
-
if (item.collapsibleState !== undefined && item.collapsibleState !== TreeViewItemCollapsibleState.None) {
|
|
280
|
-
// Reuse existing composite node and reset it
|
|
281
|
-
if (node instanceof ResolvableCompositeTreeViewNode) {
|
|
282
|
-
node.reset();
|
|
283
|
-
return Object.assign(node, update);
|
|
284
|
-
}
|
|
285
|
-
// Create new composite node
|
|
286
|
-
const compositeNode = Object.assign({
|
|
287
|
-
id: item.id,
|
|
288
|
-
parent,
|
|
289
|
-
visible: true,
|
|
290
|
-
selected: false,
|
|
291
|
-
expanded: TreeViewItemCollapsibleState.Expanded === item.collapsibleState,
|
|
292
|
-
children: [],
|
|
293
|
-
command: item.command
|
|
294
|
-
}, update);
|
|
295
|
-
return new ResolvableCompositeTreeViewNode(compositeNode, async (token: CancellationToken) => this._proxy?.$resolveTreeItem(this.options.id, item.id, token));
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
// Node is a leaf
|
|
299
|
-
// Reuse existing node and reset it.
|
|
300
|
-
if (node instanceof ResolvableTreeViewNode && !ExpandableTreeNode.is(node)) {
|
|
301
|
-
node.reset();
|
|
302
|
-
return Object.assign(node, update);
|
|
303
|
-
}
|
|
304
|
-
const treeNode = Object.assign({
|
|
305
|
-
id: item.id,
|
|
306
|
-
parent,
|
|
307
|
-
visible: true,
|
|
308
|
-
selected: false,
|
|
309
|
-
command: item.command,
|
|
310
|
-
}, update);
|
|
311
|
-
return new ResolvableTreeViewNode(treeNode, async (token: CancellationToken) => this._proxy?.$resolveTreeItem(this.options.id, item.id, token));
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
protected createTreeNodeUpdate(item: TreeViewItem): Partial<TreeViewNode> {
|
|
315
|
-
const decorationData = this.toDecorationData(item);
|
|
316
|
-
const icon = this.toIconClass(item);
|
|
317
|
-
const resourceUri = item.resourceUri && URI.fromComponents(item.resourceUri).toString();
|
|
318
|
-
const themeIcon = item.themeIcon ? item.themeIcon : item.collapsibleState !== TreeViewItemCollapsibleState.None ? { id: 'folder' } : undefined;
|
|
319
|
-
return {
|
|
320
|
-
name: item.label,
|
|
321
|
-
decorationData,
|
|
322
|
-
icon,
|
|
323
|
-
description: item.description,
|
|
324
|
-
themeIcon,
|
|
325
|
-
resourceUri,
|
|
326
|
-
tooltip: item.tooltip,
|
|
327
|
-
contextValue: item.contextValue,
|
|
328
|
-
command: item.command,
|
|
329
|
-
accessibilityInformation: item.accessibilityInformation,
|
|
330
|
-
};
|
|
331
|
-
}
|
|
332
|
-
|
|
333
|
-
protected toDecorationData(item: TreeViewItem): WidgetDecoration.Data {
|
|
334
|
-
let decoration: WidgetDecoration.Data = {};
|
|
335
|
-
if (item.highlights) {
|
|
336
|
-
const highlight = {
|
|
337
|
-
ranges: item.highlights.map(h => ({ offset: h[0], length: h[1] - h[0] }))
|
|
338
|
-
};
|
|
339
|
-
decoration = { highlight };
|
|
340
|
-
}
|
|
341
|
-
return decoration;
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
protected toIconClass(item: TreeViewItem): string | undefined {
|
|
345
|
-
if (item.icon) {
|
|
346
|
-
return 'fa ' + item.icon;
|
|
347
|
-
}
|
|
348
|
-
if (item.iconUrl) {
|
|
349
|
-
const reference = this.sharedStyle.toIconClass(item.iconUrl);
|
|
350
|
-
this.toDispose.push(reference);
|
|
351
|
-
return reference.object.iconClass;
|
|
352
|
-
}
|
|
353
|
-
return undefined;
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
@injectable()
|
|
359
|
-
export class PluginTreeModel extends TreeModelImpl {
|
|
360
|
-
|
|
361
|
-
@inject(PluginTree)
|
|
362
|
-
protected override readonly tree: PluginTree;
|
|
363
|
-
|
|
364
|
-
set proxy(proxy: TreeViewsExt | undefined) {
|
|
365
|
-
this.tree.proxy = proxy;
|
|
366
|
-
}
|
|
367
|
-
get proxy(): TreeViewsExt | undefined {
|
|
368
|
-
return this.tree.proxy;
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
get hasTreeItemResolve(): Promise<boolean> {
|
|
372
|
-
return this.tree.hasTreeItemResolve;
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
set viewInfo(viewInfo: View) {
|
|
376
|
-
this.tree.viewInfo = viewInfo;
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
get isTreeEmpty(): boolean {
|
|
380
|
-
return this.tree.isEmpty;
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
get onDidChangeWelcomeState(): Event<void> {
|
|
384
|
-
return this.tree.onDidChangeWelcomeState;
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
override doOpenNode(node: TreeNode): void {
|
|
388
|
-
super.doOpenNode(node);
|
|
389
|
-
if (node instanceof ResolvableTreeViewNode) {
|
|
390
|
-
node.resolve(CancellationToken.None);
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
|
|
395
|
-
@injectable()
|
|
396
|
-
export class TreeViewWidget extends TreeViewWelcomeWidget {
|
|
397
|
-
|
|
398
|
-
protected _contextSelection = false;
|
|
399
|
-
|
|
400
|
-
@inject(ApplicationShell)
|
|
401
|
-
protected readonly applicationShell: ApplicationShell;
|
|
402
|
-
|
|
403
|
-
@inject(MenuModelRegistry)
|
|
404
|
-
protected readonly menus: MenuModelRegistry;
|
|
405
|
-
|
|
406
|
-
@inject(ContextKeyService)
|
|
407
|
-
protected readonly contextKeys: ContextKeyService;
|
|
408
|
-
|
|
409
|
-
@inject(TreeViewWidgetOptions)
|
|
410
|
-
readonly options: TreeViewWidgetOptions;
|
|
411
|
-
|
|
412
|
-
@inject(PluginTreeModel)
|
|
413
|
-
override readonly model: PluginTreeModel;
|
|
414
|
-
|
|
415
|
-
@inject(ContextKeyService)
|
|
416
|
-
protected readonly contextKeyService: ContextKeyService;
|
|
417
|
-
|
|
418
|
-
@inject(HoverService)
|
|
419
|
-
protected readonly hoverService: HoverService;
|
|
420
|
-
|
|
421
|
-
@inject(LabelParser)
|
|
422
|
-
protected readonly labelParser: LabelParser;
|
|
423
|
-
|
|
424
|
-
@inject(ColorRegistry)
|
|
425
|
-
protected readonly colorRegistry: ColorRegistry;
|
|
426
|
-
|
|
427
|
-
@inject(DnDFileContentStore)
|
|
428
|
-
protected readonly dndFileContentStore: DnDFileContentStore;
|
|
429
|
-
|
|
430
|
-
protected treeDragType: string;
|
|
431
|
-
protected readonly expansionTimeouts: Map<string, number> = new Map();
|
|
432
|
-
|
|
433
|
-
@postConstruct()
|
|
434
|
-
protected override init(): void {
|
|
435
|
-
super.init();
|
|
436
|
-
this.id = this.options.id;
|
|
437
|
-
this.addClass('theia-tree-view');
|
|
438
|
-
this.node.style.height = '100%';
|
|
439
|
-
this.model.onDidChangeWelcomeState(this.update, this);
|
|
440
|
-
this.toDispose.push(this.model.onDidChangeWelcomeState(this.update, this));
|
|
441
|
-
this.toDispose.push(this.onDidChangeVisibilityEmitter);
|
|
442
|
-
this.toDispose.push(this.contextKeyService.onDidChange(() => this.update()));
|
|
443
|
-
this.treeDragType = `application/vnd.code.tree.${this.id.toLowerCase()}`;
|
|
444
|
-
}
|
|
445
|
-
|
|
446
|
-
protected override renderIcon(node: TreeNode, props: NodeProps): React.ReactNode {
|
|
447
|
-
const icon = this.toNodeIcon(node);
|
|
448
|
-
if (icon) {
|
|
449
|
-
let style: React.CSSProperties | undefined;
|
|
450
|
-
if (TreeViewNode.is(node) && node.themeIcon?.color) {
|
|
451
|
-
const color = this.colorRegistry.getCurrentColor(node.themeIcon.color.id);
|
|
452
|
-
if (color) {
|
|
453
|
-
style = { color };
|
|
454
|
-
}
|
|
455
|
-
}
|
|
456
|
-
return <div className={icon + ' theia-tree-view-icon'} style={style}></div>;
|
|
457
|
-
}
|
|
458
|
-
return undefined;
|
|
459
|
-
}
|
|
460
|
-
|
|
461
|
-
protected override renderCaption(node: TreeViewNode, props: NodeProps): React.ReactNode {
|
|
462
|
-
const classes = [TREE_NODE_SEGMENT_CLASS];
|
|
463
|
-
if (!this.hasTrailingSuffixes(node)) {
|
|
464
|
-
classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
|
|
465
|
-
}
|
|
466
|
-
const className = classes.join(' ');
|
|
467
|
-
|
|
468
|
-
let attrs: React.HTMLAttributes<HTMLElement> & Partial<TooltipAttributes> = {
|
|
469
|
-
...this.decorateCaption(node, {}),
|
|
470
|
-
className,
|
|
471
|
-
id: node.id
|
|
472
|
-
};
|
|
473
|
-
|
|
474
|
-
if (node.accessibilityInformation) {
|
|
475
|
-
attrs = {
|
|
476
|
-
...attrs,
|
|
477
|
-
'aria-label': node.accessibilityInformation.label,
|
|
478
|
-
'role': node.accessibilityInformation.role
|
|
479
|
-
};
|
|
480
|
-
}
|
|
481
|
-
|
|
482
|
-
if (!node.tooltip && node instanceof ResolvableTreeViewNode) {
|
|
483
|
-
let configuredTip = false;
|
|
484
|
-
let source: CancellationTokenSource | undefined;
|
|
485
|
-
attrs = {
|
|
486
|
-
...attrs,
|
|
487
|
-
onMouseLeave: () => source?.cancel(),
|
|
488
|
-
onMouseEnter: async event => {
|
|
489
|
-
if (configuredTip) {
|
|
490
|
-
if (MarkdownString.is(node.tooltip)) {
|
|
491
|
-
this.hoverService.requestHover({
|
|
492
|
-
content: node.tooltip,
|
|
493
|
-
target: event.target as HTMLElement,
|
|
494
|
-
position: 'right'
|
|
495
|
-
});
|
|
496
|
-
}
|
|
497
|
-
return;
|
|
498
|
-
}
|
|
499
|
-
if (!node.resolved) {
|
|
500
|
-
source = new CancellationTokenSource();
|
|
501
|
-
const token = source.token;
|
|
502
|
-
await node.resolve(token);
|
|
503
|
-
if (token.isCancellationRequested) {
|
|
504
|
-
return;
|
|
505
|
-
}
|
|
506
|
-
}
|
|
507
|
-
if (MarkdownString.is(node.tooltip)) {
|
|
508
|
-
this.hoverService.requestHover({
|
|
509
|
-
content: node.tooltip,
|
|
510
|
-
target: event.target as HTMLElement,
|
|
511
|
-
position: 'right'
|
|
512
|
-
});
|
|
513
|
-
} else {
|
|
514
|
-
const title = node.tooltip ||
|
|
515
|
-
(node.resourceUri && this.labelProvider.getLongName(new URI(node.resourceUri)))
|
|
516
|
-
|| this.toNodeName(node);
|
|
517
|
-
event.currentTarget.title = title;
|
|
518
|
-
}
|
|
519
|
-
configuredTip = true;
|
|
520
|
-
}
|
|
521
|
-
};
|
|
522
|
-
} else if (MarkdownString.is(node.tooltip)) {
|
|
523
|
-
attrs = {
|
|
524
|
-
...attrs,
|
|
525
|
-
onMouseEnter: event => {
|
|
526
|
-
this.hoverService.requestHover({
|
|
527
|
-
content: node.tooltip!,
|
|
528
|
-
target: event.target as HTMLElement,
|
|
529
|
-
position: 'right'
|
|
530
|
-
});
|
|
531
|
-
}
|
|
532
|
-
};
|
|
533
|
-
} else {
|
|
534
|
-
const title = node.tooltip ||
|
|
535
|
-
(node.resourceUri && this.labelProvider.getLongName(new URI(node.resourceUri)))
|
|
536
|
-
|| this.toNodeName(node);
|
|
537
|
-
|
|
538
|
-
attrs = {
|
|
539
|
-
...attrs,
|
|
540
|
-
title
|
|
541
|
-
};
|
|
542
|
-
}
|
|
543
|
-
|
|
544
|
-
const children: React.ReactNode[] = [];
|
|
545
|
-
const caption = this.toNodeName(node);
|
|
546
|
-
const highlight = this.getDecorationData(node, 'highlight')[0];
|
|
547
|
-
if (highlight) {
|
|
548
|
-
children.push(this.toReactNode(caption, highlight));
|
|
549
|
-
}
|
|
550
|
-
const searchHighlight = this.searchHighlights && this.searchHighlights.get(node.id);
|
|
551
|
-
if (searchHighlight) {
|
|
552
|
-
children.push(...this.toReactNode(caption, searchHighlight));
|
|
553
|
-
} else if (!highlight) {
|
|
554
|
-
children.push(caption);
|
|
555
|
-
}
|
|
556
|
-
const description = this.toNodeDescription(node);
|
|
557
|
-
if (description) {
|
|
558
|
-
children.push(<span className='theia-tree-view-description'>{description}</span>);
|
|
559
|
-
}
|
|
560
|
-
return <div {...attrs}>{...children}</div>;
|
|
561
|
-
}
|
|
562
|
-
|
|
563
|
-
protected override createNodeAttributes(node: TreeViewNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
|
|
564
|
-
const attrs = super.createNodeAttributes(node, props);
|
|
565
|
-
|
|
566
|
-
if (this.options.dragMimeTypes) {
|
|
567
|
-
attrs.onDragStart = event => this.handleDragStartEvent(node, event);
|
|
568
|
-
attrs.onDragEnd = event => this.handleDragEnd(node, event);
|
|
569
|
-
attrs.draggable = true;
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
if (this.options.dropMimeTypes) {
|
|
573
|
-
attrs.onDrop = event => this.handleDropEvent(node, event);
|
|
574
|
-
attrs.onDragEnter = event => this.handleDragEnter(node, event);
|
|
575
|
-
attrs.onDragLeave = event => this.handleDragLeave(node, event);
|
|
576
|
-
attrs.onDragOver = event => this.handleDragOver(event);
|
|
577
|
-
}
|
|
578
|
-
|
|
579
|
-
return attrs;
|
|
580
|
-
}
|
|
581
|
-
handleDragLeave(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
582
|
-
const timeout = this.expansionTimeouts.get(node.id);
|
|
583
|
-
if (typeof timeout !== 'undefined') {
|
|
584
|
-
console.debug(`dragleave ${node.id} canceling timeout`);
|
|
585
|
-
clearTimeout(timeout);
|
|
586
|
-
this.expansionTimeouts.delete(node.id);
|
|
587
|
-
}
|
|
588
|
-
}
|
|
589
|
-
handleDragEnter(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
590
|
-
console.debug(`dragenter ${node.id}`);
|
|
591
|
-
if (ExpandableTreeNode.is(node)) {
|
|
592
|
-
console.debug(`dragenter ${node.id} starting timeout`);
|
|
593
|
-
this.expansionTimeouts.set(node.id, window.setTimeout(() => {
|
|
594
|
-
console.debug(`dragenter ${node.id} timeout reached`);
|
|
595
|
-
this.model.expandNode(node);
|
|
596
|
-
}, 500));
|
|
597
|
-
}
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
protected override createContainerAttributes(): React.HTMLAttributes<HTMLElement> {
|
|
601
|
-
const attrs = super.createContainerAttributes();
|
|
602
|
-
if (this.options.dropMimeTypes) {
|
|
603
|
-
attrs.onDrop = event => this.handleDropEvent(undefined, event);
|
|
604
|
-
attrs.onDragOver = event => this.handleDragOver(event);
|
|
605
|
-
}
|
|
606
|
-
return attrs;
|
|
607
|
-
}
|
|
608
|
-
|
|
609
|
-
protected handleDragStartEvent(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
610
|
-
event.dataTransfer!.setData(this.treeDragType, '');
|
|
611
|
-
let selectedNodes: TreeViewNode[] = [];
|
|
612
|
-
if (this.model.selectedNodes.find(selected => TreeNode.equals(selected, node))) {
|
|
613
|
-
selectedNodes = this.model.selectedNodes.filter(TreeViewNode.is);
|
|
614
|
-
} else {
|
|
615
|
-
selectedNodes = [node];
|
|
616
|
-
}
|
|
617
|
-
|
|
618
|
-
this.options.dragMimeTypes!.forEach(type => {
|
|
619
|
-
if (type === 'text/uri-list') {
|
|
620
|
-
ApplicationShell.setDraggedEditorUris(event.dataTransfer, selectedNodes.filter(n => n.resourceUri).map(n => new URI(n.resourceUri)));
|
|
621
|
-
} else {
|
|
622
|
-
event.dataTransfer.setData(type, '');
|
|
623
|
-
}
|
|
624
|
-
});
|
|
625
|
-
|
|
626
|
-
this.model.proxy!.$dragStarted(this.options.id, selectedNodes.map(selected => selected.id), CancellationToken.None).then(maybeUris => {
|
|
627
|
-
if (maybeUris) {
|
|
628
|
-
this.applicationShell.addAdditionalDraggedEditorUris(maybeUris.map(URI.fromComponents));
|
|
629
|
-
}
|
|
630
|
-
});
|
|
631
|
-
}
|
|
632
|
-
|
|
633
|
-
handleDragEnd(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
634
|
-
this.applicationShell.clearAdditionalDraggedEditorUris();
|
|
635
|
-
}
|
|
636
|
-
|
|
637
|
-
handleDragOver(event: React.DragEvent<HTMLElement>): void {
|
|
638
|
-
if (event.dataTransfer) {
|
|
639
|
-
const canDrop = event.dataTransfer.types.some(type => this.options.dropMimeTypes!.includes(type)) ||
|
|
640
|
-
event.dataTransfer.types.includes(this.treeDragType) ||
|
|
641
|
-
this.options.dropMimeTypes!.includes('files') && event.dataTransfer.files.length > 0;
|
|
642
|
-
if (canDrop) {
|
|
643
|
-
event.preventDefault();
|
|
644
|
-
event.dataTransfer.dropEffect = 'move';
|
|
645
|
-
} else {
|
|
646
|
-
event.dataTransfer.dropEffect = 'none';
|
|
647
|
-
}
|
|
648
|
-
event.stopPropagation();
|
|
649
|
-
}
|
|
650
|
-
}
|
|
651
|
-
|
|
652
|
-
protected handleDropEvent(node: TreeViewNode | undefined, event: React.DragEvent<HTMLElement>): void {
|
|
653
|
-
if (event.dataTransfer) {
|
|
654
|
-
const items: [string, string | DataTransferFileDTO][] = [];
|
|
655
|
-
let files: string[] = [];
|
|
656
|
-
try {
|
|
657
|
-
for (let i = 0; i < event.dataTransfer.items.length; i++) {
|
|
658
|
-
const transferItem = event.dataTransfer.items[i];
|
|
659
|
-
if (transferItem.type !== this.treeDragType) {
|
|
660
|
-
// do not pass the artificial drag data to the extension
|
|
661
|
-
const f = event.dataTransfer.items[i].getAsFile();
|
|
662
|
-
if (f) {
|
|
663
|
-
const fileId = this.dndFileContentStore.addFile(f);
|
|
664
|
-
files.push(fileId);
|
|
665
|
-
const uri = f.path ? {
|
|
666
|
-
scheme: 'file',
|
|
667
|
-
path: f.path,
|
|
668
|
-
authority: '',
|
|
669
|
-
query: '',
|
|
670
|
-
fragment: ''
|
|
671
|
-
} : undefined;
|
|
672
|
-
items.push([transferItem.type, new DataTransferFileDTO(f.name, fileId, uri)]);
|
|
673
|
-
} else {
|
|
674
|
-
const textData = event.dataTransfer.getData(transferItem.type);
|
|
675
|
-
if (textData) {
|
|
676
|
-
items.push([transferItem.type, textData]);
|
|
677
|
-
}
|
|
678
|
-
}
|
|
679
|
-
}
|
|
680
|
-
}
|
|
681
|
-
if (items.length > 0 || event.dataTransfer.types.includes(this.treeDragType)) {
|
|
682
|
-
event.preventDefault();
|
|
683
|
-
event.stopPropagation();
|
|
684
|
-
this.model.proxy?.$drop(this.id, node?.id, items, CancellationToken.None).finally(() => {
|
|
685
|
-
for (const file of files) {
|
|
686
|
-
this.dndFileContentStore.removeFile(file);
|
|
687
|
-
}
|
|
688
|
-
});
|
|
689
|
-
files = [];
|
|
690
|
-
}
|
|
691
|
-
} catch (e) {
|
|
692
|
-
for (const file of files) {
|
|
693
|
-
this.dndFileContentStore.removeFile(file);
|
|
694
|
-
}
|
|
695
|
-
throw e;
|
|
696
|
-
}
|
|
697
|
-
}
|
|
698
|
-
}
|
|
699
|
-
|
|
700
|
-
protected override renderTailDecorations(treeViewNode: TreeViewNode, props: NodeProps): React.ReactNode {
|
|
701
|
-
return this.contextKeys.with({ view: this.id, viewItem: treeViewNode.contextValue }, () => {
|
|
702
|
-
const menu = this.menus.getMenu(VIEW_ITEM_INLINE_MENU);
|
|
703
|
-
const args = this.toContextMenuArgs(treeViewNode);
|
|
704
|
-
const inlineCommands = menu.children.filter((item): item is ActionMenuNode => item instanceof ActionMenuNode);
|
|
705
|
-
const tailDecorations = super.renderTailDecorations(treeViewNode, props);
|
|
706
|
-
return <React.Fragment>
|
|
707
|
-
{inlineCommands.length > 0 && <div className={TREE_NODE_SEGMENT_CLASS + ' flex'}>
|
|
708
|
-
{inlineCommands.map((item, index) => this.renderInlineCommand(item, index, this.focusService.hasFocus(treeViewNode), args))}
|
|
709
|
-
</div>}
|
|
710
|
-
{tailDecorations !== undefined && <div className={TREE_NODE_SEGMENT_CLASS + ' flex'}>{tailDecorations}</div>}
|
|
711
|
-
</React.Fragment>;
|
|
712
|
-
});
|
|
713
|
-
}
|
|
714
|
-
|
|
715
|
-
toTreeViewItemReference(treeNode: TreeNode): TreeViewItemReference {
|
|
716
|
-
return { viewId: this.id, itemId: treeNode.id };
|
|
717
|
-
}
|
|
718
|
-
|
|
719
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
720
|
-
protected renderInlineCommand(actionMenuNode: ActionMenuNode, index: number, tabbable: boolean, args: any[]): React.ReactNode {
|
|
721
|
-
if (!actionMenuNode.icon || !this.commands.isVisible(actionMenuNode.command, ...args) || !actionMenuNode.when || !this.contextKeys.match(actionMenuNode.when)) {
|
|
722
|
-
return false;
|
|
723
|
-
}
|
|
724
|
-
const className = [TREE_NODE_SEGMENT_CLASS, TREE_NODE_TAIL_CLASS, actionMenuNode.icon, ACTION_ITEM, 'theia-tree-view-inline-action'].join(' ');
|
|
725
|
-
const tabIndex = tabbable ? 0 : undefined;
|
|
726
|
-
return <div key={index} className={className} title={actionMenuNode.label} tabIndex={tabIndex} onClick={e => {
|
|
727
|
-
e.stopPropagation();
|
|
728
|
-
this.commands.executeCommand(actionMenuNode.command, ...args);
|
|
729
|
-
}} />;
|
|
730
|
-
}
|
|
731
|
-
|
|
732
|
-
protected override toContextMenuArgs(target: SelectableTreeNode): [TreeViewItemReference, TreeViewItemReference[]] | [TreeViewItemReference] {
|
|
733
|
-
if (this.options.multiSelect) {
|
|
734
|
-
return [this.toTreeViewItemReference(target), this.model.selectedNodes.map(node => this.toTreeViewItemReference(node))];
|
|
735
|
-
} else {
|
|
736
|
-
return [this.toTreeViewItemReference(target)];
|
|
737
|
-
}
|
|
738
|
-
}
|
|
739
|
-
|
|
740
|
-
override setFlag(flag: Widget.Flag): void {
|
|
741
|
-
super.setFlag(flag);
|
|
742
|
-
if (flag === Widget.Flag.IsVisible) {
|
|
743
|
-
this.onDidChangeVisibilityEmitter.fire(this.isVisible);
|
|
744
|
-
}
|
|
745
|
-
}
|
|
746
|
-
|
|
747
|
-
override clearFlag(flag: Widget.Flag): void {
|
|
748
|
-
super.clearFlag(flag);
|
|
749
|
-
if (flag === Widget.Flag.IsVisible) {
|
|
750
|
-
this.onDidChangeVisibilityEmitter.fire(this.isVisible);
|
|
751
|
-
}
|
|
752
|
-
}
|
|
753
|
-
|
|
754
|
-
override handleEnter(event: KeyboardEvent): void {
|
|
755
|
-
super.handleEnter(event);
|
|
756
|
-
this.tryExecuteCommand();
|
|
757
|
-
}
|
|
758
|
-
|
|
759
|
-
protected override tapNode(node?: TreeNode): void {
|
|
760
|
-
super.tapNode(node);
|
|
761
|
-
this.findCommands(node).then(commandMap => {
|
|
762
|
-
if (commandMap.size > 0) {
|
|
763
|
-
this.tryExecuteCommandMap(commandMap);
|
|
764
|
-
} else if (node && this.isExpandable(node)) {
|
|
765
|
-
this.model.toggleNodeExpansion(node);
|
|
766
|
-
}
|
|
767
|
-
});
|
|
768
|
-
}
|
|
769
|
-
|
|
770
|
-
// execute TreeItem.command if present
|
|
771
|
-
protected async tryExecuteCommand(node?: TreeNode): Promise<void> {
|
|
772
|
-
this.tryExecuteCommandMap(await this.findCommands(node));
|
|
773
|
-
}
|
|
774
|
-
|
|
775
|
-
protected tryExecuteCommandMap(commandMap: Map<string, unknown[]>): void {
|
|
776
|
-
commandMap.forEach((args, commandId) => {
|
|
777
|
-
this.commands.executeCommand(commandId, ...args);
|
|
778
|
-
});
|
|
779
|
-
}
|
|
780
|
-
|
|
781
|
-
protected async findCommands(node?: TreeNode): Promise<Map<string, unknown[]>> {
|
|
782
|
-
const commandMap = new Map<string, unknown[]>();
|
|
783
|
-
const treeNodes = (node ? [node] : this.model.selectedNodes) as TreeViewNode[];
|
|
784
|
-
if (await this.model.hasTreeItemResolve) {
|
|
785
|
-
const cancellationToken = new CancellationTokenSource().token;
|
|
786
|
-
// Resolve all resolvable nodes that don't have a command and haven't been resolved.
|
|
787
|
-
const allResolved = Promise.all(treeNodes.map(maybeNeedsResolve => {
|
|
788
|
-
if (!maybeNeedsResolve.command && maybeNeedsResolve instanceof ResolvableTreeViewNode && !maybeNeedsResolve.resolved) {
|
|
789
|
-
return maybeNeedsResolve.resolve(cancellationToken).catch(err => {
|
|
790
|
-
console.error(`Failed to resolve tree item '${maybeNeedsResolve.id}'`, err);
|
|
791
|
-
});
|
|
792
|
-
}
|
|
793
|
-
return Promise.resolve(maybeNeedsResolve);
|
|
794
|
-
}));
|
|
795
|
-
// Only need to wait but don't need the values because tree items are resolved in place.
|
|
796
|
-
await allResolved;
|
|
797
|
-
}
|
|
798
|
-
for (const treeNode of treeNodes) {
|
|
799
|
-
if (treeNode && treeNode.command) {
|
|
800
|
-
commandMap.set(treeNode.command.id, treeNode.command.arguments || []);
|
|
801
|
-
}
|
|
802
|
-
}
|
|
803
|
-
return commandMap;
|
|
804
|
-
}
|
|
805
|
-
|
|
806
|
-
private _message: string | undefined;
|
|
807
|
-
get message(): string | undefined {
|
|
808
|
-
return this._message;
|
|
809
|
-
}
|
|
810
|
-
|
|
811
|
-
set message(message: string | undefined) {
|
|
812
|
-
this._message = message;
|
|
813
|
-
this.update();
|
|
814
|
-
}
|
|
815
|
-
|
|
816
|
-
protected override render(): React.ReactNode {
|
|
817
|
-
return React.createElement('div', this.createContainerAttributes(), this.renderSearchInfo(), this.renderTree(this.model));
|
|
818
|
-
}
|
|
819
|
-
|
|
820
|
-
protected renderSearchInfo(): React.ReactNode {
|
|
821
|
-
if (this._message) {
|
|
822
|
-
return <div className='theia-TreeViewInfo'>{this._message}</div>;
|
|
823
|
-
}
|
|
824
|
-
return undefined;
|
|
825
|
-
}
|
|
826
|
-
|
|
827
|
-
override shouldShowWelcomeView(): boolean {
|
|
828
|
-
return (this.model.proxy === undefined || this.model.isTreeEmpty) && this.message === undefined;
|
|
829
|
-
}
|
|
830
|
-
|
|
831
|
-
protected override handleContextMenuEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement, MouseEvent>): void {
|
|
832
|
-
if (SelectableTreeNode.is(node)) {
|
|
833
|
-
// Keep the selection for the context menu, if the widget support multi-selection and the right click happens on an already selected node.
|
|
834
|
-
if (!this.props.multiSelect || !node.selected) {
|
|
835
|
-
const type = !!this.props.multiSelect && this.hasCtrlCmdMask(event) ? TreeSelection.SelectionType.TOGGLE : TreeSelection.SelectionType.DEFAULT;
|
|
836
|
-
this.model.addSelection({ node, type });
|
|
837
|
-
}
|
|
838
|
-
this.focusService.setFocus(node);
|
|
839
|
-
const contextMenuPath = this.props.contextMenuPath;
|
|
840
|
-
if (contextMenuPath) {
|
|
841
|
-
const { x, y } = event.nativeEvent;
|
|
842
|
-
const args = this.toContextMenuArgs(node);
|
|
843
|
-
const contextKeyService = this.contextKeyService.createOverlay([
|
|
844
|
-
['viewItem', (TreeViewNode.is(node) && node.contextValue) || undefined],
|
|
845
|
-
['view', this.options.id]
|
|
846
|
-
]);
|
|
847
|
-
setTimeout(() => this.contextMenuRenderer.render({
|
|
848
|
-
menuPath: contextMenuPath,
|
|
849
|
-
anchor: { x, y },
|
|
850
|
-
args,
|
|
851
|
-
contextKeyService,
|
|
852
|
-
onHide: () => contextKeyService.dispose(),
|
|
853
|
-
}), 10);
|
|
854
|
-
}
|
|
855
|
-
}
|
|
856
|
-
event.stopPropagation();
|
|
857
|
-
event.preventDefault();
|
|
858
|
-
}
|
|
859
|
-
}
|
|
1
|
+
// *****************************************************************************
|
|
2
|
+
// Copyright (C) 2018-2019 Red Hat, Inc. and others.
|
|
3
|
+
//
|
|
4
|
+
// This program and the accompanying materials are made available under the
|
|
5
|
+
// terms of the Eclipse Public License v. 2.0 which is available at
|
|
6
|
+
// http://www.eclipse.org/legal/epl-2.0.
|
|
7
|
+
//
|
|
8
|
+
// This Source Code may also be made available under the following Secondary
|
|
9
|
+
// Licenses when the conditions for such availability set forth in the Eclipse
|
|
10
|
+
// Public License v. 2.0 are satisfied: GNU General Public License, version 2
|
|
11
|
+
// with the GNU Classpath Exception which is available at
|
|
12
|
+
// https://www.gnu.org/software/classpath/license.html.
|
|
13
|
+
//
|
|
14
|
+
// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
|
|
15
|
+
// *****************************************************************************
|
|
16
|
+
|
|
17
|
+
import { injectable, inject, postConstruct } from '@theia/core/shared/inversify';
|
|
18
|
+
import { TreeViewsExt, TreeViewItemCollapsibleState, TreeViewItem, TreeViewItemReference, ThemeIcon, DataTransferFileDTO } from '../../../common/plugin-api-rpc';
|
|
19
|
+
import { Command } from '../../../common/plugin-api-rpc-model';
|
|
20
|
+
import {
|
|
21
|
+
TreeNode,
|
|
22
|
+
NodeProps,
|
|
23
|
+
SelectableTreeNode,
|
|
24
|
+
ExpandableTreeNode,
|
|
25
|
+
CompositeTreeNode,
|
|
26
|
+
TreeImpl,
|
|
27
|
+
TREE_NODE_SEGMENT_CLASS,
|
|
28
|
+
TREE_NODE_SEGMENT_GROW_CLASS,
|
|
29
|
+
TREE_NODE_TAIL_CLASS,
|
|
30
|
+
TreeModelImpl,
|
|
31
|
+
TreeViewWelcomeWidget,
|
|
32
|
+
TooltipAttributes,
|
|
33
|
+
TreeSelection,
|
|
34
|
+
HoverService,
|
|
35
|
+
ApplicationShell
|
|
36
|
+
} from '@theia/core/lib/browser';
|
|
37
|
+
import { MenuPath, MenuModelRegistry, ActionMenuNode } from '@theia/core/lib/common/menu';
|
|
38
|
+
import * as React from '@theia/core/shared/react';
|
|
39
|
+
import { PluginSharedStyle } from '../plugin-shared-style';
|
|
40
|
+
import { ACTION_ITEM, Widget } from '@theia/core/lib/browser/widgets/widget';
|
|
41
|
+
import { Emitter, Event } from '@theia/core/lib/common/event';
|
|
42
|
+
import { MessageService } from '@theia/core/lib/common/message-service';
|
|
43
|
+
import { View } from '../../../common/plugin-protocol';
|
|
44
|
+
import { URI } from '@theia/core/lib/common/uri';
|
|
45
|
+
import { ContextKeyService } from '@theia/core/lib/browser/context-key-service';
|
|
46
|
+
import { MarkdownString } from '@theia/core/lib/common/markdown-rendering';
|
|
47
|
+
import { LabelParser } from '@theia/core/lib/browser/label-parser';
|
|
48
|
+
import { AccessibilityInformation } from '@theia/plugin';
|
|
49
|
+
import { ColorRegistry } from '@theia/core/lib/browser/color-registry';
|
|
50
|
+
import { DecoratedTreeNode } from '@theia/core/lib/browser/tree/tree-decorator';
|
|
51
|
+
import { WidgetDecoration } from '@theia/core/lib/browser/widget-decoration';
|
|
52
|
+
import { CancellationTokenSource, CancellationToken } from '@theia/core/lib/common';
|
|
53
|
+
import { mixin } from '../../../common/types';
|
|
54
|
+
import { Deferred } from '@theia/core/lib/common/promise-util';
|
|
55
|
+
import { DnDFileContentStore } from './dnd-file-content-store';
|
|
56
|
+
|
|
57
|
+
export const TREE_NODE_HYPERLINK = 'theia-TreeNodeHyperlink';
|
|
58
|
+
export const VIEW_ITEM_CONTEXT_MENU: MenuPath = ['view-item-context-menu'];
|
|
59
|
+
export const VIEW_ITEM_INLINE_MENU: MenuPath = ['view-item-context-menu', 'inline'];
|
|
60
|
+
|
|
61
|
+
export interface SelectionEventHandler {
|
|
62
|
+
readonly node: SelectableTreeNode;
|
|
63
|
+
readonly contextSelection: boolean;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
export interface TreeViewNode extends SelectableTreeNode, DecoratedTreeNode {
|
|
67
|
+
contextValue?: string;
|
|
68
|
+
command?: Command;
|
|
69
|
+
resourceUri?: string;
|
|
70
|
+
themeIcon?: ThemeIcon;
|
|
71
|
+
tooltip?: string | MarkdownString;
|
|
72
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
73
|
+
description?: string | boolean | any;
|
|
74
|
+
accessibilityInformation?: AccessibilityInformation;
|
|
75
|
+
}
|
|
76
|
+
export namespace TreeViewNode {
|
|
77
|
+
export function is(arg: TreeNode | undefined): arg is TreeViewNode {
|
|
78
|
+
return !!arg && SelectableTreeNode.is(arg) && DecoratedTreeNode.is(arg);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export class ResolvableTreeViewNode implements TreeViewNode {
|
|
83
|
+
contextValue?: string;
|
|
84
|
+
command?: Command;
|
|
85
|
+
resourceUri?: string;
|
|
86
|
+
themeIcon?: ThemeIcon;
|
|
87
|
+
tooltip?: string | MarkdownString;
|
|
88
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
89
|
+
description?: string | boolean | any;
|
|
90
|
+
accessibilityInformation?: AccessibilityInformation;
|
|
91
|
+
selected: boolean;
|
|
92
|
+
focus?: boolean;
|
|
93
|
+
id: string;
|
|
94
|
+
name?: string;
|
|
95
|
+
icon?: string;
|
|
96
|
+
visible?: boolean;
|
|
97
|
+
parent: Readonly<CompositeTreeNode>;
|
|
98
|
+
previousSibling?: TreeNode;
|
|
99
|
+
nextSibling?: TreeNode;
|
|
100
|
+
busy?: number;
|
|
101
|
+
decorationData: WidgetDecoration.Data;
|
|
102
|
+
|
|
103
|
+
resolve: ((token: CancellationToken) => Promise<void>);
|
|
104
|
+
|
|
105
|
+
private _resolved = false;
|
|
106
|
+
private resolving: Deferred<void> | undefined;
|
|
107
|
+
|
|
108
|
+
constructor(treeViewNode: Partial<TreeViewNode>, resolve: (token: CancellationToken) => Promise<TreeViewItem | undefined>) {
|
|
109
|
+
mixin(this, treeViewNode);
|
|
110
|
+
this.resolve = async (token: CancellationToken) => {
|
|
111
|
+
if (this.resolving) {
|
|
112
|
+
return this.resolving.promise;
|
|
113
|
+
}
|
|
114
|
+
if (!this._resolved) {
|
|
115
|
+
this.resolving = new Deferred();
|
|
116
|
+
const resolvedTreeItem = await resolve(token);
|
|
117
|
+
if (resolvedTreeItem) {
|
|
118
|
+
this.command = this.command ?? resolvedTreeItem.command;
|
|
119
|
+
this.tooltip = this.tooltip ?? resolvedTreeItem.tooltip;
|
|
120
|
+
}
|
|
121
|
+
this.resolving.resolve();
|
|
122
|
+
this.resolving = undefined;
|
|
123
|
+
}
|
|
124
|
+
if (!token.isCancellationRequested) {
|
|
125
|
+
this._resolved = true;
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
reset(): void {
|
|
131
|
+
this._resolved = false;
|
|
132
|
+
this.resolving = undefined;
|
|
133
|
+
this.command = undefined;
|
|
134
|
+
this.tooltip = undefined;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
get resolved(): boolean {
|
|
138
|
+
return this._resolved;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
export class ResolvableCompositeTreeViewNode extends ResolvableTreeViewNode implements CompositeTreeViewNode {
|
|
143
|
+
expanded: boolean;
|
|
144
|
+
children: readonly TreeNode[];
|
|
145
|
+
constructor(
|
|
146
|
+
treeViewNode: Pick<CompositeTreeViewNode, 'children' | 'expanded'> & Partial<TreeViewNode>,
|
|
147
|
+
resolve: (token: CancellationToken) => Promise<TreeViewItem | undefined>) {
|
|
148
|
+
super(treeViewNode, resolve);
|
|
149
|
+
this.expanded = treeViewNode.expanded;
|
|
150
|
+
this.children = treeViewNode.children;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
export interface CompositeTreeViewNode extends TreeViewNode, ExpandableTreeNode, CompositeTreeNode {
|
|
155
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
156
|
+
description?: string | boolean | any;
|
|
157
|
+
}
|
|
158
|
+
export namespace CompositeTreeViewNode {
|
|
159
|
+
export function is(arg: TreeNode | undefined): arg is CompositeTreeViewNode {
|
|
160
|
+
return TreeViewNode.is(arg) && ExpandableTreeNode.is(arg) && CompositeTreeNode.is(arg);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
@injectable()
|
|
165
|
+
export class TreeViewWidgetOptions {
|
|
166
|
+
id: string;
|
|
167
|
+
multiSelect: boolean | undefined;
|
|
168
|
+
dragMimeTypes: string[] | undefined;
|
|
169
|
+
dropMimeTypes: string[] | undefined;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
@injectable()
|
|
173
|
+
export class PluginTree extends TreeImpl {
|
|
174
|
+
|
|
175
|
+
@inject(PluginSharedStyle)
|
|
176
|
+
protected readonly sharedStyle: PluginSharedStyle;
|
|
177
|
+
|
|
178
|
+
@inject(TreeViewWidgetOptions)
|
|
179
|
+
protected readonly options: TreeViewWidgetOptions;
|
|
180
|
+
|
|
181
|
+
@inject(MessageService)
|
|
182
|
+
protected readonly notification: MessageService;
|
|
183
|
+
|
|
184
|
+
protected readonly onDidChangeWelcomeStateEmitter: Emitter<void> = new Emitter<void>();
|
|
185
|
+
readonly onDidChangeWelcomeState = this.onDidChangeWelcomeStateEmitter.event;
|
|
186
|
+
|
|
187
|
+
private _proxy: TreeViewsExt | undefined;
|
|
188
|
+
private _viewInfo: View | undefined;
|
|
189
|
+
private _isEmpty: boolean;
|
|
190
|
+
private _hasTreeItemResolve: Promise<boolean> = Promise.resolve(false);
|
|
191
|
+
|
|
192
|
+
set proxy(proxy: TreeViewsExt | undefined) {
|
|
193
|
+
this._proxy = proxy;
|
|
194
|
+
if (proxy) {
|
|
195
|
+
this._hasTreeItemResolve = proxy.$hasResolveTreeItem(this.options.id);
|
|
196
|
+
} else {
|
|
197
|
+
this._hasTreeItemResolve = Promise.resolve(false);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
get proxy(): TreeViewsExt | undefined {
|
|
201
|
+
return this._proxy;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
get hasTreeItemResolve(): Promise<boolean> {
|
|
205
|
+
return this._hasTreeItemResolve;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
set viewInfo(viewInfo: View) {
|
|
209
|
+
this._viewInfo = viewInfo;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
get isEmpty(): boolean {
|
|
213
|
+
return this._isEmpty;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
protected override async resolveChildren(parent: CompositeTreeNode): Promise<TreeNode[]> {
|
|
217
|
+
if (!this._proxy) {
|
|
218
|
+
return super.resolveChildren(parent);
|
|
219
|
+
}
|
|
220
|
+
const children = await this.fetchChildren(this._proxy, parent);
|
|
221
|
+
const hasResolve = await this.hasTreeItemResolve;
|
|
222
|
+
return children.map(value => hasResolve ? this.createResolvableTreeNode(value, parent) : this.createTreeNode(value, parent));
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
protected async fetchChildren(proxy: TreeViewsExt, parent: CompositeTreeNode): Promise<TreeViewItem[]> {
|
|
226
|
+
try {
|
|
227
|
+
const children = await proxy.$getChildren(this.options.id, parent.id);
|
|
228
|
+
const oldEmpty = this._isEmpty;
|
|
229
|
+
this._isEmpty = !parent.id && (!children || children.length === 0);
|
|
230
|
+
if (oldEmpty !== this._isEmpty) {
|
|
231
|
+
this.onDidChangeWelcomeStateEmitter.fire();
|
|
232
|
+
}
|
|
233
|
+
return children || [];
|
|
234
|
+
} catch (e) {
|
|
235
|
+
if (e) {
|
|
236
|
+
console.error(`Failed to fetch children for '${this.options.id}'`, e);
|
|
237
|
+
const label = this._viewInfo ? this._viewInfo.name : this.options.id;
|
|
238
|
+
this.notification.error(`${label}: ${e.message}`);
|
|
239
|
+
}
|
|
240
|
+
return [];
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
protected createTreeNode(item: TreeViewItem, parent: CompositeTreeNode): TreeNode {
|
|
245
|
+
const update: Partial<TreeViewNode> = this.createTreeNodeUpdate(item);
|
|
246
|
+
const node = this.getNode(item.id);
|
|
247
|
+
if (item.collapsibleState !== undefined && item.collapsibleState !== TreeViewItemCollapsibleState.None) {
|
|
248
|
+
if (CompositeTreeViewNode.is(node)) {
|
|
249
|
+
return Object.assign(node, update);
|
|
250
|
+
}
|
|
251
|
+
return Object.assign({
|
|
252
|
+
id: item.id,
|
|
253
|
+
parent,
|
|
254
|
+
visible: true,
|
|
255
|
+
selected: false,
|
|
256
|
+
expanded: TreeViewItemCollapsibleState.Expanded === item.collapsibleState,
|
|
257
|
+
children: [],
|
|
258
|
+
command: item.command
|
|
259
|
+
}, update);
|
|
260
|
+
}
|
|
261
|
+
if (TreeViewNode.is(node) && !ExpandableTreeNode.is(node)) {
|
|
262
|
+
return Object.assign(node, update, { command: item.command });
|
|
263
|
+
}
|
|
264
|
+
return Object.assign({
|
|
265
|
+
id: item.id,
|
|
266
|
+
parent,
|
|
267
|
+
visible: true,
|
|
268
|
+
selected: false,
|
|
269
|
+
command: item.command,
|
|
270
|
+
}, update);
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
/** Creates a resolvable tree node. If a node already exists, reset it because the underlying TreeViewItem might have been disposed in the backend. */
|
|
274
|
+
protected createResolvableTreeNode(item: TreeViewItem, parent: CompositeTreeNode): TreeNode {
|
|
275
|
+
const update: Partial<TreeViewNode> = this.createTreeNodeUpdate(item);
|
|
276
|
+
const node = this.getNode(item.id);
|
|
277
|
+
|
|
278
|
+
// Node is a composite node that might contain children
|
|
279
|
+
if (item.collapsibleState !== undefined && item.collapsibleState !== TreeViewItemCollapsibleState.None) {
|
|
280
|
+
// Reuse existing composite node and reset it
|
|
281
|
+
if (node instanceof ResolvableCompositeTreeViewNode) {
|
|
282
|
+
node.reset();
|
|
283
|
+
return Object.assign(node, update);
|
|
284
|
+
}
|
|
285
|
+
// Create new composite node
|
|
286
|
+
const compositeNode = Object.assign({
|
|
287
|
+
id: item.id,
|
|
288
|
+
parent,
|
|
289
|
+
visible: true,
|
|
290
|
+
selected: false,
|
|
291
|
+
expanded: TreeViewItemCollapsibleState.Expanded === item.collapsibleState,
|
|
292
|
+
children: [],
|
|
293
|
+
command: item.command
|
|
294
|
+
}, update);
|
|
295
|
+
return new ResolvableCompositeTreeViewNode(compositeNode, async (token: CancellationToken) => this._proxy?.$resolveTreeItem(this.options.id, item.id, token));
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
// Node is a leaf
|
|
299
|
+
// Reuse existing node and reset it.
|
|
300
|
+
if (node instanceof ResolvableTreeViewNode && !ExpandableTreeNode.is(node)) {
|
|
301
|
+
node.reset();
|
|
302
|
+
return Object.assign(node, update);
|
|
303
|
+
}
|
|
304
|
+
const treeNode = Object.assign({
|
|
305
|
+
id: item.id,
|
|
306
|
+
parent,
|
|
307
|
+
visible: true,
|
|
308
|
+
selected: false,
|
|
309
|
+
command: item.command,
|
|
310
|
+
}, update);
|
|
311
|
+
return new ResolvableTreeViewNode(treeNode, async (token: CancellationToken) => this._proxy?.$resolveTreeItem(this.options.id, item.id, token));
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
protected createTreeNodeUpdate(item: TreeViewItem): Partial<TreeViewNode> {
|
|
315
|
+
const decorationData = this.toDecorationData(item);
|
|
316
|
+
const icon = this.toIconClass(item);
|
|
317
|
+
const resourceUri = item.resourceUri && URI.fromComponents(item.resourceUri).toString();
|
|
318
|
+
const themeIcon = item.themeIcon ? item.themeIcon : item.collapsibleState !== TreeViewItemCollapsibleState.None ? { id: 'folder' } : undefined;
|
|
319
|
+
return {
|
|
320
|
+
name: item.label,
|
|
321
|
+
decorationData,
|
|
322
|
+
icon,
|
|
323
|
+
description: item.description,
|
|
324
|
+
themeIcon,
|
|
325
|
+
resourceUri,
|
|
326
|
+
tooltip: item.tooltip,
|
|
327
|
+
contextValue: item.contextValue,
|
|
328
|
+
command: item.command,
|
|
329
|
+
accessibilityInformation: item.accessibilityInformation,
|
|
330
|
+
};
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
protected toDecorationData(item: TreeViewItem): WidgetDecoration.Data {
|
|
334
|
+
let decoration: WidgetDecoration.Data = {};
|
|
335
|
+
if (item.highlights) {
|
|
336
|
+
const highlight = {
|
|
337
|
+
ranges: item.highlights.map(h => ({ offset: h[0], length: h[1] - h[0] }))
|
|
338
|
+
};
|
|
339
|
+
decoration = { highlight };
|
|
340
|
+
}
|
|
341
|
+
return decoration;
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
protected toIconClass(item: TreeViewItem): string | undefined {
|
|
345
|
+
if (item.icon) {
|
|
346
|
+
return 'fa ' + item.icon;
|
|
347
|
+
}
|
|
348
|
+
if (item.iconUrl) {
|
|
349
|
+
const reference = this.sharedStyle.toIconClass(item.iconUrl);
|
|
350
|
+
this.toDispose.push(reference);
|
|
351
|
+
return reference.object.iconClass;
|
|
352
|
+
}
|
|
353
|
+
return undefined;
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
@injectable()
|
|
359
|
+
export class PluginTreeModel extends TreeModelImpl {
|
|
360
|
+
|
|
361
|
+
@inject(PluginTree)
|
|
362
|
+
protected override readonly tree: PluginTree;
|
|
363
|
+
|
|
364
|
+
set proxy(proxy: TreeViewsExt | undefined) {
|
|
365
|
+
this.tree.proxy = proxy;
|
|
366
|
+
}
|
|
367
|
+
get proxy(): TreeViewsExt | undefined {
|
|
368
|
+
return this.tree.proxy;
|
|
369
|
+
}
|
|
370
|
+
|
|
371
|
+
get hasTreeItemResolve(): Promise<boolean> {
|
|
372
|
+
return this.tree.hasTreeItemResolve;
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
set viewInfo(viewInfo: View) {
|
|
376
|
+
this.tree.viewInfo = viewInfo;
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
get isTreeEmpty(): boolean {
|
|
380
|
+
return this.tree.isEmpty;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
get onDidChangeWelcomeState(): Event<void> {
|
|
384
|
+
return this.tree.onDidChangeWelcomeState;
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
override doOpenNode(node: TreeNode): void {
|
|
388
|
+
super.doOpenNode(node);
|
|
389
|
+
if (node instanceof ResolvableTreeViewNode) {
|
|
390
|
+
node.resolve(CancellationToken.None);
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
@injectable()
|
|
396
|
+
export class TreeViewWidget extends TreeViewWelcomeWidget {
|
|
397
|
+
|
|
398
|
+
protected _contextSelection = false;
|
|
399
|
+
|
|
400
|
+
@inject(ApplicationShell)
|
|
401
|
+
protected readonly applicationShell: ApplicationShell;
|
|
402
|
+
|
|
403
|
+
@inject(MenuModelRegistry)
|
|
404
|
+
protected readonly menus: MenuModelRegistry;
|
|
405
|
+
|
|
406
|
+
@inject(ContextKeyService)
|
|
407
|
+
protected readonly contextKeys: ContextKeyService;
|
|
408
|
+
|
|
409
|
+
@inject(TreeViewWidgetOptions)
|
|
410
|
+
readonly options: TreeViewWidgetOptions;
|
|
411
|
+
|
|
412
|
+
@inject(PluginTreeModel)
|
|
413
|
+
override readonly model: PluginTreeModel;
|
|
414
|
+
|
|
415
|
+
@inject(ContextKeyService)
|
|
416
|
+
protected readonly contextKeyService: ContextKeyService;
|
|
417
|
+
|
|
418
|
+
@inject(HoverService)
|
|
419
|
+
protected readonly hoverService: HoverService;
|
|
420
|
+
|
|
421
|
+
@inject(LabelParser)
|
|
422
|
+
protected readonly labelParser: LabelParser;
|
|
423
|
+
|
|
424
|
+
@inject(ColorRegistry)
|
|
425
|
+
protected readonly colorRegistry: ColorRegistry;
|
|
426
|
+
|
|
427
|
+
@inject(DnDFileContentStore)
|
|
428
|
+
protected readonly dndFileContentStore: DnDFileContentStore;
|
|
429
|
+
|
|
430
|
+
protected treeDragType: string;
|
|
431
|
+
protected readonly expansionTimeouts: Map<string, number> = new Map();
|
|
432
|
+
|
|
433
|
+
@postConstruct()
|
|
434
|
+
protected override init(): void {
|
|
435
|
+
super.init();
|
|
436
|
+
this.id = this.options.id;
|
|
437
|
+
this.addClass('theia-tree-view');
|
|
438
|
+
this.node.style.height = '100%';
|
|
439
|
+
this.model.onDidChangeWelcomeState(this.update, this);
|
|
440
|
+
this.toDispose.push(this.model.onDidChangeWelcomeState(this.update, this));
|
|
441
|
+
this.toDispose.push(this.onDidChangeVisibilityEmitter);
|
|
442
|
+
this.toDispose.push(this.contextKeyService.onDidChange(() => this.update()));
|
|
443
|
+
this.treeDragType = `application/vnd.code.tree.${this.id.toLowerCase()}`;
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
protected override renderIcon(node: TreeNode, props: NodeProps): React.ReactNode {
|
|
447
|
+
const icon = this.toNodeIcon(node);
|
|
448
|
+
if (icon) {
|
|
449
|
+
let style: React.CSSProperties | undefined;
|
|
450
|
+
if (TreeViewNode.is(node) && node.themeIcon?.color) {
|
|
451
|
+
const color = this.colorRegistry.getCurrentColor(node.themeIcon.color.id);
|
|
452
|
+
if (color) {
|
|
453
|
+
style = { color };
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
return <div className={icon + ' theia-tree-view-icon'} style={style}></div>;
|
|
457
|
+
}
|
|
458
|
+
return undefined;
|
|
459
|
+
}
|
|
460
|
+
|
|
461
|
+
protected override renderCaption(node: TreeViewNode, props: NodeProps): React.ReactNode {
|
|
462
|
+
const classes = [TREE_NODE_SEGMENT_CLASS];
|
|
463
|
+
if (!this.hasTrailingSuffixes(node)) {
|
|
464
|
+
classes.push(TREE_NODE_SEGMENT_GROW_CLASS);
|
|
465
|
+
}
|
|
466
|
+
const className = classes.join(' ');
|
|
467
|
+
|
|
468
|
+
let attrs: React.HTMLAttributes<HTMLElement> & Partial<TooltipAttributes> = {
|
|
469
|
+
...this.decorateCaption(node, {}),
|
|
470
|
+
className,
|
|
471
|
+
id: node.id
|
|
472
|
+
};
|
|
473
|
+
|
|
474
|
+
if (node.accessibilityInformation) {
|
|
475
|
+
attrs = {
|
|
476
|
+
...attrs,
|
|
477
|
+
'aria-label': node.accessibilityInformation.label,
|
|
478
|
+
'role': node.accessibilityInformation.role
|
|
479
|
+
};
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
if (!node.tooltip && node instanceof ResolvableTreeViewNode) {
|
|
483
|
+
let configuredTip = false;
|
|
484
|
+
let source: CancellationTokenSource | undefined;
|
|
485
|
+
attrs = {
|
|
486
|
+
...attrs,
|
|
487
|
+
onMouseLeave: () => source?.cancel(),
|
|
488
|
+
onMouseEnter: async event => {
|
|
489
|
+
if (configuredTip) {
|
|
490
|
+
if (MarkdownString.is(node.tooltip)) {
|
|
491
|
+
this.hoverService.requestHover({
|
|
492
|
+
content: node.tooltip,
|
|
493
|
+
target: event.target as HTMLElement,
|
|
494
|
+
position: 'right'
|
|
495
|
+
});
|
|
496
|
+
}
|
|
497
|
+
return;
|
|
498
|
+
}
|
|
499
|
+
if (!node.resolved) {
|
|
500
|
+
source = new CancellationTokenSource();
|
|
501
|
+
const token = source.token;
|
|
502
|
+
await node.resolve(token);
|
|
503
|
+
if (token.isCancellationRequested) {
|
|
504
|
+
return;
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
if (MarkdownString.is(node.tooltip)) {
|
|
508
|
+
this.hoverService.requestHover({
|
|
509
|
+
content: node.tooltip,
|
|
510
|
+
target: event.target as HTMLElement,
|
|
511
|
+
position: 'right'
|
|
512
|
+
});
|
|
513
|
+
} else {
|
|
514
|
+
const title = node.tooltip ||
|
|
515
|
+
(node.resourceUri && this.labelProvider.getLongName(new URI(node.resourceUri)))
|
|
516
|
+
|| this.toNodeName(node);
|
|
517
|
+
event.currentTarget.title = title;
|
|
518
|
+
}
|
|
519
|
+
configuredTip = true;
|
|
520
|
+
}
|
|
521
|
+
};
|
|
522
|
+
} else if (MarkdownString.is(node.tooltip)) {
|
|
523
|
+
attrs = {
|
|
524
|
+
...attrs,
|
|
525
|
+
onMouseEnter: event => {
|
|
526
|
+
this.hoverService.requestHover({
|
|
527
|
+
content: node.tooltip!,
|
|
528
|
+
target: event.target as HTMLElement,
|
|
529
|
+
position: 'right'
|
|
530
|
+
});
|
|
531
|
+
}
|
|
532
|
+
};
|
|
533
|
+
} else {
|
|
534
|
+
const title = node.tooltip ||
|
|
535
|
+
(node.resourceUri && this.labelProvider.getLongName(new URI(node.resourceUri)))
|
|
536
|
+
|| this.toNodeName(node);
|
|
537
|
+
|
|
538
|
+
attrs = {
|
|
539
|
+
...attrs,
|
|
540
|
+
title
|
|
541
|
+
};
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
const children: React.ReactNode[] = [];
|
|
545
|
+
const caption = this.toNodeName(node);
|
|
546
|
+
const highlight = this.getDecorationData(node, 'highlight')[0];
|
|
547
|
+
if (highlight) {
|
|
548
|
+
children.push(this.toReactNode(caption, highlight));
|
|
549
|
+
}
|
|
550
|
+
const searchHighlight = this.searchHighlights && this.searchHighlights.get(node.id);
|
|
551
|
+
if (searchHighlight) {
|
|
552
|
+
children.push(...this.toReactNode(caption, searchHighlight));
|
|
553
|
+
} else if (!highlight) {
|
|
554
|
+
children.push(caption);
|
|
555
|
+
}
|
|
556
|
+
const description = this.toNodeDescription(node);
|
|
557
|
+
if (description) {
|
|
558
|
+
children.push(<span className='theia-tree-view-description'>{description}</span>);
|
|
559
|
+
}
|
|
560
|
+
return <div {...attrs}>{...children}</div>;
|
|
561
|
+
}
|
|
562
|
+
|
|
563
|
+
protected override createNodeAttributes(node: TreeViewNode, props: NodeProps): React.Attributes & React.HTMLAttributes<HTMLElement> {
|
|
564
|
+
const attrs = super.createNodeAttributes(node, props);
|
|
565
|
+
|
|
566
|
+
if (this.options.dragMimeTypes) {
|
|
567
|
+
attrs.onDragStart = event => this.handleDragStartEvent(node, event);
|
|
568
|
+
attrs.onDragEnd = event => this.handleDragEnd(node, event);
|
|
569
|
+
attrs.draggable = true;
|
|
570
|
+
}
|
|
571
|
+
|
|
572
|
+
if (this.options.dropMimeTypes) {
|
|
573
|
+
attrs.onDrop = event => this.handleDropEvent(node, event);
|
|
574
|
+
attrs.onDragEnter = event => this.handleDragEnter(node, event);
|
|
575
|
+
attrs.onDragLeave = event => this.handleDragLeave(node, event);
|
|
576
|
+
attrs.onDragOver = event => this.handleDragOver(event);
|
|
577
|
+
}
|
|
578
|
+
|
|
579
|
+
return attrs;
|
|
580
|
+
}
|
|
581
|
+
handleDragLeave(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
582
|
+
const timeout = this.expansionTimeouts.get(node.id);
|
|
583
|
+
if (typeof timeout !== 'undefined') {
|
|
584
|
+
console.debug(`dragleave ${node.id} canceling timeout`);
|
|
585
|
+
clearTimeout(timeout);
|
|
586
|
+
this.expansionTimeouts.delete(node.id);
|
|
587
|
+
}
|
|
588
|
+
}
|
|
589
|
+
handleDragEnter(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
590
|
+
console.debug(`dragenter ${node.id}`);
|
|
591
|
+
if (ExpandableTreeNode.is(node)) {
|
|
592
|
+
console.debug(`dragenter ${node.id} starting timeout`);
|
|
593
|
+
this.expansionTimeouts.set(node.id, window.setTimeout(() => {
|
|
594
|
+
console.debug(`dragenter ${node.id} timeout reached`);
|
|
595
|
+
this.model.expandNode(node);
|
|
596
|
+
}, 500));
|
|
597
|
+
}
|
|
598
|
+
}
|
|
599
|
+
|
|
600
|
+
protected override createContainerAttributes(): React.HTMLAttributes<HTMLElement> {
|
|
601
|
+
const attrs = super.createContainerAttributes();
|
|
602
|
+
if (this.options.dropMimeTypes) {
|
|
603
|
+
attrs.onDrop = event => this.handleDropEvent(undefined, event);
|
|
604
|
+
attrs.onDragOver = event => this.handleDragOver(event);
|
|
605
|
+
}
|
|
606
|
+
return attrs;
|
|
607
|
+
}
|
|
608
|
+
|
|
609
|
+
protected handleDragStartEvent(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
610
|
+
event.dataTransfer!.setData(this.treeDragType, '');
|
|
611
|
+
let selectedNodes: TreeViewNode[] = [];
|
|
612
|
+
if (this.model.selectedNodes.find(selected => TreeNode.equals(selected, node))) {
|
|
613
|
+
selectedNodes = this.model.selectedNodes.filter(TreeViewNode.is);
|
|
614
|
+
} else {
|
|
615
|
+
selectedNodes = [node];
|
|
616
|
+
}
|
|
617
|
+
|
|
618
|
+
this.options.dragMimeTypes!.forEach(type => {
|
|
619
|
+
if (type === 'text/uri-list') {
|
|
620
|
+
ApplicationShell.setDraggedEditorUris(event.dataTransfer, selectedNodes.filter(n => n.resourceUri).map(n => new URI(n.resourceUri)));
|
|
621
|
+
} else {
|
|
622
|
+
event.dataTransfer.setData(type, '');
|
|
623
|
+
}
|
|
624
|
+
});
|
|
625
|
+
|
|
626
|
+
this.model.proxy!.$dragStarted(this.options.id, selectedNodes.map(selected => selected.id), CancellationToken.None).then(maybeUris => {
|
|
627
|
+
if (maybeUris) {
|
|
628
|
+
this.applicationShell.addAdditionalDraggedEditorUris(maybeUris.map(URI.fromComponents));
|
|
629
|
+
}
|
|
630
|
+
});
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
handleDragEnd(node: TreeViewNode, event: React.DragEvent<HTMLElement>): void {
|
|
634
|
+
this.applicationShell.clearAdditionalDraggedEditorUris();
|
|
635
|
+
}
|
|
636
|
+
|
|
637
|
+
handleDragOver(event: React.DragEvent<HTMLElement>): void {
|
|
638
|
+
if (event.dataTransfer) {
|
|
639
|
+
const canDrop = event.dataTransfer.types.some(type => this.options.dropMimeTypes!.includes(type)) ||
|
|
640
|
+
event.dataTransfer.types.includes(this.treeDragType) ||
|
|
641
|
+
this.options.dropMimeTypes!.includes('files') && event.dataTransfer.files.length > 0;
|
|
642
|
+
if (canDrop) {
|
|
643
|
+
event.preventDefault();
|
|
644
|
+
event.dataTransfer.dropEffect = 'move';
|
|
645
|
+
} else {
|
|
646
|
+
event.dataTransfer.dropEffect = 'none';
|
|
647
|
+
}
|
|
648
|
+
event.stopPropagation();
|
|
649
|
+
}
|
|
650
|
+
}
|
|
651
|
+
|
|
652
|
+
protected handleDropEvent(node: TreeViewNode | undefined, event: React.DragEvent<HTMLElement>): void {
|
|
653
|
+
if (event.dataTransfer) {
|
|
654
|
+
const items: [string, string | DataTransferFileDTO][] = [];
|
|
655
|
+
let files: string[] = [];
|
|
656
|
+
try {
|
|
657
|
+
for (let i = 0; i < event.dataTransfer.items.length; i++) {
|
|
658
|
+
const transferItem = event.dataTransfer.items[i];
|
|
659
|
+
if (transferItem.type !== this.treeDragType) {
|
|
660
|
+
// do not pass the artificial drag data to the extension
|
|
661
|
+
const f = event.dataTransfer.items[i].getAsFile();
|
|
662
|
+
if (f) {
|
|
663
|
+
const fileId = this.dndFileContentStore.addFile(f);
|
|
664
|
+
files.push(fileId);
|
|
665
|
+
const uri = f.path ? {
|
|
666
|
+
scheme: 'file',
|
|
667
|
+
path: f.path,
|
|
668
|
+
authority: '',
|
|
669
|
+
query: '',
|
|
670
|
+
fragment: ''
|
|
671
|
+
} : undefined;
|
|
672
|
+
items.push([transferItem.type, new DataTransferFileDTO(f.name, fileId, uri)]);
|
|
673
|
+
} else {
|
|
674
|
+
const textData = event.dataTransfer.getData(transferItem.type);
|
|
675
|
+
if (textData) {
|
|
676
|
+
items.push([transferItem.type, textData]);
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
if (items.length > 0 || event.dataTransfer.types.includes(this.treeDragType)) {
|
|
682
|
+
event.preventDefault();
|
|
683
|
+
event.stopPropagation();
|
|
684
|
+
this.model.proxy?.$drop(this.id, node?.id, items, CancellationToken.None).finally(() => {
|
|
685
|
+
for (const file of files) {
|
|
686
|
+
this.dndFileContentStore.removeFile(file);
|
|
687
|
+
}
|
|
688
|
+
});
|
|
689
|
+
files = [];
|
|
690
|
+
}
|
|
691
|
+
} catch (e) {
|
|
692
|
+
for (const file of files) {
|
|
693
|
+
this.dndFileContentStore.removeFile(file);
|
|
694
|
+
}
|
|
695
|
+
throw e;
|
|
696
|
+
}
|
|
697
|
+
}
|
|
698
|
+
}
|
|
699
|
+
|
|
700
|
+
protected override renderTailDecorations(treeViewNode: TreeViewNode, props: NodeProps): React.ReactNode {
|
|
701
|
+
return this.contextKeys.with({ view: this.id, viewItem: treeViewNode.contextValue }, () => {
|
|
702
|
+
const menu = this.menus.getMenu(VIEW_ITEM_INLINE_MENU);
|
|
703
|
+
const args = this.toContextMenuArgs(treeViewNode);
|
|
704
|
+
const inlineCommands = menu.children.filter((item): item is ActionMenuNode => item instanceof ActionMenuNode);
|
|
705
|
+
const tailDecorations = super.renderTailDecorations(treeViewNode, props);
|
|
706
|
+
return <React.Fragment>
|
|
707
|
+
{inlineCommands.length > 0 && <div className={TREE_NODE_SEGMENT_CLASS + ' flex'}>
|
|
708
|
+
{inlineCommands.map((item, index) => this.renderInlineCommand(item, index, this.focusService.hasFocus(treeViewNode), args))}
|
|
709
|
+
</div>}
|
|
710
|
+
{tailDecorations !== undefined && <div className={TREE_NODE_SEGMENT_CLASS + ' flex'}>{tailDecorations}</div>}
|
|
711
|
+
</React.Fragment>;
|
|
712
|
+
});
|
|
713
|
+
}
|
|
714
|
+
|
|
715
|
+
toTreeViewItemReference(treeNode: TreeNode): TreeViewItemReference {
|
|
716
|
+
return { viewId: this.id, itemId: treeNode.id };
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
720
|
+
protected renderInlineCommand(actionMenuNode: ActionMenuNode, index: number, tabbable: boolean, args: any[]): React.ReactNode {
|
|
721
|
+
if (!actionMenuNode.icon || !this.commands.isVisible(actionMenuNode.command, ...args) || !actionMenuNode.when || !this.contextKeys.match(actionMenuNode.when)) {
|
|
722
|
+
return false;
|
|
723
|
+
}
|
|
724
|
+
const className = [TREE_NODE_SEGMENT_CLASS, TREE_NODE_TAIL_CLASS, actionMenuNode.icon, ACTION_ITEM, 'theia-tree-view-inline-action'].join(' ');
|
|
725
|
+
const tabIndex = tabbable ? 0 : undefined;
|
|
726
|
+
return <div key={index} className={className} title={actionMenuNode.label} tabIndex={tabIndex} onClick={e => {
|
|
727
|
+
e.stopPropagation();
|
|
728
|
+
this.commands.executeCommand(actionMenuNode.command, ...args);
|
|
729
|
+
}} />;
|
|
730
|
+
}
|
|
731
|
+
|
|
732
|
+
protected override toContextMenuArgs(target: SelectableTreeNode): [TreeViewItemReference, TreeViewItemReference[]] | [TreeViewItemReference] {
|
|
733
|
+
if (this.options.multiSelect) {
|
|
734
|
+
return [this.toTreeViewItemReference(target), this.model.selectedNodes.map(node => this.toTreeViewItemReference(node))];
|
|
735
|
+
} else {
|
|
736
|
+
return [this.toTreeViewItemReference(target)];
|
|
737
|
+
}
|
|
738
|
+
}
|
|
739
|
+
|
|
740
|
+
override setFlag(flag: Widget.Flag): void {
|
|
741
|
+
super.setFlag(flag);
|
|
742
|
+
if (flag === Widget.Flag.IsVisible) {
|
|
743
|
+
this.onDidChangeVisibilityEmitter.fire(this.isVisible);
|
|
744
|
+
}
|
|
745
|
+
}
|
|
746
|
+
|
|
747
|
+
override clearFlag(flag: Widget.Flag): void {
|
|
748
|
+
super.clearFlag(flag);
|
|
749
|
+
if (flag === Widget.Flag.IsVisible) {
|
|
750
|
+
this.onDidChangeVisibilityEmitter.fire(this.isVisible);
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
|
|
754
|
+
override handleEnter(event: KeyboardEvent): void {
|
|
755
|
+
super.handleEnter(event);
|
|
756
|
+
this.tryExecuteCommand();
|
|
757
|
+
}
|
|
758
|
+
|
|
759
|
+
protected override tapNode(node?: TreeNode): void {
|
|
760
|
+
super.tapNode(node);
|
|
761
|
+
this.findCommands(node).then(commandMap => {
|
|
762
|
+
if (commandMap.size > 0) {
|
|
763
|
+
this.tryExecuteCommandMap(commandMap);
|
|
764
|
+
} else if (node && this.isExpandable(node)) {
|
|
765
|
+
this.model.toggleNodeExpansion(node);
|
|
766
|
+
}
|
|
767
|
+
});
|
|
768
|
+
}
|
|
769
|
+
|
|
770
|
+
// execute TreeItem.command if present
|
|
771
|
+
protected async tryExecuteCommand(node?: TreeNode): Promise<void> {
|
|
772
|
+
this.tryExecuteCommandMap(await this.findCommands(node));
|
|
773
|
+
}
|
|
774
|
+
|
|
775
|
+
protected tryExecuteCommandMap(commandMap: Map<string, unknown[]>): void {
|
|
776
|
+
commandMap.forEach((args, commandId) => {
|
|
777
|
+
this.commands.executeCommand(commandId, ...args);
|
|
778
|
+
});
|
|
779
|
+
}
|
|
780
|
+
|
|
781
|
+
protected async findCommands(node?: TreeNode): Promise<Map<string, unknown[]>> {
|
|
782
|
+
const commandMap = new Map<string, unknown[]>();
|
|
783
|
+
const treeNodes = (node ? [node] : this.model.selectedNodes) as TreeViewNode[];
|
|
784
|
+
if (await this.model.hasTreeItemResolve) {
|
|
785
|
+
const cancellationToken = new CancellationTokenSource().token;
|
|
786
|
+
// Resolve all resolvable nodes that don't have a command and haven't been resolved.
|
|
787
|
+
const allResolved = Promise.all(treeNodes.map(maybeNeedsResolve => {
|
|
788
|
+
if (!maybeNeedsResolve.command && maybeNeedsResolve instanceof ResolvableTreeViewNode && !maybeNeedsResolve.resolved) {
|
|
789
|
+
return maybeNeedsResolve.resolve(cancellationToken).catch(err => {
|
|
790
|
+
console.error(`Failed to resolve tree item '${maybeNeedsResolve.id}'`, err);
|
|
791
|
+
});
|
|
792
|
+
}
|
|
793
|
+
return Promise.resolve(maybeNeedsResolve);
|
|
794
|
+
}));
|
|
795
|
+
// Only need to wait but don't need the values because tree items are resolved in place.
|
|
796
|
+
await allResolved;
|
|
797
|
+
}
|
|
798
|
+
for (const treeNode of treeNodes) {
|
|
799
|
+
if (treeNode && treeNode.command) {
|
|
800
|
+
commandMap.set(treeNode.command.id, treeNode.command.arguments || []);
|
|
801
|
+
}
|
|
802
|
+
}
|
|
803
|
+
return commandMap;
|
|
804
|
+
}
|
|
805
|
+
|
|
806
|
+
private _message: string | undefined;
|
|
807
|
+
get message(): string | undefined {
|
|
808
|
+
return this._message;
|
|
809
|
+
}
|
|
810
|
+
|
|
811
|
+
set message(message: string | undefined) {
|
|
812
|
+
this._message = message;
|
|
813
|
+
this.update();
|
|
814
|
+
}
|
|
815
|
+
|
|
816
|
+
protected override render(): React.ReactNode {
|
|
817
|
+
return React.createElement('div', this.createContainerAttributes(), this.renderSearchInfo(), this.renderTree(this.model));
|
|
818
|
+
}
|
|
819
|
+
|
|
820
|
+
protected renderSearchInfo(): React.ReactNode {
|
|
821
|
+
if (this._message) {
|
|
822
|
+
return <div className='theia-TreeViewInfo'>{this._message}</div>;
|
|
823
|
+
}
|
|
824
|
+
return undefined;
|
|
825
|
+
}
|
|
826
|
+
|
|
827
|
+
override shouldShowWelcomeView(): boolean {
|
|
828
|
+
return (this.model.proxy === undefined || this.model.isTreeEmpty) && this.message === undefined;
|
|
829
|
+
}
|
|
830
|
+
|
|
831
|
+
protected override handleContextMenuEvent(node: TreeNode | undefined, event: React.MouseEvent<HTMLElement, MouseEvent>): void {
|
|
832
|
+
if (SelectableTreeNode.is(node)) {
|
|
833
|
+
// Keep the selection for the context menu, if the widget support multi-selection and the right click happens on an already selected node.
|
|
834
|
+
if (!this.props.multiSelect || !node.selected) {
|
|
835
|
+
const type = !!this.props.multiSelect && this.hasCtrlCmdMask(event) ? TreeSelection.SelectionType.TOGGLE : TreeSelection.SelectionType.DEFAULT;
|
|
836
|
+
this.model.addSelection({ node, type });
|
|
837
|
+
}
|
|
838
|
+
this.focusService.setFocus(node);
|
|
839
|
+
const contextMenuPath = this.props.contextMenuPath;
|
|
840
|
+
if (contextMenuPath) {
|
|
841
|
+
const { x, y } = event.nativeEvent;
|
|
842
|
+
const args = this.toContextMenuArgs(node);
|
|
843
|
+
const contextKeyService = this.contextKeyService.createOverlay([
|
|
844
|
+
['viewItem', (TreeViewNode.is(node) && node.contextValue) || undefined],
|
|
845
|
+
['view', this.options.id]
|
|
846
|
+
]);
|
|
847
|
+
setTimeout(() => this.contextMenuRenderer.render({
|
|
848
|
+
menuPath: contextMenuPath,
|
|
849
|
+
anchor: { x, y },
|
|
850
|
+
args,
|
|
851
|
+
contextKeyService,
|
|
852
|
+
onHide: () => contextKeyService.dispose(),
|
|
853
|
+
}), 10);
|
|
854
|
+
}
|
|
855
|
+
}
|
|
856
|
+
event.stopPropagation();
|
|
857
|
+
event.preventDefault();
|
|
858
|
+
}
|
|
859
|
+
}
|