main.tsx 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. /// <reference types="vite/client" />
  2. /// <reference types="vite-plugin-svgr/client" />
  3. import "./assets/styles/index.scss";
  4. import { ResizeObserver } from "@juggle/resize-observer";
  5. if (!window.ResizeObserver) {
  6. window.ResizeObserver = ResizeObserver;
  7. }
  8. import React from "react";
  9. import { createRoot } from "react-dom/client";
  10. import { ComposeContextProvider } from "foxact/compose-context-provider";
  11. import { BrowserRouter } from "react-router-dom";
  12. import { BaseErrorBoundary } from "./components/base";
  13. import Layout from "./pages/_layout";
  14. import "./services/i18n";
  15. import {
  16. LoadingCacheProvider,
  17. ThemeModeProvider,
  18. UpdateStateProvider,
  19. } from "./services/states";
  20. const mainElementId = "root";
  21. const container = document.getElementById(mainElementId);
  22. if (!container) {
  23. throw new Error(
  24. `No container '${mainElementId}' found to render application`
  25. );
  26. }
  27. document.addEventListener("keydown", (event) => {
  28. // Disable WebView keyboard shortcuts
  29. const disabledShortcuts =
  30. ["F5", "F7"].includes(event.key) ||
  31. (event.altKey && ["ArrowLeft", "ArrowRight"].includes(event.key)) ||
  32. ((event.ctrlKey || event.metaKey) &&
  33. ["F", "G", "H", "J", "P", "Q", "R", "U"].includes(
  34. event.key.toUpperCase()
  35. ));
  36. disabledShortcuts && event.preventDefault();
  37. });
  38. const contexts = [
  39. <ThemeModeProvider />,
  40. <LoadingCacheProvider />,
  41. <UpdateStateProvider />,
  42. ];
  43. createRoot(container).render(
  44. <React.StrictMode>
  45. <ComposeContextProvider contexts={contexts}>
  46. <BaseErrorBoundary>
  47. <BrowserRouter>
  48. <Layout />
  49. </BrowserRouter>
  50. </BaseErrorBoundary>
  51. </ComposeContextProvider>
  52. </React.StrictMode>
  53. );