2021-12-29 13:18:48 +01:00
|
|
|
<script context="module" lang="ts">
|
|
|
|
declare const Neutralino;
|
|
|
|
</script>
|
2021-12-29 14:59:55 +02:00
|
|
|
|
2021-12-29 14:02:12 +02:00
|
|
|
<script lang="ts">
|
|
|
|
import { onMount } from 'svelte';
|
|
|
|
import { _, locale } from 'svelte-i18n';
|
|
|
|
|
2021-12-29 14:56:54 +02:00
|
|
|
import Configs from './ts/Configs';
|
2022-01-01 23:40:26 +02:00
|
|
|
import IPC from './ts/core/IPC';
|
2021-12-29 14:56:54 +02:00
|
|
|
|
2021-12-29 14:02:12 +02:00
|
|
|
import Window from './ts/neutralino/Window';
|
|
|
|
|
2021-12-29 14:56:54 +02:00
|
|
|
import Splash from './assets/gifs/running-qiqi.gif';
|
|
|
|
import SplashSecret from './assets/gifs/loading-marie-please.gif';
|
|
|
|
|
|
|
|
const splash = Math.round(Math.random() * 100) < 100 ? Splash : SplashSecret;
|
2021-12-29 14:02:12 +02:00
|
|
|
|
|
|
|
let phrase = Math.round(Math.random() * 2);
|
|
|
|
|
|
|
|
onMount(() => {
|
|
|
|
Window.current.show();
|
|
|
|
});
|
|
|
|
|
|
|
|
const isLauncherLoaded = () => {
|
2022-01-01 23:57:50 +02:00
|
|
|
IPC.read().then(async (records) => {
|
2022-01-01 23:40:26 +02:00
|
|
|
const launcherLoaded = records.filter((record) => record.data === 'launcher-loaded');
|
|
|
|
|
|
|
|
if (launcherLoaded.length > 0)
|
|
|
|
{
|
2022-01-01 23:57:50 +02:00
|
|
|
for (const record of launcherLoaded)
|
|
|
|
await record.pop();
|
2021-12-29 14:02:12 +02:00
|
|
|
|
|
|
|
Window.current.hide();
|
|
|
|
|
|
|
|
Neutralino.app.exit();
|
2022-01-01 23:40:26 +02:00
|
|
|
}
|
|
|
|
|
2022-01-05 23:27:00 +02:00
|
|
|
else setTimeout(isLauncherLoaded, 500);
|
2022-01-01 23:40:26 +02:00
|
|
|
});
|
2021-12-29 14:02:12 +02:00
|
|
|
};
|
|
|
|
|
2022-01-05 23:27:00 +02:00
|
|
|
Neutralino.events.on('ready', () => isLauncherLoaded());
|
2021-12-29 14:02:12 +02:00
|
|
|
|
|
|
|
Neutralino.events.on('windowClose', () => {
|
|
|
|
Neutralino.app.exit();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Auto theme switcher
|
2021-12-29 14:56:54 +02:00
|
|
|
Configs.get('theme').then((theme) => {
|
|
|
|
if (theme === 'system')
|
|
|
|
theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
|
|
|
|
|
|
|
|
document.body.setAttribute('data-theme', theme as string);
|
|
|
|
});
|
2021-12-29 14:02:12 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
{#if typeof $locale === 'string'}
|
|
|
|
<main>
|
2021-12-29 14:56:54 +02:00
|
|
|
<img src={splash} alt="" />
|
2021-12-29 14:02:12 +02:00
|
|
|
|
|
|
|
<h2>{$_('splash.title')}</h2>
|
|
|
|
<p>{$_(`splash.phrases.${phrase}`)}</p>
|
|
|
|
</main>
|
|
|
|
{/if}
|