Skip to content

Commit 48c0539

Browse files
authored
Add splash screen before starting backend finished (#216)
1 parent 550857c commit 48c0539

File tree

3 files changed

+119
-1
lines changed

3 files changed

+119
-1
lines changed

core/electron-libs/core.js

Lines changed: 24 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ const processes = [];
3030
* @type BrowserWindow
3131
*/
3232
let mainWindow = null;
33+
let splashWindow = null;
3334

3435
async function cleanUpProcesses() {
3536
for (const process of processes) {
@@ -49,9 +50,14 @@ async function cleanUpProcesses() {
4950
}
5051

5152
function startService() {
53+
createSplashWindow();
54+
5255
if (inDevMode()) {
5356
global.backendPort = 9091;
54-
windowsManager.createWindow();
57+
setTimeout(function () {
58+
splashWindow.close();
59+
windowsManager.createWindow();
60+
}, 1000);
5561
return;
5662
}
5763

@@ -70,6 +76,7 @@ function startService() {
7076
process.stdout.on('data', data => {
7177
if (data.includes(`Tomcat started on port(s): ${port}`)) {
7278
console.log(`Tomcat is now started on port ${port}`);
79+
splashWindow.close();
7380
windowsManager.createWindow();
7481
}
7582
});
@@ -93,6 +100,22 @@ function startService() {
93100
});
94101
}
95102

103+
function createSplashWindow() {
104+
splashWindow = new BrowserWindow({
105+
width: 800,
106+
height: 600,
107+
frame: false,
108+
alwaysOnTop: true,
109+
transparent: true,
110+
});
111+
112+
const splashScreenPath = inDevMode()
113+
? path.join('.', 'electron-libs', 'loading-screen')
114+
: path.join(__dirname, '..', '..', '..', 'loading-screen');
115+
116+
splashWindow.loadFile(`${splashScreenPath}${path.sep}splash.html`).catch(() => console.log('Splash screen not found.'));
117+
}
118+
96119
module.exports = {
97120
mainWindow,
98121
cleanUpProcesses,
Lines changed: 74 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,74 @@
1+
<!--
2+
~ Copyright (c) 2024 Robert Bosch Manufacturing Solutions GmbH
3+
~
4+
~ See the AUTHORS file(s) distributed with this work for
5+
~ additional information regarding authorship.
6+
~
7+
~ This Source Code Form is subject to the terms of the Mozilla Public
8+
~ License, v. 2.0. If a copy of the MPL was not distributed with this
9+
~ file, You can obtain one at https://mozilla.org/MPL/2.0/.
10+
~
11+
~ SPDX-License-Identifier: MPL-2.0
12+
-->
13+
14+
<!doctype html>
15+
<html>
16+
<head>
17+
<title>Loading...</title>
18+
<style>
19+
body {
20+
background-color: #f9f9f9;
21+
display: flex;
22+
justify-content: center;
23+
align-items: center;
24+
height: 100vh;
25+
margin: 0;
26+
font-family: Arial, sans-serif;
27+
flex-direction: column;
28+
}
29+
30+
.loader {
31+
border: 16px solid #f3f3f3;
32+
border-radius: 50%;
33+
border-top: 16px solid #3498db;
34+
width: 50px;
35+
height: 50px;
36+
animation: spin 2s linear infinite;
37+
}
38+
39+
.text {
40+
margin-top: 20px;
41+
margin-bottom: 50px;
42+
font-size: 20px;
43+
display: flex;
44+
align-items: center;
45+
}
46+
47+
.text img {
48+
width: 50px;
49+
height: 50px;
50+
margin-left: 10px;
51+
margin-right: 10px;
52+
}
53+
54+
@keyframes spin {
55+
0% {
56+
transform: rotate(0deg);
57+
}
58+
100% {
59+
transform: rotate(360deg);
60+
}
61+
}
62+
</style>
63+
</head>
64+
<body>
65+
<p class="text">
66+
<img
67+
src=""
68+
alt="Aspect Model Editor Icon"
69+
/>
70+
Loading Aspect Model Editor...
71+
</p>
72+
<div class="loader"></div>
73+
</body>
74+
</html>

core/package.json

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,13 @@
3737
"filter": [
3838
"**/*"
3939
]
40+
},
41+
{
42+
"from": "./electron-libs/loading-screen/",
43+
"to": "loading-screen/",
44+
"filter": [
45+
"**/*"
46+
]
4047
}
4148
]
4249
},
@@ -69,6 +76,13 @@
6976
"filter": [
7077
"**/*"
7178
]
79+
},
80+
{
81+
"from": "./electron-libs/loading-screen/",
82+
"to": "loading-screen/",
83+
"filter": [
84+
"**/*"
85+
]
7286
}
7387
]
7488
},
@@ -101,6 +115,13 @@
101115
"filter": [
102116
"**/*"
103117
]
118+
},
119+
{
120+
"from": "./electron-libs/loading-screen/",
121+
"to": "loading-screen/",
122+
"filter": [
123+
"**/*"
124+
]
104125
}
105126
]
106127
},

0 commit comments

Comments
 (0)