Compare commits

..

1 Commits

Author SHA1 Message Date
valerio
a3bf261682 FEAT: Splash Screen
todo: loading status and percent
2026-03-23 19:57:20 +01:00
2 changed files with 82 additions and 31 deletions

View File

@ -0,0 +1,34 @@
<script>
let { loadingState } = $props();
</script>
<div class="splash">
{#if loadingState == 'loading'}
<div class="spinner">
<pre class="monospace">
▄▄▄▄▄
██▀▀▀▀█▄ █▄ █▄
▀██▄ ▄▀ ▄ ▄██▄██ ▀▀
▀██▄▄ ███▄███▄ ▄███▄ ▄███▄ ██ ████▄ ██ ▄█▀█▄
▄ ▀██▄ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██▄█▀
▀██████▀▄██ ██ ▀█▄▀███▀▄▀███▀▄██▄██ ██▄██▄▀█▄▄▄
</pre>
</div>
{/if}
</div>
<style>
.splash {
align-items: center;
justify-content: center;
display: flex;
width: 100%;
height: 100%;
}
.spinner {
}
.monospace {
font-family: monospace;
color: var(--black);
}
</style>

View File

@ -1,28 +1,38 @@
<script> <script>
import '@webtui/css/components/spinner.css'; // LIBS
import { setupTrayIcon } from '$lib/trayicon'; import { getVersion } from '@tauri-apps/api/app';
import { fade } from 'svelte/transition';
import { onMount } from 'svelte'; import { onMount } from 'svelte';
import { getSettings, currentSettings } from '$lib/settings.js'; import { fade } from 'svelte/transition';
import '@webtui/css/components/spinner.css';
// MODULES
import { setupTrayIcon } from '$lib/trayicon';
import { getSettings, currentSettings } from '$lib/settings';
import { getInstalledVersions, currentInstalledVersions } from '$lib/library';
import { getBlenderReleases, blenderReleases } from '$lib/blenderfetch'; import { getBlenderReleases, blenderReleases } from '$lib/blenderfetch';
import { getInstalledVersions, currentInstalledVersions } from '$lib/library.js'; import { downloadTasksStore } from '$lib/download';
import { downloadTasksStore } from '$lib/download.js';
// COMPONENTS
import Library from '$lib/components/Library.svelte'; import Library from '$lib/components/Library.svelte';
import Download from '$lib/components/Download.svelte'; import Download from '$lib/components/Download.svelte';
import Settings from '$lib/components/Settings.svelte'; import Settings from '$lib/components/Settings.svelte';
import Popup from '$lib/components/Popup.svelte'; import Popup from '$lib/components/Popup.svelte';
import Dialog from '$lib/components/Dialog.svelte'; import Dialog from '$lib/components/Dialog.svelte';
import Splash from '$lib/components/Splash.svelte';
// states
let fadeInSettings = { duration: 100 }; let fadeInSettings = { duration: 100 };
let fadeOutSettings = { duration: 100, delay: fadeInSettings.duration }; let fadeOutSettings = { duration: 100, delay: fadeInSettings.duration };
let activeTab = 'library'; let activeTab = $state('library');
let blenderVersions = []; let blenderVersions = $state([]);
let installedVersions = []; let installedVersions = $state([]);
let downloadTasks = []; let downloadTasks = $state([]);
let settings = {}; let settings = $state();
let initialized = false; let initialized = $state(false);
let version = $state('');
let loadingState = $state('loading'); // load, update, initialized
function initStoresListeners() { async function initStoresListeners() {
currentSettings.subscribe((value) => { currentSettings.subscribe((value) => {
settings = value; settings = value;
console.log('Loaded settings:', settings); console.log('Loaded settings:', settings);
@ -42,26 +52,13 @@
} }
onMount(async () => { onMount(async () => {
const startTime = Date.now(); version = await getVersion();
await getSettings(); await getSettings();
await getBlenderReleases(); await getBlenderReleases();
await getInstalledVersions(); await getInstalledVersions();
await setupTrayIcon(); await setupTrayIcon();
await initStoresListeners();
initStoresListeners(); loadingState = 'initialized';
const elapsed = Date.now() - startTime;
if (elapsed < 2000) {
initialized = true;
/* setTimeout(() => {
initialized = true;
}, 2000 - elapsed);*/
} else {
initialized = true;
}
//await getInstalledVersions();
//
}); });
</script> </script>
@ -69,7 +66,7 @@
<Dialog /> <Dialog />
<div id="main"> <div id="main">
{#if initialized} {#if loadingState == 'initialized'}
<div class="tablist" role="tablist"> <div class="tablist" role="tablist">
<div <div
role="tab" role="tab"
@ -122,8 +119,11 @@
{/if} {/if}
</div> </div>
</div> </div>
<div class="version">v{version}</div>
{:else} {:else}
LOADING... <div class="splash-wrapper" in:fade={{ duration: 100 }} out:fade={{ delay: 50, duration: 200 }}>
<Splash {loadingState} />
</div>
{/if} {/if}
</div> </div>
@ -207,4 +207,21 @@
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.version {
position: fixed;
bottom: 2rem;
right: 2rem;
z-index: 2;
text-align: right;
color: var(--light-accent);
}
.splash-wrapper {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: var(--white);
z-index: 1;
}
</style> </style>