1 import { isAuthPath, setIsoData } from "@utils/app";
2 import { dataBsTheme } from "@utils/browser";
3 import { Component, RefObject, createRef, linkEvent } from "inferno";
4 import { Provider } from "inferno-i18next-dess";
5 import { Route, Switch } from "inferno-router";
6 import { IsoDataOptionalSite } from "../../interfaces";
7 import { routes } from "../../routes";
8 import { FirstLoadService, I18NextService, UserService } from "../../services";
9 import AuthGuard from "../common/auth-guard";
10 import ErrorGuard from "../common/error-guard";
11 import { ErrorPage } from "./error-page";
12 import { Footer } from "./footer";
13 import { Navbar } from "./navbar";
14 import "./styles.scss";
15 import { Theme } from "./theme";
17 export class App extends Component<any, any> {
18 private isoData: IsoDataOptionalSite = setIsoData(this.context);
19 private readonly mainContentRef: RefObject<HTMLElement>;
20 constructor(props: any, context: any) {
21 super(props, context);
22 this.mainContentRef = createRef();
25 handleJumpToContent(event) {
26 event.preventDefault();
27 this.mainContentRef.current?.focus();
30 user = UserService.Instance.myUserInfo;
33 this.setState({ bsTheme: dataBsTheme(this.user) });
37 const siteRes = this.isoData.site_res;
38 const siteView = siteRes?.site_view;
42 <Provider i18next={I18NextService.i18n}>
45 className="lemmy-site"
46 data-bs-theme={this.state?.bsTheme}
50 className="btn skip-link bg-light position-absolute start-0 z-3"
51 onClick={linkEvent(this, this.handleJumpToContent)}
53 {I18NextService.i18n.t("jump_to_content", "Jump to content")}
56 <Theme defaultTheme={siteView.local_site.default_theme} />
58 <Navbar siteRes={siteRes} />
59 <div className="mt-4 p-0 fl-1">
62 ({ path, component: RouteComponent, fetchInitialData }) => (
67 component={routeProps => {
68 if (!fetchInitialData) {
69 FirstLoadService.falsify();
76 (isAuthPath(path ?? "") ? (
78 <RouteComponent {...routeProps} />
81 <RouteComponent {...routeProps} />
90 <Route component={ErrorPage} />
93 <Footer site={siteRes} />