2023-03-19 17:01:08 +00:00
|
|
|
import "core-js/stable";
|
2023-03-19 19:53:44 +00:00
|
|
|
import React, { Suspense } from "react";
|
2023-09-01 13:37:03 +00:00
|
|
|
import type { ReactNode } from "react";
|
2022-02-16 20:30:12 +00:00
|
|
|
import ReactDOM from "react-dom";
|
2023-10-14 17:28:27 +00:00
|
|
|
import { HelmetProvider } from "react-helmet-async";
|
2023-02-19 15:05:19 +00:00
|
|
|
import { BrowserRouter, HashRouter } from "react-router-dom";
|
2023-02-24 19:12:20 +00:00
|
|
|
import { registerSW } from "virtual:pwa-register";
|
2023-01-07 20:36:18 +00:00
|
|
|
|
2023-04-24 15:41:54 +00:00
|
|
|
import { ErrorBoundary } from "@/components/layout/ErrorBoundary";
|
2023-01-07 20:36:18 +00:00
|
|
|
import App from "@/setup/App";
|
2023-10-21 20:14:54 +00:00
|
|
|
import { conf } from "@/setup/config";
|
2023-06-18 12:10:26 +00:00
|
|
|
import i18n from "@/setup/i18n";
|
2023-04-24 15:41:54 +00:00
|
|
|
|
2023-02-21 20:45:14 +00:00
|
|
|
import "@/setup/ga";
|
2023-01-07 20:36:18 +00:00
|
|
|
import "@/setup/index.css";
|
2023-01-25 20:44:15 +00:00
|
|
|
import { initializeChromecast } from "./setup/chromecast";
|
2023-06-18 12:10:26 +00:00
|
|
|
import { SettingsStore } from "./state/settings/store";
|
2023-02-11 23:41:55 +00:00
|
|
|
import { initializeStores } from "./utils/storage";
|
2022-12-29 17:25:57 +00:00
|
|
|
|
|
|
|
// initialize
|
|
|
|
const key =
|
|
|
|
(window as any)?.__CONFIG__?.VITE_KEY ?? import.meta.env.VITE_KEY ?? null;
|
|
|
|
if (key) {
|
2023-02-22 20:41:13 +00:00
|
|
|
(window as any).initMW(conf().PROXY_URLS, key);
|
2022-12-29 17:25:57 +00:00
|
|
|
}
|
2023-01-25 20:44:15 +00:00
|
|
|
initializeChromecast();
|
2023-02-24 19:12:20 +00:00
|
|
|
registerSW({
|
2023-03-19 17:01:08 +00:00
|
|
|
immediate: true,
|
2023-02-24 19:12:20 +00:00
|
|
|
});
|
2021-07-13 22:31:37 +00:00
|
|
|
|
2023-02-11 23:41:55 +00:00
|
|
|
const LazyLoadedApp = React.lazy(async () => {
|
|
|
|
await initializeStores();
|
2023-06-18 12:10:26 +00:00
|
|
|
i18n.changeLanguage(SettingsStore.get().language ?? "en");
|
2023-02-11 23:41:55 +00:00
|
|
|
return {
|
|
|
|
default: App,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2023-02-19 15:05:19 +00:00
|
|
|
function TheRouter(props: { children: ReactNode }) {
|
|
|
|
const normalRouter = conf().NORMAL_ROUTER;
|
2023-02-19 17:03:54 +00:00
|
|
|
|
|
|
|
if (normalRouter) return <BrowserRouter>{props.children}</BrowserRouter>;
|
|
|
|
return <HashRouter>{props.children}</HashRouter>;
|
2023-02-19 15:05:19 +00:00
|
|
|
}
|
|
|
|
|
2021-07-13 22:31:37 +00:00
|
|
|
ReactDOM.render(
|
2022-02-16 20:30:12 +00:00
|
|
|
<React.StrictMode>
|
|
|
|
<ErrorBoundary>
|
2023-10-14 17:28:27 +00:00
|
|
|
<HelmetProvider>
|
|
|
|
<TheRouter>
|
|
|
|
<Suspense fallback="">
|
|
|
|
<LazyLoadedApp />
|
|
|
|
</Suspense>
|
|
|
|
</TheRouter>
|
|
|
|
</HelmetProvider>
|
2022-02-16 20:30:12 +00:00
|
|
|
</ErrorBoundary>
|
|
|
|
</React.StrictMode>,
|
|
|
|
document.getElementById("root")
|
2021-07-13 22:31:37 +00:00
|
|
|
);
|