@theia/application-manager 1.53.0-next.5 → 1.53.0-next.55
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 +25 -25
- package/lib/generator/backend-generator.js +157 -157
- package/lib/generator/frontend-generator.js +143 -143
- package/lib/generator/webpack-generator.js +432 -432
- package/package.json +6 -6
- package/src/application-package-manager.ts +263 -263
- package/src/application-process.ts +86 -86
- package/src/expose-loader.ts +80 -80
- package/src/generator/abstract-generator.ts +69 -69
- package/src/generator/backend-generator.ts +204 -204
- package/src/generator/frontend-generator.ts +222 -222
- package/src/generator/index.ts +19 -19
- package/src/generator/webpack-generator.ts +501 -501
- package/src/index.ts +19 -19
- package/src/package.spec.ts +28 -28
- package/src/rebuild.ts +350 -350
|
@@ -42,110 +42,110 @@ class FrontendGenerator extends abstract_generator_1.AbstractGenerator {
|
|
|
42
42
|
return template;
|
|
43
43
|
}
|
|
44
44
|
compileIndexHtml(frontendModules) {
|
|
45
|
-
return `<!DOCTYPE html>
|
|
46
|
-
<html lang="en">
|
|
47
|
-
|
|
48
|
-
<head>${this.compileIndexHead(frontendModules)}
|
|
49
|
-
</head>
|
|
50
|
-
|
|
51
|
-
<body>
|
|
52
|
-
<div class="theia-preload">${this.compileIndexPreload(frontendModules)}</div>
|
|
53
|
-
<script type="text/javascript" src="./bundle.js" charset="utf-8"></script>
|
|
54
|
-
</body>
|
|
55
|
-
|
|
45
|
+
return `<!DOCTYPE html>
|
|
46
|
+
<html lang="en">
|
|
47
|
+
|
|
48
|
+
<head>${this.compileIndexHead(frontendModules)}
|
|
49
|
+
</head>
|
|
50
|
+
|
|
51
|
+
<body>
|
|
52
|
+
<div class="theia-preload">${this.compileIndexPreload(frontendModules)}</div>
|
|
53
|
+
<script type="text/javascript" src="./bundle.js" charset="utf-8"></script>
|
|
54
|
+
</body>
|
|
55
|
+
|
|
56
56
|
</html>`;
|
|
57
57
|
}
|
|
58
58
|
compileIndexHead(frontendModules) {
|
|
59
|
-
return `
|
|
60
|
-
<meta charset="UTF-8">
|
|
61
|
-
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
62
|
-
<meta name="apple-mobile-web-app-capable" content="yes">
|
|
59
|
+
return `
|
|
60
|
+
<meta charset="UTF-8">
|
|
61
|
+
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
62
|
+
<meta name="apple-mobile-web-app-capable" content="yes">
|
|
63
63
|
<title>${this.pck.props.frontend.config.applicationName}</title>`;
|
|
64
64
|
}
|
|
65
65
|
compileIndexJs(frontendModules, frontendPreloadModules) {
|
|
66
|
-
return `\
|
|
67
|
-
// @ts-check
|
|
68
|
-
${this.ifBrowser("require('es6-promise/auto');")}
|
|
69
|
-
require('reflect-metadata');
|
|
70
|
-
require('setimmediate');
|
|
71
|
-
const { Container } = require('inversify');
|
|
72
|
-
const { FrontendApplicationConfigProvider } = require('@theia/core/lib/browser/frontend-application-config-provider');
|
|
73
|
-
|
|
74
|
-
FrontendApplicationConfigProvider.set(${this.prettyStringify(this.pck.props.frontend.config)});
|
|
75
|
-
|
|
76
|
-
${this.ifMonaco(() => `
|
|
77
|
-
self.MonacoEnvironment = {
|
|
78
|
-
getWorkerUrl: function (moduleId, label) {
|
|
79
|
-
return './editor.worker.js';
|
|
80
|
-
}
|
|
81
|
-
}`)}
|
|
82
|
-
|
|
83
|
-
function load(container, jsModule) {
|
|
84
|
-
return Promise.resolve(jsModule)
|
|
85
|
-
.then(containerModule => container.load(containerModule.default));
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
async function preload(container) {
|
|
89
|
-
try {
|
|
90
|
-
${Array.from(frontendPreloadModules.values(), jsModulePath => `\
|
|
91
|
-
await load(container, ${this.importOrRequire()}('${jsModulePath}'));`).join(os_1.EOL)}
|
|
92
|
-
const { Preloader } = require('@theia/core/lib/browser/preload/preloader');
|
|
93
|
-
const preloader = container.get(Preloader);
|
|
94
|
-
await preloader.initialize();
|
|
95
|
-
} catch (reason) {
|
|
96
|
-
console.error('Failed to run preload scripts.');
|
|
97
|
-
if (reason) {
|
|
98
|
-
console.error(reason);
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
module.exports = (async () => {
|
|
66
|
+
return `\
|
|
67
|
+
// @ts-check
|
|
68
|
+
${this.ifBrowser("require('es6-promise/auto');")}
|
|
69
|
+
require('reflect-metadata');
|
|
70
|
+
require('setimmediate');
|
|
71
|
+
const { Container } = require('inversify');
|
|
72
|
+
const { FrontendApplicationConfigProvider } = require('@theia/core/lib/browser/frontend-application-config-provider');
|
|
73
|
+
|
|
74
|
+
FrontendApplicationConfigProvider.set(${this.prettyStringify(this.pck.props.frontend.config)});
|
|
75
|
+
|
|
76
|
+
${this.ifMonaco(() => `
|
|
77
|
+
self.MonacoEnvironment = {
|
|
78
|
+
getWorkerUrl: function (moduleId, label) {
|
|
79
|
+
return './editor.worker.js';
|
|
80
|
+
}
|
|
81
|
+
}`)}
|
|
82
|
+
|
|
83
|
+
function load(container, jsModule) {
|
|
84
|
+
return Promise.resolve(jsModule)
|
|
85
|
+
.then(containerModule => container.load(containerModule.default));
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
async function preload(container) {
|
|
89
|
+
try {
|
|
90
|
+
${Array.from(frontendPreloadModules.values(), jsModulePath => `\
|
|
91
|
+
await load(container, ${this.importOrRequire()}('${jsModulePath}'));`).join(os_1.EOL)}
|
|
92
|
+
const { Preloader } = require('@theia/core/lib/browser/preload/preloader');
|
|
93
|
+
const preloader = container.get(Preloader);
|
|
94
|
+
await preloader.initialize();
|
|
95
|
+
} catch (reason) {
|
|
96
|
+
console.error('Failed to run preload scripts.');
|
|
97
|
+
if (reason) {
|
|
98
|
+
console.error(reason);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
module.exports = (async () => {
|
|
104
104
|
const { messagingFrontendModule } = require('@theia/core/lib/${this.pck.isBrowser() || this.pck.isBrowserOnly()
|
|
105
105
|
? 'browser/messaging/messaging-frontend-module'
|
|
106
|
-
: 'electron-browser/messaging/electron-messaging-frontend-module'}');
|
|
107
|
-
const container = new Container();
|
|
108
|
-
container.load(messagingFrontendModule);
|
|
109
|
-
${this.ifBrowserOnly(`const { messagingFrontendOnlyModule } = require('@theia/core/lib/browser-only/messaging/messaging-frontend-only-module');
|
|
110
|
-
container.load(messagingFrontendOnlyModule);`)}
|
|
111
|
-
|
|
112
|
-
await preload(container);
|
|
113
|
-
|
|
114
|
-
${this.ifMonaco(() => `
|
|
115
|
-
const { MonacoInit } = require('@theia/monaco/lib/browser/monaco-init');
|
|
116
|
-
`)};
|
|
117
|
-
|
|
118
|
-
const { FrontendApplication } = require('@theia/core/lib/browser');
|
|
119
|
-
const { frontendApplicationModule } = require('@theia/core/lib/browser/frontend-application-module');
|
|
120
|
-
const { loggerFrontendModule } = require('@theia/core/lib/browser/logger-frontend-module');
|
|
121
|
-
|
|
122
|
-
container.load(frontendApplicationModule);
|
|
123
|
-
${this.pck.ifBrowserOnly(`const { frontendOnlyApplicationModule } = require('@theia/core/lib/browser-only/frontend-only-application-module');
|
|
124
|
-
container.load(frontendOnlyApplicationModule);`)}
|
|
125
|
-
|
|
126
|
-
container.load(loggerFrontendModule);
|
|
127
|
-
${this.ifBrowserOnly(`const { loggerFrontendOnlyModule } = require('@theia/core/lib/browser-only/logger-frontend-only-module');
|
|
128
|
-
container.load(loggerFrontendOnlyModule);`)}
|
|
129
|
-
|
|
130
|
-
try {
|
|
131
|
-
${Array.from(frontendModules.values(), jsModulePath => `\
|
|
132
|
-
await load(container, ${this.importOrRequire()}('${jsModulePath}'));`).join(os_1.EOL)}
|
|
133
|
-
${this.ifMonaco(() => `
|
|
134
|
-
MonacoInit.init(container);
|
|
135
|
-
`)};
|
|
136
|
-
await start();
|
|
137
|
-
} catch (reason) {
|
|
138
|
-
console.error('Failed to start the frontend application.');
|
|
139
|
-
if (reason) {
|
|
140
|
-
console.error(reason);
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
function start() {
|
|
145
|
-
(window['theia'] = window['theia'] || {}).container = container;
|
|
146
|
-
return container.get(FrontendApplication).start();
|
|
147
|
-
}
|
|
148
|
-
})();
|
|
106
|
+
: 'electron-browser/messaging/electron-messaging-frontend-module'}');
|
|
107
|
+
const container = new Container();
|
|
108
|
+
container.load(messagingFrontendModule);
|
|
109
|
+
${this.ifBrowserOnly(`const { messagingFrontendOnlyModule } = require('@theia/core/lib/browser-only/messaging/messaging-frontend-only-module');
|
|
110
|
+
container.load(messagingFrontendOnlyModule);`)}
|
|
111
|
+
|
|
112
|
+
await preload(container);
|
|
113
|
+
|
|
114
|
+
${this.ifMonaco(() => `
|
|
115
|
+
const { MonacoInit } = require('@theia/monaco/lib/browser/monaco-init');
|
|
116
|
+
`)};
|
|
117
|
+
|
|
118
|
+
const { FrontendApplication } = require('@theia/core/lib/browser');
|
|
119
|
+
const { frontendApplicationModule } = require('@theia/core/lib/browser/frontend-application-module');
|
|
120
|
+
const { loggerFrontendModule } = require('@theia/core/lib/browser/logger-frontend-module');
|
|
121
|
+
|
|
122
|
+
container.load(frontendApplicationModule);
|
|
123
|
+
${this.pck.ifBrowserOnly(`const { frontendOnlyApplicationModule } = require('@theia/core/lib/browser-only/frontend-only-application-module');
|
|
124
|
+
container.load(frontendOnlyApplicationModule);`)}
|
|
125
|
+
|
|
126
|
+
container.load(loggerFrontendModule);
|
|
127
|
+
${this.ifBrowserOnly(`const { loggerFrontendOnlyModule } = require('@theia/core/lib/browser-only/logger-frontend-only-module');
|
|
128
|
+
container.load(loggerFrontendOnlyModule);`)}
|
|
129
|
+
|
|
130
|
+
try {
|
|
131
|
+
${Array.from(frontendModules.values(), jsModulePath => `\
|
|
132
|
+
await load(container, ${this.importOrRequire()}('${jsModulePath}'));`).join(os_1.EOL)}
|
|
133
|
+
${this.ifMonaco(() => `
|
|
134
|
+
MonacoInit.init(container);
|
|
135
|
+
`)};
|
|
136
|
+
await start();
|
|
137
|
+
} catch (reason) {
|
|
138
|
+
console.error('Failed to start the frontend application.');
|
|
139
|
+
if (reason) {
|
|
140
|
+
console.error(reason);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
function start() {
|
|
145
|
+
(window['theia'] = window['theia'] || {}).container = container;
|
|
146
|
+
return container.get(FrontendApplication).start();
|
|
147
|
+
}
|
|
148
|
+
})();
|
|
149
149
|
`;
|
|
150
150
|
}
|
|
151
151
|
importOrRequire() {
|
|
@@ -153,59 +153,59 @@ ${Array.from(frontendModules.values(), jsModulePath => `\
|
|
|
153
153
|
}
|
|
154
154
|
/** HTML for secondary windows that contain an extracted widget. */
|
|
155
155
|
compileSecondaryWindowHtml() {
|
|
156
|
-
return `<!DOCTYPE html>
|
|
157
|
-
<html lang="en">
|
|
158
|
-
|
|
159
|
-
<head>
|
|
160
|
-
<meta charset="UTF-8">
|
|
161
|
-
<title>Theia — Secondary Window</title>
|
|
162
|
-
<style>
|
|
163
|
-
html, body {
|
|
164
|
-
overflow: hidden;
|
|
165
|
-
-ms-overflow-style: none;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
body {
|
|
169
|
-
margin: 0;
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
html,
|
|
173
|
-
head,
|
|
174
|
-
body,
|
|
175
|
-
.secondary-widget-root,
|
|
176
|
-
#widget-host {
|
|
177
|
-
width: 100% !important;
|
|
178
|
-
height: 100% !important;
|
|
179
|
-
}
|
|
180
|
-
</style>
|
|
181
|
-
<link rel="stylesheet" href="./secondary-window.css">
|
|
182
|
-
</head>
|
|
183
|
-
|
|
184
|
-
<body>
|
|
185
|
-
<div id="widget-host"></div>
|
|
186
|
-
</body>
|
|
187
|
-
|
|
156
|
+
return `<!DOCTYPE html>
|
|
157
|
+
<html lang="en">
|
|
158
|
+
|
|
159
|
+
<head>
|
|
160
|
+
<meta charset="UTF-8">
|
|
161
|
+
<title>Theia — Secondary Window</title>
|
|
162
|
+
<style>
|
|
163
|
+
html, body {
|
|
164
|
+
overflow: hidden;
|
|
165
|
+
-ms-overflow-style: none;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
body {
|
|
169
|
+
margin: 0;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
html,
|
|
173
|
+
head,
|
|
174
|
+
body,
|
|
175
|
+
.secondary-widget-root,
|
|
176
|
+
#widget-host {
|
|
177
|
+
width: 100% !important;
|
|
178
|
+
height: 100% !important;
|
|
179
|
+
}
|
|
180
|
+
</style>
|
|
181
|
+
<link rel="stylesheet" href="./secondary-window.css">
|
|
182
|
+
</head>
|
|
183
|
+
|
|
184
|
+
<body>
|
|
185
|
+
<div id="widget-host"></div>
|
|
186
|
+
</body>
|
|
187
|
+
|
|
188
188
|
</html>`;
|
|
189
189
|
}
|
|
190
190
|
compileSecondaryIndexJs(secondaryWindowModules) {
|
|
191
|
-
return `\
|
|
192
|
-
// @ts-check
|
|
193
|
-
require('reflect-metadata');
|
|
194
|
-
const { Container } = require('inversify');
|
|
195
|
-
|
|
196
|
-
module.exports = Promise.resolve().then(() => {
|
|
197
|
-
const { frontendApplicationModule } = require('@theia/core/lib/browser/frontend-application-module');
|
|
198
|
-
const container = new Container();
|
|
199
|
-
container.load(frontendApplicationModule);
|
|
200
|
-
${Array.from(secondaryWindowModules.values(), jsModulePath => `\
|
|
201
|
-
container.load(require('${jsModulePath}').default);`).join(os_1.EOL)}
|
|
202
|
-
});
|
|
191
|
+
return `\
|
|
192
|
+
// @ts-check
|
|
193
|
+
require('reflect-metadata');
|
|
194
|
+
const { Container } = require('inversify');
|
|
195
|
+
|
|
196
|
+
module.exports = Promise.resolve().then(() => {
|
|
197
|
+
const { frontendApplicationModule } = require('@theia/core/lib/browser/frontend-application-module');
|
|
198
|
+
const container = new Container();
|
|
199
|
+
container.load(frontendApplicationModule);
|
|
200
|
+
${Array.from(secondaryWindowModules.values(), jsModulePath => `\
|
|
201
|
+
container.load(require('${jsModulePath}').default);`).join(os_1.EOL)}
|
|
202
|
+
});
|
|
203
203
|
`;
|
|
204
204
|
}
|
|
205
205
|
compilePreloadJs() {
|
|
206
|
-
return `\
|
|
207
|
-
// @ts-check
|
|
208
|
-
${Array.from(this.pck.preloadModules.values(), path => `require('${path}').preload();`).join(os_1.EOL)}
|
|
206
|
+
return `\
|
|
207
|
+
// @ts-check
|
|
208
|
+
${Array.from(this.pck.preloadModules.values(), path => `require('${path}').preload();`).join(os_1.EOL)}
|
|
209
209
|
`;
|
|
210
210
|
}
|
|
211
211
|
}
|