@theia/core 1.37.0-next.9 → 1.38.0-next.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -9
- package/i18n/nls.cs.json +6 -1
- package/i18n/nls.de.json +6 -1
- package/i18n/nls.es.json +6 -1
- package/i18n/nls.fr.json +6 -1
- package/i18n/nls.hu.json +6 -1
- package/i18n/nls.it.json +6 -1
- package/i18n/nls.ja.json +6 -1
- package/i18n/nls.json +6 -1
- package/i18n/nls.pl.json +6 -1
- package/i18n/nls.pt-br.json +6 -1
- package/i18n/nls.pt-pt.json +6 -1
- package/i18n/nls.ru.json +6 -1
- package/i18n/nls.zh-cn.json +6 -1
- package/lib/browser/core-preferences.d.ts +4 -0
- package/lib/browser/core-preferences.d.ts.map +1 -1
- package/lib/browser/core-preferences.js +22 -0
- package/lib/browser/core-preferences.js.map +1 -1
- package/lib/browser/hover-service.d.ts +5 -0
- package/lib/browser/hover-service.d.ts.map +1 -1
- package/lib/browser/hover-service.js +7 -1
- package/lib/browser/hover-service.js.map +1 -1
- package/lib/browser/icon-theme-service.js +1 -1
- package/lib/browser/icon-theme-service.js.map +1 -1
- package/lib/browser/shell/application-shell.d.ts +2 -1
- package/lib/browser/shell/application-shell.d.ts.map +1 -1
- package/lib/browser/shell/application-shell.js +30 -3
- package/lib/browser/shell/application-shell.js.map +1 -1
- package/lib/browser/shell/tab-bars.d.ts +21 -5
- package/lib/browser/shell/tab-bars.d.ts.map +1 -1
- package/lib/browser/shell/tab-bars.js +94 -17
- package/lib/browser/shell/tab-bars.js.map +1 -1
- package/lib/browser/test/jsdom.js +1 -1
- package/lib/browser/test/jsdom.js.map +1 -1
- package/lib/browser/tree/tree-iterator.js +4 -4
- package/lib/browser/tree/tree-iterator.js.map +1 -1
- package/lib/browser/tree/tree-selection-state.spec.js +26 -2
- package/lib/browser/tree/tree-selection-state.spec.js.map +1 -1
- package/lib/common/i18n/localization.d.ts +1 -0
- package/lib/common/i18n/localization.d.ts.map +1 -1
- package/lib/common/i18n/localization.js +2 -16
- package/lib/common/i18n/localization.js.map +1 -1
- package/lib/common/nls.d.ts +1 -0
- package/lib/common/nls.d.ts.map +1 -1
- package/lib/common/nls.js +2 -1
- package/lib/common/nls.js.map +1 -1
- package/lib/common/quick-pick-service.d.ts +2 -1
- package/lib/common/quick-pick-service.d.ts.map +1 -1
- package/lib/common/quick-pick-service.js.map +1 -1
- package/lib/electron-browser/electron-clipboard-service.d.ts.map +1 -1
- package/lib/electron-browser/electron-clipboard-service.js +2 -3
- package/lib/electron-browser/electron-clipboard-service.js.map +1 -1
- package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.d.ts.map +1 -1
- package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.js +1 -2
- package/lib/electron-browser/keyboard/electron-keyboard-layout-change-notifier.js.map +1 -1
- package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts +2 -3
- package/lib/electron-browser/menu/electron-context-menu-renderer.d.ts.map +1 -1
- package/lib/electron-browser/menu/electron-context-menu-renderer.js +10 -18
- package/lib/electron-browser/menu/electron-context-menu-renderer.js.map +1 -1
- package/lib/electron-browser/menu/electron-main-menu-factory.d.ts +10 -8
- package/lib/electron-browser/menu/electron-main-menu-factory.d.ts.map +1 -1
- package/lib/electron-browser/menu/electron-main-menu-factory.js +33 -32
- package/lib/electron-browser/menu/electron-main-menu-factory.js.map +1 -1
- package/lib/electron-browser/menu/electron-menu-contribution.d.ts +6 -6
- package/lib/electron-browser/menu/electron-menu-contribution.d.ts.map +1 -1
- package/lib/electron-browser/menu/electron-menu-contribution.js +39 -54
- package/lib/electron-browser/menu/electron-menu-contribution.js.map +1 -1
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.d.ts.map +1 -1
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.js +2 -6
- package/lib/electron-browser/messaging/electron-ipc-connection-provider.js.map +1 -1
- package/lib/electron-browser/preload.d.ts +2 -0
- package/lib/electron-browser/preload.d.ts.map +1 -0
- package/lib/electron-browser/preload.js +183 -0
- package/lib/electron-browser/preload.js.map +1 -0
- package/lib/electron-browser/token/electron-token-frontend-module.d.ts.map +1 -1
- package/lib/electron-browser/token/electron-token-frontend-module.js +1 -2
- package/lib/electron-browser/token/electron-token-frontend-module.js.map +1 -1
- package/lib/electron-browser/window/electron-frontend-application-state.d.ts.map +1 -1
- package/lib/electron-browser/window/electron-frontend-application-state.js +1 -3
- package/lib/electron-browser/window/electron-frontend-application-state.js.map +1 -1
- package/lib/electron-browser/window/electron-secondary-window-service.d.ts +1 -3
- package/lib/electron-browser/window/electron-secondary-window-service.d.ts.map +1 -1
- package/lib/electron-browser/window/electron-secondary-window-service.js +6 -34
- package/lib/electron-browser/window/electron-secondary-window-service.js.map +1 -1
- package/lib/electron-browser/window/electron-window-service.d.ts +1 -8
- package/lib/electron-browser/window/electron-window-service.d.ts.map +1 -1
- package/lib/electron-browser/window/electron-window-service.js +8 -25
- package/lib/electron-browser/window/electron-window-service.js.map +1 -1
- package/lib/electron-common/electron-api.d.ts +94 -0
- package/lib/electron-common/electron-api.d.ts.map +1 -0
- package/lib/electron-common/electron-api.js +53 -0
- package/lib/electron-common/electron-api.js.map +1 -0
- package/lib/electron-common/messaging/electron-connection-handler.d.ts +0 -7
- package/lib/electron-common/messaging/electron-connection-handler.d.ts.map +1 -1
- package/lib/electron-common/messaging/electron-connection-handler.js +1 -5
- package/lib/electron-common/messaging/electron-connection-handler.js.map +1 -1
- package/lib/electron-main/electron-api-main.d.ts +21 -0
- package/lib/electron-main/electron-api-main.d.ts.map +1 -0
- package/lib/electron-main/electron-api-main.js +261 -0
- package/lib/electron-main/electron-api-main.js.map +1 -0
- package/lib/electron-main/electron-main-application-module.d.ts.map +1 -1
- package/lib/electron-main/electron-main-application-module.js +3 -3
- package/lib/electron-main/electron-main-application-module.js.map +1 -1
- package/lib/electron-main/electron-main-application.d.ts +8 -2
- package/lib/electron-main/electron-main-application.d.ts.map +1 -1
- package/lib/electron-main/electron-main-application.js +32 -29
- package/lib/electron-main/electron-main-application.js.map +1 -1
- package/lib/electron-main/electron-security-token-service.d.ts.map +1 -1
- package/lib/electron-main/electron-security-token-service.js +2 -1
- package/lib/electron-main/electron-security-token-service.js.map +1 -1
- package/lib/electron-main/messaging/electron-messaging-contribution.d.ts +4 -5
- package/lib/electron-main/messaging/electron-messaging-contribution.d.ts.map +1 -1
- package/lib/electron-main/messaging/electron-messaging-contribution.js +4 -7
- package/lib/electron-main/messaging/electron-messaging-contribution.js.map +1 -1
- package/lib/electron-main/theia-electron-window.d.ts +2 -4
- package/lib/electron-main/theia-electron-window.d.ts.map +1 -1
- package/lib/electron-main/theia-electron-window.js +11 -34
- package/lib/electron-main/theia-electron-window.js.map +1 -1
- package/lib/node/i18n/localization-backend-contribution.d.ts.map +1 -1
- package/lib/node/i18n/localization-backend-contribution.js +2 -1
- package/lib/node/i18n/localization-backend-contribution.js.map +1 -1
- package/lib/node/i18n/localization-provider.d.ts.map +1 -1
- package/lib/node/i18n/localization-provider.js +2 -1
- package/lib/node/i18n/localization-provider.js.map +1 -1
- package/package.json +9 -6
- package/src/browser/core-preferences.ts +26 -0
- package/src/browser/hover-service.ts +12 -1
- package/src/browser/icon-theme-service.ts +1 -1
- package/src/browser/shell/application-shell.ts +29 -1
- package/src/browser/shell/tab-bars.ts +111 -17
- package/src/browser/style/hover-service.css +4 -0
- package/src/browser/style/tabs.css +25 -0
- package/src/browser/style/tree.css +1 -0
- package/src/browser/test/jsdom.ts +1 -1
- package/src/browser/tree/tree-iterator.ts +4 -4
- package/src/browser/tree/tree-selection-state.spec.ts +29 -2
- package/src/common/i18n/localization.ts +6 -16
- package/src/common/nls.ts +3 -1
- package/src/common/quick-pick-service.ts +2 -1
- package/src/electron-browser/electron-clipboard-service.ts +2 -3
- package/src/electron-browser/keyboard/electron-keyboard-layout-change-notifier.ts +1 -2
- package/src/electron-browser/menu/electron-context-menu-renderer.ts +10 -17
- package/src/electron-browser/menu/electron-main-menu-factory.ts +51 -44
- package/src/electron-browser/menu/electron-menu-contribution.ts +46 -57
- package/src/electron-browser/messaging/electron-ipc-connection-provider.ts +4 -9
- package/src/electron-browser/preload.ts +208 -0
- package/src/electron-browser/token/electron-token-frontend-module.ts +1 -2
- package/src/electron-browser/window/electron-frontend-application-state.ts +1 -3
- package/src/electron-browser/window/electron-secondary-window-service.ts +7 -31
- package/src/electron-browser/window/electron-window-service.ts +8 -25
- package/src/electron-common/electron-api.ts +134 -0
- package/src/electron-common/messaging/electron-connection-handler.ts +0 -9
- package/src/electron-main/electron-api-main.ts +291 -0
- package/src/electron-main/electron-main-application-module.ts +3 -4
- package/src/electron-main/electron-main-application.ts +33 -37
- package/src/electron-main/electron-security-token-service.ts +2 -1
- package/src/electron-main/messaging/electron-messaging-contribution.ts +8 -10
- package/src/electron-main/theia-electron-window.ts +8 -33
- package/src/node/i18n/localization-backend-contribution.ts +2 -1
- package/src/node/i18n/localization-provider.ts +2 -1
- package/LICENSE +0 -642
- package/electron-shared/@electron/remote/index.d.ts +0 -1
- package/electron-shared/@electron/remote/index.js +0 -1
- package/electron-shared/@electron/remote/main/index.d.ts +0 -1
- package/electron-shared/@electron/remote/main/index.js +0 -1
- package/lib/electron-common/messaging/electron-messages.d.ts +0 -25
- package/lib/electron-common/messaging/electron-messages.d.ts.map +0 -1
- package/lib/electron-common/messaging/electron-messages.js +0 -37
- package/lib/electron-common/messaging/electron-messages.js.map +0 -1
- package/lib/electron-main/electron-native-keymap.d.ts +0 -8
- package/lib/electron-main/electron-native-keymap.d.ts.map +0 -1
- package/lib/electron-main/electron-native-keymap.js +0 -48
- package/lib/electron-main/electron-native-keymap.js.map +0 -1
- package/src/electron-common/messaging/electron-messages.ts +0 -42
- package/src/electron-main/electron-native-keymap.ts +0 -40
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { WebContents } from '@theia/electron/shared/electron';
|
|
2
2
|
import { ContributionProvider } from '../../common/contribution-provider';
|
|
3
3
|
import { MessagingContribution } from '../../node/messaging/messaging-contribution';
|
|
4
|
-
import { ElectronConnectionHandler } from '../../electron-common/messaging/electron-connection-handler';
|
|
5
4
|
import { ElectronMainApplicationContribution } from '../electron-main-application';
|
|
6
5
|
import { ElectronMessagingService } from './electron-messaging-service';
|
|
7
6
|
import { AbstractChannel, Channel, ChannelMultiplexer, MessageProvider } from '../../common/message-rpc/channel';
|
|
8
|
-
import { Emitter, WriteBuffer } from '../../common';
|
|
7
|
+
import { ConnectionHandler, Emitter, WriteBuffer } from '../../common';
|
|
9
8
|
/**
|
|
10
9
|
* This component replicates the role filled by `MessagingContribution` but for Electron.
|
|
11
10
|
* Unlike the WebSocket based implementation, we do not expect to receive
|
|
@@ -15,7 +14,7 @@ import { Emitter, WriteBuffer } from '../../common';
|
|
|
15
14
|
*/
|
|
16
15
|
export declare class ElectronMessagingContribution implements ElectronMainApplicationContribution, ElectronMessagingService {
|
|
17
16
|
protected readonly messagingContributions: ContributionProvider<ElectronMessagingService.Contribution>;
|
|
18
|
-
protected readonly connectionHandlers: ContributionProvider<
|
|
17
|
+
protected readonly connectionHandlers: ContributionProvider<ConnectionHandler>;
|
|
19
18
|
protected readonly channelHandlers: MessagingContribution.ConnectionHandlers<Channel>;
|
|
20
19
|
/**
|
|
21
20
|
* Each electron window has a main channel and its own multiplexer to route multiple client messages the same IPC connection.
|
|
@@ -25,7 +24,7 @@ export declare class ElectronMessagingContribution implements ElectronMainApplic
|
|
|
25
24
|
multiplexer: ChannelMultiplexer;
|
|
26
25
|
}>;
|
|
27
26
|
protected init(): void;
|
|
28
|
-
protected handleIpcEvent(
|
|
27
|
+
protected handleIpcEvent(sender: WebContents, data: Uint8Array): void;
|
|
29
28
|
protected createWindowChannelData(sender: Electron.WebContents): {
|
|
30
29
|
channel: ElectronWebContentChannel;
|
|
31
30
|
multiplexer: ChannelMultiplexer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"electron-messaging-contribution.d.ts","sourceRoot":"","sources":["../../../src/electron-main/messaging/electron-messaging-contribution.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"electron-messaging-contribution.d.ts","sourceRoot":"","sources":["../../../src/electron-main/messaging/electron-messaging-contribution.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAE9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AAEpF,OAAO,EAAE,mCAAmC,EAAE,MAAM,8BAA8B,CAAC;AACnF,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACjH,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAIvE;;;;;;GAMG;AAEH,qBACa,6BAA8B,YAAW,mCAAmC,EAAE,wBAAwB;IAG/G,SAAS,CAAC,QAAQ,CAAC,sBAAsB,EAAE,oBAAoB,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAAC;IAGvG,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,oBAAoB,CAAC,iBAAiB,CAAC,CAAC;IAE/E,SAAS,CAAC,QAAQ,CAAC,eAAe,oDAA2D;IAC7F;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,wBAAwB;iBAA8B,yBAAyB;qBAAe,kBAAkB;OAAM;IAGzI,SAAS,CAAC,IAAI,IAAI,IAAI;IAItB,SAAS,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,EAAE,IAAI,EAAE,UAAU,GAAG,IAAI;IAWrE,SAAS,CAAC,uBAAuB,CAAC,MAAM,EAAE,QAAQ,CAAC,WAAW,GAAG;QAAE,OAAO,EAAE,yBAAyB,CAAC;QAAC,WAAW,EAAE,kBAAkB,CAAA;KAAE;IAkBxI;;;OAGG;IACH,SAAS,CAAC,uBAAuB,CAAC,MAAM,EAAE,WAAW,GAAG,yBAAyB;IAIjF,SAAS,CAAC,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAKrG,OAAO,IAAI,IAAI;IAYf,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,GAAG,IAAI;CAGpF;AAED;;;GAGG;AACH,qBAAa,yBAA0B,SAAQ,eAAe;IAK9C,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,QAAQ,CAAC,WAAW;IAF3D,SAAkB,gBAAgB,EAAE,OAAO,CAAC,eAAe,CAAC,CAAiB;gBAE9C,MAAM,EAAE,QAAQ,CAAC,WAAW;IAI3D,cAAc,IAAI,WAAW;CAYhC"}
|
|
@@ -25,7 +25,6 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
25
25
|
};
|
|
26
26
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
27
|
exports.ElectronWebContentChannel = exports.ElectronMessagingContribution = void 0;
|
|
28
|
-
const electron_1 = require("@theia/electron/shared/electron");
|
|
29
28
|
const inversify_1 = require("inversify");
|
|
30
29
|
const contribution_provider_1 = require("../../common/contribution-provider");
|
|
31
30
|
const messaging_contribution_1 = require("../../node/messaging/messaging-contribution");
|
|
@@ -34,6 +33,7 @@ const electron_messaging_service_1 = require("./electron-messaging-service");
|
|
|
34
33
|
const channel_1 = require("../../common/message-rpc/channel");
|
|
35
34
|
const common_1 = require("../../common");
|
|
36
35
|
const uint8_array_message_buffer_1 = require("../../common/message-rpc/uint8-array-message-buffer");
|
|
36
|
+
const electron_api_main_1 = require("../electron-api-main");
|
|
37
37
|
/**
|
|
38
38
|
* This component replicates the role filled by `MessagingContribution` but for Electron.
|
|
39
39
|
* Unlike the WebSocket based implementation, we do not expect to receive
|
|
@@ -50,13 +50,10 @@ let ElectronMessagingContribution = class ElectronMessagingContribution {
|
|
|
50
50
|
this.windowChannelMultiplexer = new Map();
|
|
51
51
|
}
|
|
52
52
|
init() {
|
|
53
|
-
|
|
54
|
-
this.handleIpcEvent(event, data);
|
|
55
|
-
});
|
|
53
|
+
electron_api_main_1.TheiaRendererAPI.onIpcData((sender, data) => this.handleIpcEvent(sender, data));
|
|
56
54
|
}
|
|
57
|
-
handleIpcEvent(
|
|
55
|
+
handleIpcEvent(sender, data) {
|
|
58
56
|
var _a;
|
|
59
|
-
const sender = event.sender;
|
|
60
57
|
// Get the multiplexer for a given window id
|
|
61
58
|
try {
|
|
62
59
|
const windowChannelData = (_a = this.windowChannelMultiplexer.get(sender.id)) !== null && _a !== void 0 ? _a : this.createWindowChannelData(sender);
|
|
@@ -144,7 +141,7 @@ class ElectronWebContentChannel extends channel_1.AbstractChannel {
|
|
|
144
141
|
const writer = new uint8_array_message_buffer_1.Uint8ArrayWriteBuffer();
|
|
145
142
|
writer.onCommit(buffer => {
|
|
146
143
|
if (!this.sender.isDestroyed()) {
|
|
147
|
-
|
|
144
|
+
electron_api_main_1.TheiaRendererAPI.sendData(this.sender, buffer);
|
|
148
145
|
}
|
|
149
146
|
});
|
|
150
147
|
return writer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"electron-messaging-contribution.js","sourceRoot":"","sources":["../../../src/electron-main/messaging/electron-messaging-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,0CAA0C;AAC1C,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,2EAA2E;AAC3E,gFAAgF;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"electron-messaging-contribution.js","sourceRoot":"","sources":["../../../src/electron-main/messaging/electron-messaging-contribution.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { FrontendApplicationConfig } from '@theia/application-package';
|
|
2
|
-
import { FrontendApplicationState } from '../common/frontend-application-state';
|
|
3
|
-
import {
|
|
4
|
-
import { BrowserWindow, BrowserWindowConstructorOptions, IpcMainEvent } from '../../electron-shared/electron';
|
|
2
|
+
import { FrontendApplicationState, StopReason } from '../common/frontend-application-state';
|
|
3
|
+
import { BrowserWindow, BrowserWindowConstructorOptions } from '../../electron-shared/electron';
|
|
5
4
|
import { ElectronMainApplicationGlobals } from './electron-main-constants';
|
|
6
5
|
import { DisposableCollection, Emitter, Event } from '../common';
|
|
7
6
|
/**
|
|
@@ -45,7 +44,6 @@ export declare class TheiaElectronWindow {
|
|
|
45
44
|
protected restoreMaximizedState(): void;
|
|
46
45
|
protected trackApplicationState(): void;
|
|
47
46
|
protected attachReloadListener(): void;
|
|
48
|
-
protected isSender(e: IpcMainEvent): boolean;
|
|
49
47
|
dispose(): void;
|
|
50
48
|
}
|
|
51
49
|
export interface TheiaElectronWindowFactory {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theia-electron-window.d.ts","sourceRoot":"","sources":["../../src/electron-main/theia-electron-window.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,wBAAwB,EAAE,
|
|
1
|
+
{"version":3,"file":"theia-electron-window.d.ts","sourceRoot":"","sources":["../../src/electron-main/theia-electron-window.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,wBAAwB,EAAE,UAAU,EAAE,MAAM,sCAAsC,CAAC;AAC5F,OAAO,EAAE,aAAa,EAAE,+BAA+B,EAAE,MAAM,gCAAgC,CAAC;AAEhG,OAAO,EAAE,8BAA8B,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAMjE;;GAEG;AACH,MAAM,WAAW,yBAA0B,SAAQ,+BAA+B;IAC9E,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB;;;;OAIG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,eAAO,MAAM,yBAAyB,eAAsC,CAAC;AAE7E,eAAO,MAAM,uBAAuB,eAAoC,CAAC;AACzE,oBAAY,uBAAuB,GAAG,yBAAyB,CAAC;AAEhE,qBACa,mBAAmB;IACO,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,yBAAyB,CAAC;IACxD,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,uBAAuB,CAAC;IAC5C,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,8BAA8B,CAAC;IAEnG,SAAS,CAAC,iBAAiB,gBAAuB;IAElD,IAAI,UAAU,IAAI,KAAK,CAAC,IAAI,CAAC,CAE5B;IAED,SAAS,CAAC,QAAQ,CAAC,SAAS,uBAAoD;IAEhF,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC;IACjC,IAAI,MAAM,IAAI,aAAa,CAE1B;IAED,SAAS,CAAC,gBAAgB,UAAS;IACnC,SAAS,CAAC,gBAAgB,EAAE,wBAAwB,CAAU;IAG9D,SAAS,CAAC,IAAI,IAAI,IAAI;IAUtB;;OAEG;IACH,SAAS,CAAC,iBAAiB,IAAI,IAAI;IAInC,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAetC,SAAS,CAAC,aAAa,IAAI,IAAI;IAK/B,KAAK,CAAC,MAAM,GAAE,UAA6B,GAAG,OAAO,CAAC,OAAO,CAAC;IAI9D,SAAS,CAAC,MAAM,IAAI,IAAI;cAOR,iBAAiB,CAAC,cAAc,EAAE,MAAM,OAAO,EAAE,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAsBtG,SAAS,CAAC,eAAe,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAI/D,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAQvC,SAAS,CAAC,qBAAqB,IAAI,IAAI;IAMvC,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAItC,OAAO,IAAI,IAAI;CAGlB;AAED,MAAM,WAAW,0BAA0B;IACvC,CAAC,OAAO,EAAE,yBAAyB,EAAE,MAAM,EAAE,yBAAyB,GAAG,mBAAmB,CAAC;CAChG;AAED,eAAO,MAAM,0BAA0B,eAAuC,CAAC"}
|
|
@@ -25,7 +25,7 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
25
25
|
};
|
|
26
26
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
27
|
exports.TheiaElectronWindowFactory = exports.TheiaElectronWindow = exports.WindowApplicationConfig = exports.TheiaBrowserWindowOptions = void 0;
|
|
28
|
-
const
|
|
28
|
+
const frontend_application_state_1 = require("../common/frontend-application-state");
|
|
29
29
|
const electron_1 = require("../../electron-shared/electron");
|
|
30
30
|
const inversify_1 = require("../../shared/inversify");
|
|
31
31
|
const electron_main_constants_1 = require("./electron-main-constants");
|
|
@@ -33,6 +33,7 @@ const common_1 = require("../common");
|
|
|
33
33
|
const event_utils_1 = require("./event-utils");
|
|
34
34
|
const uri_1 = require("../common/uri");
|
|
35
35
|
const file_uri_1 = require("../node/file-uri");
|
|
36
|
+
const electron_api_main_1 = require("./electron-api-main");
|
|
36
37
|
exports.TheiaBrowserWindowOptions = Symbol('TheiaBrowserWindowOptions');
|
|
37
38
|
exports.WindowApplicationConfig = Symbol('WindowApplicationConfig');
|
|
38
39
|
let TheiaElectronWindow = class TheiaElectronWindow {
|
|
@@ -74,21 +75,21 @@ let TheiaElectronWindow = class TheiaElectronWindow {
|
|
|
74
75
|
return;
|
|
75
76
|
}
|
|
76
77
|
event.preventDefault();
|
|
77
|
-
this.handleStopRequest(() => this.doCloseWindow(),
|
|
78
|
+
this.handleStopRequest(() => this.doCloseWindow(), frontend_application_state_1.StopReason.Close);
|
|
78
79
|
}, this.toDispose);
|
|
79
80
|
}
|
|
80
81
|
doCloseWindow() {
|
|
81
82
|
this.closeIsConfirmed = true;
|
|
82
83
|
this._window.close();
|
|
83
84
|
}
|
|
84
|
-
close(reason =
|
|
85
|
+
close(reason = frontend_application_state_1.StopReason.Close) {
|
|
85
86
|
return this.handleStopRequest(() => this.doCloseWindow(), reason);
|
|
86
87
|
}
|
|
87
88
|
reload() {
|
|
88
89
|
this.handleStopRequest(() => {
|
|
89
90
|
this.applicationState = 'init';
|
|
90
91
|
this._window.reload();
|
|
91
|
-
},
|
|
92
|
+
}, frontend_application_state_1.StopReason.Reload);
|
|
92
93
|
}
|
|
93
94
|
async handleStopRequest(onSafeCallback, reason) {
|
|
94
95
|
// Only confirm close to windows that have loaded our frontend.
|
|
@@ -107,28 +108,13 @@ let TheiaElectronWindow = class TheiaElectronWindow {
|
|
|
107
108
|
return true;
|
|
108
109
|
}
|
|
109
110
|
catch (e) {
|
|
110
|
-
console.warn(`Request ${
|
|
111
|
+
console.warn(`Request ${frontend_application_state_1.StopReason[reason]} failed.`, e);
|
|
111
112
|
}
|
|
112
113
|
}
|
|
113
114
|
return false;
|
|
114
115
|
}
|
|
115
116
|
checkSafeToStop(reason) {
|
|
116
|
-
|
|
117
|
-
const cancelChannel = `notSafeToClose-${this._window.id}`;
|
|
118
|
-
const temporaryDisposables = new common_1.DisposableCollection();
|
|
119
|
-
return new Promise(resolve => {
|
|
120
|
-
this._window.webContents.send(electron_messages_1.CLOSE_REQUESTED_SIGNAL, { confirmChannel, cancelChannel, reason });
|
|
121
|
-
(0, event_utils_1.createDisposableListener)(electron_1.ipcMain, confirmChannel, (e) => {
|
|
122
|
-
if (this.isSender(e)) {
|
|
123
|
-
resolve(true);
|
|
124
|
-
}
|
|
125
|
-
}, temporaryDisposables);
|
|
126
|
-
(0, event_utils_1.createDisposableListener)(electron_1.ipcMain, cancelChannel, (e) => {
|
|
127
|
-
if (this.isSender(e)) {
|
|
128
|
-
resolve(false);
|
|
129
|
-
}
|
|
130
|
-
}, temporaryDisposables);
|
|
131
|
-
}).finally(() => temporaryDisposables.dispose());
|
|
117
|
+
return electron_api_main_1.TheiaRendererAPI.requestClose(this.window.webContents, reason);
|
|
132
118
|
}
|
|
133
119
|
restoreMaximizedState() {
|
|
134
120
|
if (this.options.isMaximized) {
|
|
@@ -139,21 +125,12 @@ let TheiaElectronWindow = class TheiaElectronWindow {
|
|
|
139
125
|
}
|
|
140
126
|
}
|
|
141
127
|
trackApplicationState() {
|
|
142
|
-
(
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
}
|
|
146
|
-
}, this.toDispose);
|
|
128
|
+
this.toDispose.push(electron_api_main_1.TheiaRendererAPI.onApplicationStateChanged(this.window.webContents, state => {
|
|
129
|
+
this.applicationState = state;
|
|
130
|
+
}));
|
|
147
131
|
}
|
|
148
132
|
attachReloadListener() {
|
|
149
|
-
(
|
|
150
|
-
if (this.isSender(e)) {
|
|
151
|
-
this.reload();
|
|
152
|
-
}
|
|
153
|
-
}, this.toDispose);
|
|
154
|
-
}
|
|
155
|
-
isSender(e) {
|
|
156
|
-
return electron_1.BrowserWindow.fromId(e.sender.id) === this._window;
|
|
133
|
+
this.toDispose.push(electron_api_main_1.TheiaRendererAPI.onRequestReload(this.window.webContents, () => this.reload()));
|
|
157
134
|
}
|
|
158
135
|
dispose() {
|
|
159
136
|
this.toDispose.dispose();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theia-electron-window.js","sourceRoot":"","sources":["../../src/electron-main/theia-electron-window.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,0CAA0C;AAC1C,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,2EAA2E;AAC3E,gFAAgF;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"theia-electron-window.js","sourceRoot":"","sources":["../../src/electron-main/theia-electron-window.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"localization-backend-contribution.d.ts","sourceRoot":"","sources":["../../../src/node/i18n/localization-backend-contribution.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"localization-backend-contribution.d.ts","sourceRoot":"","sources":["../../../src/node/i18n/localization-backend-contribution.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,OAAO,MAAM,SAAS,CAAC;AAGnC,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD,OAAO,EAAE,8BAA8B,EAAE,MAAM,wBAAwB,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAE/D,qBACa,+BAAgC,YAAW,8BAA8B;IAClF,SAAS,CAAC,QAAQ,CAAC,WAAW,iBAAwB;IAGtD,SAAS,CAAC,QAAQ,CAAC,oBAAoB,EAAE,oBAAoB,CAAC;IAG9D,SAAS,CAAC,QAAQ,CAAC,oBAAoB,EAAE,oBAAoB,CAAC;IAExD,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAKjC,qBAAqB,IAAI,OAAO,CAAC,IAAI,CAAC;IAItC,SAAS,CAAC,GAAG,EAAE,OAAO,CAAC,WAAW,GAAG,IAAI;CAS5C"}
|
|
@@ -26,6 +26,7 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
26
26
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
27
27
|
exports.LocalizationBackendContribution = void 0;
|
|
28
28
|
const inversify_1 = require("inversify");
|
|
29
|
+
const nls_1 = require("../../common/nls");
|
|
29
30
|
const promise_util_1 = require("../../common/promise-util");
|
|
30
31
|
const localization_contribution_1 = require("./localization-contribution");
|
|
31
32
|
const localization_provider_1 = require("./localization-provider");
|
|
@@ -44,7 +45,7 @@ let LocalizationBackendContribution = class LocalizationBackendContribution {
|
|
|
44
45
|
app.get('/i18n/:locale', async (req, res) => {
|
|
45
46
|
await this.waitForInitialization();
|
|
46
47
|
let locale = req.params.locale;
|
|
47
|
-
locale = this.localizationProvider.getAvailableLanguages().some(e => e.languageId === locale) ? locale :
|
|
48
|
+
locale = this.localizationProvider.getAvailableLanguages().some(e => e.languageId === locale) ? locale : nls_1.nls.defaultLocale;
|
|
48
49
|
this.localizationProvider.setCurrentLanguage(locale);
|
|
49
50
|
res.send(this.localizationProvider.loadLocalization(locale));
|
|
50
51
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"localization-backend-contribution.js","sourceRoot":"","sources":["../../../src/node/i18n/localization-backend-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,2EAA2E;AAC3E,gFAAgF;;;;;;;;;;;;AAGhF,yCAA+C;AAC/C,4DAAqD;AAErD,2EAAmE;AACnE,mEAA+D;AAG/D,IAAa,+BAA+B,GAA5C,MAAa,+BAA+B;IAA5C;QACuB,gBAAW,GAAG,IAAI,uBAAQ,EAAQ,CAAC;IA0B1D,CAAC;IAlBG,KAAK,CAAC,UAAU;QACZ,MAAM,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC;QAC7C,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC/B,CAAC;IAED,qBAAqB;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;IACpC,CAAC;IAED,SAAS,CAAC,GAAwB;QAC9B,GAAG,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YACxC,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACnC,IAAI,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC;YAC/B,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"localization-backend-contribution.js","sourceRoot":"","sources":["../../../src/node/i18n/localization-backend-contribution.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,2EAA2E;AAC3E,gFAAgF;;;;;;;;;;;;AAGhF,yCAA+C;AAC/C,0CAAuC;AACvC,4DAAqD;AAErD,2EAAmE;AACnE,mEAA+D;AAG/D,IAAa,+BAA+B,GAA5C,MAAa,+BAA+B;IAA5C;QACuB,gBAAW,GAAG,IAAI,uBAAQ,EAAQ,CAAC;IA0B1D,CAAC;IAlBG,KAAK,CAAC,UAAU;QACZ,MAAM,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC;QAC7C,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC/B,CAAC;IAED,qBAAqB;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;IACpC,CAAC;IAED,SAAS,CAAC,GAAwB;QAC9B,GAAG,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE;YACxC,MAAM,IAAI,CAAC,qBAAqB,EAAE,CAAC;YACnC,IAAI,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC;YAC/B,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAG,CAAC,aAAa,CAAC;YAC3H,IAAI,CAAC,oBAAoB,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;YACrD,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;IACP,CAAC;CACJ,CAAA;AAvBG;IADC,IAAA,kBAAM,EAAC,gDAAoB,CAAC;8BACY,gDAAoB;6EAAC;AAG9D;IADC,IAAA,kBAAM,EAAC,4CAAoB,CAAC;8BACY,4CAAoB;6EAAC;AAPrD,+BAA+B;IAD3C,IAAA,sBAAU,GAAE;GACA,+BAA+B,CA2B3C;AA3BY,0EAA+B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"localization-provider.d.ts","sourceRoot":"","sources":["../../../src/node/i18n/localization-provider.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"localization-provider.d.ts","sourceRoot":"","sources":["../../../src/node/i18n/localization-provider.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAC;AAE5E,qBACa,oBAAoB;IAE7B,SAAS,CAAC,aAAa,EAAE,YAAY,EAAE,CAAM;IAC7C,SAAS,CAAC,eAAe,SAAqB;IAE9C,gBAAgB,CAAC,GAAG,aAAa,EAAE,YAAY,EAAE,GAAG,IAAI;IAIxD,mBAAmB,CAAC,GAAG,aAAa,EAAE,YAAY,EAAE,GAAG,IAAI;IAS3D,kBAAkB,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI;IAI5C,kBAAkB,IAAI,MAAM;IAI5B,qBAAqB,CAAC,GAAG,CAAC,EAAE,OAAO,GAAG,YAAY,EAAE;IAgBpD,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,YAAY;CAcrD"}
|
|
@@ -23,10 +23,11 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
23
23
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
24
24
|
exports.LocalizationProvider = void 0;
|
|
25
25
|
const inversify_1 = require("inversify");
|
|
26
|
+
const nls_1 = require("../../common/nls");
|
|
26
27
|
let LocalizationProvider = class LocalizationProvider {
|
|
27
28
|
constructor() {
|
|
28
29
|
this.localizations = [];
|
|
29
|
-
this.currentLanguage =
|
|
30
|
+
this.currentLanguage = nls_1.nls.defaultLocale;
|
|
30
31
|
}
|
|
31
32
|
addLocalizations(...localizations) {
|
|
32
33
|
this.localizations.push(...localizations);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"localization-provider.js","sourceRoot":"","sources":["../../../src/node/i18n/localization-provider.ts"],"names":[],"mappings":";AAAA,gFAAgF;AAChF,yCAAyC;AACzC,EAAE;AACF,2EAA2E;AAC3E,mEAAmE;AACnE,wCAAwC;AACxC,EAAE;AACF,4EAA4E;AAC5E,8EAA8E;AAC9E,6EAA6E;AAC7E,yDAAyD;AACzD,uDAAuD;AACvD,EAAE;AACF,2EAA2E;AAC3E,gFAAgF;;;;;;;;;AAEhF,yCAAuC;AAIvC,IAAa,oBAAoB,GAAjC,MAAa,oBAAoB;IAAjC;QAEc,kBAAa,GAAmB,EAAE,CAAC;QACnC,oBAAe,GAAG,
|
|
1
|
+
{"version":3,"file":"localization-provider.js","sourceRoot":"","sources":["../../../src/node/i18n/localization-provider.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@theia/core",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.38.0-next.0+877f96225",
|
|
4
4
|
"description": "Theia is a cloud & desktop IDE framework implemented in TypeScript.",
|
|
5
5
|
"main": "lib/common/index.js",
|
|
6
6
|
"typings": "lib/common/index.d.ts",
|
|
@@ -16,8 +16,8 @@
|
|
|
16
16
|
"@phosphor/signaling": "1",
|
|
17
17
|
"@phosphor/virtualdom": "1",
|
|
18
18
|
"@phosphor/widgets": "1",
|
|
19
|
-
"@theia/application-package": "1.
|
|
20
|
-
"@theia/request": "1.
|
|
19
|
+
"@theia/application-package": "1.38.0-next.0+877f96225",
|
|
20
|
+
"@theia/request": "1.38.0-next.0+877f96225",
|
|
21
21
|
"@types/body-parser": "^1.16.4",
|
|
22
22
|
"@types/cookie": "^0.3.3",
|
|
23
23
|
"@types/dompurify": "^2.2.2",
|
|
@@ -129,6 +129,9 @@
|
|
|
129
129
|
}
|
|
130
130
|
},
|
|
131
131
|
"theiaExtensions": [
|
|
132
|
+
{
|
|
133
|
+
"preload": "lib/electron-browser/preload"
|
|
134
|
+
},
|
|
132
135
|
{
|
|
133
136
|
"frontend": "lib/browser/i18n/i18n-frontend-module",
|
|
134
137
|
"backend": "lib/node/i18n/i18n-backend-module"
|
|
@@ -195,12 +198,12 @@
|
|
|
195
198
|
"watch": "theiaext watch"
|
|
196
199
|
},
|
|
197
200
|
"devDependencies": {
|
|
198
|
-
"@theia/ext-scripts": "1.
|
|
199
|
-
"@theia/re-exports": "1.
|
|
201
|
+
"@theia/ext-scripts": "1.37.0",
|
|
202
|
+
"@theia/re-exports": "1.37.0",
|
|
200
203
|
"minimist": "^1.2.0"
|
|
201
204
|
},
|
|
202
205
|
"nyc": {
|
|
203
206
|
"extends": "../../configs/nyc.json"
|
|
204
207
|
},
|
|
205
|
-
"gitHead": "
|
|
208
|
+
"gitHead": "877f96225ebb78dea2f764d56890cecc477e204c"
|
|
206
209
|
}
|
|
@@ -80,6 +80,11 @@ export const corePreferenceSchema: PreferenceSchema = {
|
|
|
80
80
|
default: 'code',
|
|
81
81
|
markdownDescription: nls.localizeByDefault('Controls the dispatching logic for key presses to use either `code` (recommended) or `keyCode`.')
|
|
82
82
|
},
|
|
83
|
+
'window.tabbar.enhancedPreview': {
|
|
84
|
+
type: 'boolean',
|
|
85
|
+
default: false,
|
|
86
|
+
description: nls.localize('theia/core/enhancedPreview', 'Controls whether more information about the tab should be displayed in horizontal tab bars.')
|
|
87
|
+
},
|
|
83
88
|
'window.menuBarVisibility': {
|
|
84
89
|
type: 'string',
|
|
85
90
|
enum: ['classic', 'visible', 'hidden', 'compact'],
|
|
@@ -232,6 +237,23 @@ export const corePreferenceSchema: PreferenceSchema = {
|
|
|
232
237
|
type: 'boolean',
|
|
233
238
|
default: false,
|
|
234
239
|
description: nls.localize('theia/core/tabMaximize', 'Controls whether to maximize tabs on double click.')
|
|
240
|
+
},
|
|
241
|
+
'workbench.tab.shrinkToFit.enabled': {
|
|
242
|
+
type: 'boolean',
|
|
243
|
+
default: false,
|
|
244
|
+
description: nls.localize('theia/core/tabShrinkToFit', 'Shrink tabs to fit available space.')
|
|
245
|
+
},
|
|
246
|
+
'workbench.tab.shrinkToFit.minimumSize': {
|
|
247
|
+
type: 'number',
|
|
248
|
+
default: 50,
|
|
249
|
+
minimum: 10,
|
|
250
|
+
description: nls.localize('theia/core/tabMinimumSize', 'Specifies the minimum size for tabs.')
|
|
251
|
+
},
|
|
252
|
+
'workbench.tab.shrinkToFit.defaultSize': {
|
|
253
|
+
type: 'number',
|
|
254
|
+
default: 200,
|
|
255
|
+
minimum: 10,
|
|
256
|
+
description: nls.localize('theia/core/tabDefaultSize', 'Specifies the default size for tabs.')
|
|
235
257
|
}
|
|
236
258
|
}
|
|
237
259
|
};
|
|
@@ -241,6 +263,7 @@ export interface CoreConfiguration {
|
|
|
241
263
|
'breadcrumbs.enabled': boolean;
|
|
242
264
|
'files.encoding': string;
|
|
243
265
|
'keyboard.dispatch': 'code' | 'keyCode';
|
|
266
|
+
'window.tabbar.enhancedPreview': boolean;
|
|
244
267
|
'window.menuBarVisibility': 'classic' | 'visible' | 'hidden' | 'compact';
|
|
245
268
|
'window.title': string;
|
|
246
269
|
'window.titleSeparator': string;
|
|
@@ -259,6 +282,9 @@ export interface CoreConfiguration {
|
|
|
259
282
|
'workbench.sash.hoverDelay': number;
|
|
260
283
|
'workbench.sash.size': number;
|
|
261
284
|
'workbench.tab.maximize': boolean;
|
|
285
|
+
'workbench.tab.shrinkToFit.enabled': boolean;
|
|
286
|
+
'workbench.tab.shrinkToFit.minimumSize': number;
|
|
287
|
+
'workbench.tab.shrinkToFit.defaultSize': number;
|
|
262
288
|
}
|
|
263
289
|
|
|
264
290
|
export const CorePreferenceContribution = Symbol('CorePreferenceContribution');
|
|
@@ -57,6 +57,11 @@ export interface HoverRequest {
|
|
|
57
57
|
* if the specified content does not fit in the window next to the target element
|
|
58
58
|
*/
|
|
59
59
|
position: HoverPosition
|
|
60
|
+
/**
|
|
61
|
+
* Additional css classes that should be added to the hover box.
|
|
62
|
+
* Used to style certain boxes different e.g. for the extended tab preview.
|
|
63
|
+
*/
|
|
64
|
+
cssClasses?: string []
|
|
60
65
|
}
|
|
61
66
|
|
|
62
67
|
@injectable()
|
|
@@ -101,7 +106,10 @@ export class HoverService {
|
|
|
101
106
|
|
|
102
107
|
protected async renderHover(request: HoverRequest): Promise<void> {
|
|
103
108
|
const host = this.hoverHost;
|
|
104
|
-
const { target, content, position } = request;
|
|
109
|
+
const { target, content, position, cssClasses } = request;
|
|
110
|
+
if (cssClasses) {
|
|
111
|
+
host.classList.add(...cssClasses);
|
|
112
|
+
}
|
|
105
113
|
this.hoverTarget = target;
|
|
106
114
|
if (content instanceof HTMLElement) {
|
|
107
115
|
host.appendChild(content);
|
|
@@ -124,6 +132,9 @@ export class HoverService {
|
|
|
124
132
|
dispose: () => {
|
|
125
133
|
this.lastHidHover = Date.now();
|
|
126
134
|
host.classList.remove(updatedPosition);
|
|
135
|
+
if (cssClasses) {
|
|
136
|
+
host.classList.remove(...cssClasses);
|
|
137
|
+
}
|
|
127
138
|
}
|
|
128
139
|
});
|
|
129
140
|
|
|
@@ -168,9 +168,9 @@ export class IconThemeService {
|
|
|
168
168
|
*/
|
|
169
169
|
setCurrent(newCurrent: IconTheme, persistSetting = true): void {
|
|
170
170
|
if (newCurrent !== this.getCurrent()) {
|
|
171
|
+
this.activeTheme = newCurrent;
|
|
171
172
|
this.toDeactivate.dispose();
|
|
172
173
|
this.toDeactivate.push(newCurrent.activate());
|
|
173
|
-
this.activeTheme = newCurrent;
|
|
174
174
|
this.onDidChangeCurrentEmitter.fire(newCurrent.id);
|
|
175
175
|
}
|
|
176
176
|
if (persistSetting) {
|
|
@@ -96,6 +96,7 @@ export class DockPanelRenderer implements DockLayout.IRenderer {
|
|
|
96
96
|
@inject(TabBarToolbarRegistry) protected readonly tabBarToolbarRegistry: TabBarToolbarRegistry,
|
|
97
97
|
@inject(TabBarToolbarFactory) protected readonly tabBarToolbarFactory: TabBarToolbarFactory,
|
|
98
98
|
@inject(BreadcrumbsRendererFactory) protected readonly breadcrumbsRendererFactory: BreadcrumbsRendererFactory,
|
|
99
|
+
@inject(CorePreferences) protected readonly corePreferences: CorePreferences
|
|
99
100
|
) { }
|
|
100
101
|
|
|
101
102
|
get onDidCreateTabBar(): CommonEvent<TabBar<Widget>> {
|
|
@@ -103,6 +104,17 @@ export class DockPanelRenderer implements DockLayout.IRenderer {
|
|
|
103
104
|
}
|
|
104
105
|
|
|
105
106
|
createTabBar(): TabBar<Widget> {
|
|
107
|
+
const getDynamicTabOptions: () => ScrollableTabBar.Options | undefined = () => {
|
|
108
|
+
if (this.corePreferences.get('workbench.tab.shrinkToFit.enabled')) {
|
|
109
|
+
return {
|
|
110
|
+
minimumTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.minimumSize'),
|
|
111
|
+
defaultTabSize: this.corePreferences.get('workbench.tab.shrinkToFit.defaultSize')
|
|
112
|
+
};
|
|
113
|
+
} else {
|
|
114
|
+
return undefined;
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
|
|
106
118
|
const renderer = this.tabBarRendererFactory();
|
|
107
119
|
const tabBar = new ToolbarAwareTabBar(
|
|
108
120
|
this.tabBarToolbarRegistry,
|
|
@@ -115,12 +127,20 @@ export class DockPanelRenderer implements DockLayout.IRenderer {
|
|
|
115
127
|
useBothWheelAxes: true,
|
|
116
128
|
scrollXMarginOffset: 4,
|
|
117
129
|
suppressScrollY: true
|
|
118
|
-
}
|
|
130
|
+
},
|
|
131
|
+
getDynamicTabOptions());
|
|
119
132
|
this.tabBarClasses.forEach(c => tabBar.addClass(c));
|
|
120
133
|
renderer.tabBar = tabBar;
|
|
121
134
|
tabBar.disposed.connect(() => renderer.dispose());
|
|
122
135
|
renderer.contextMenuPath = SHELL_TABBAR_CONTEXT_MENU;
|
|
123
136
|
tabBar.currentChanged.connect(this.onCurrentTabChanged, this);
|
|
137
|
+
this.corePreferences.onPreferenceChanged(change => {
|
|
138
|
+
if (change.preferenceName === 'workbench.tab.shrinkToFit.enabled' ||
|
|
139
|
+
change.preferenceName === 'workbench.tab.shrinkToFit.minimumSize' ||
|
|
140
|
+
change.preferenceName === 'workbench.tab.shrinkToFit.defaultSize') {
|
|
141
|
+
tabBar.dynamicTabOptions = getDynamicTabOptions();
|
|
142
|
+
}
|
|
143
|
+
});
|
|
124
144
|
this.onDidCreateTabBarEmitter.fire(tabBar);
|
|
125
145
|
return tabBar;
|
|
126
146
|
}
|
|
@@ -266,6 +286,14 @@ export class ApplicationShell extends Widget {
|
|
|
266
286
|
}
|
|
267
287
|
});
|
|
268
288
|
}
|
|
289
|
+
|
|
290
|
+
this.corePreferences.onPreferenceChanged(preference => {
|
|
291
|
+
if (preference.preferenceName === 'window.tabbar.enhancedPreview') {
|
|
292
|
+
this.allTabBars.forEach(tabBar => {
|
|
293
|
+
tabBar.update();
|
|
294
|
+
});
|
|
295
|
+
}
|
|
296
|
+
});
|
|
269
297
|
}
|
|
270
298
|
|
|
271
299
|
protected initializeShell(): void {
|