dyomedea/src/index.tsx

73 lines
1.8 KiB
TypeScript

/* @refresh reload */
import { render } from 'solid-js/web';
import { Router } from '@solidjs/router';
import {
I18nContext,
createI18nContext,
} from '@solid-primitives/i18n';
import dict from './i18n';
import App from './App';
// See https://stackoverflow.com/questions/71538643/property-wakelock-does-not-exist-on-type-navigator
const requestWakeLock = async () => {
const anyNav: any = navigator;
if ('wakeLock' in navigator) {
try {
const wakeLock = await anyNav['wakeLock'].request('screen');
} catch (err: any) {
// The wake lock request fails - usually system-related, such as low battery.
console.log(`Wake lock request failed: ${err.name}, ${err.message}`);
}
} else {
console.log('No wake lock support here...');
}
};
const handleVisibilityChange = () => {
if (document.hidden) {
console.log('Application hidden');
} else {
console.log('Application visible');
requestWakeLock();
}
};
// See https://developer.mozilla.org/en-US/docs/Web/API/Page_Visibility_API
document.addEventListener('visibilitychange', handleVisibilityChange, false);
requestWakeLock();
const getLanguage = () => {
for (const i in navigator.languages) {
const language = navigator.languages[i];
if (language in dict) {
return language;
}
const shortLanguage = language.slice(0, 2);
if (shortLanguage in dict) {
return shortLanguage;
}
}
return undefined;
};
const i18nDict = createI18nContext(dict, getLanguage());
// const [watchDbStatus] = createWorkerSignal({
// provider: 'watchDb',
// });
// createEffect(() => {
// console.log({ caller: 'createEffect', watchDbStatus: watchDbStatus() });
// });
render(
() => (
<Router>
<I18nContext.Provider value={i18nDict}>
<App />
</I18nContext.Provider>
</Router>
),
document.getElementById('root') as HTMLElement
);