123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- /// <reference types="vite/client" />
- /// <reference types="vite-plugin-svgr/client" />
- import "./assets/styles/index.scss";
- import { ResizeObserver } from "@juggle/resize-observer";
- if (!window.ResizeObserver) {
- window.ResizeObserver = ResizeObserver;
- }
- import React from "react";
- import { createRoot } from "react-dom/client";
- import { ComposeContextProvider } from "foxact/compose-context-provider";
- import { BrowserRouter } from "react-router-dom";
- import { BaseErrorBoundary } from "./components/base";
- import Layout from "./pages/_layout";
- import "./services/i18n";
- import {
- LoadingCacheProvider,
- ThemeModeProvider,
- UpdateStateProvider,
- } from "./services/states";
- const mainElementId = "root";
- const container = document.getElementById(mainElementId);
- if (!container) {
- throw new Error(
- `No container '${mainElementId}' found to render application`
- );
- }
- document.addEventListener("keydown", (event) => {
- // Disable WebView keyboard shortcuts
- const disabledShortcuts =
- ["F5", "F7"].includes(event.key) ||
- (event.altKey && ["ArrowLeft", "ArrowRight"].includes(event.key)) ||
- ((event.ctrlKey || event.metaKey) &&
- ["F", "G", "H", "J", "P", "Q", "R", "U"].includes(
- event.key.toUpperCase()
- ));
- disabledShortcuts && event.preventDefault();
- });
- const contexts = [
- <ThemeModeProvider />,
- <LoadingCacheProvider />,
- <UpdateStateProvider />,
- ];
- createRoot(container).render(
- <React.StrictMode>
- <ComposeContextProvider contexts={contexts}>
- <BaseErrorBoundary>
- <BrowserRouter>
- <Layout />
- </BrowserRouter>
- </BaseErrorBoundary>
- </ComposeContextProvider>
- </React.StrictMode>
- );
|