]> Untitled Git - lemmy-ui.git/blobdiff - src/shared/components/app/error-page.tsx
Merge branch 'main' into fix/fix-badges-spacing-componentize
[lemmy-ui.git] / src / shared / components / app / error-page.tsx
index 12472dd15a2a67e305b1a45fbed57407b43ae7ed..e083276e07fcf3eeac97a28f6cf3b53bc3255a16 100644 (file)
@@ -1,7 +1,10 @@
+import { setIsoData } from "@utils/app";
+import { removeAuthParam } from "@utils/helpers";
 import { Component } from "inferno";
+import { T } from "inferno-i18next-dess";
 import { Link } from "inferno-router";
-import { IsoDataOptionalSite } from "shared/interfaces";
-import { setIsoData } from "../../utils";
+import { IsoDataOptionalSite } from "../../interfaces";
+import { I18NextService } from "../../services";
 
 export class ErrorPage extends Component<any, any> {
   private isoData: IsoDataOptionalSite = setIsoData(this.context);
@@ -14,36 +17,34 @@ export class ErrorPage extends Component<any, any> {
     const { errorPageData } = this.isoData;
 
     return (
-      <div className="container-lg text-center">
-        <h1>{errorPageData ? "Error!" : "Page Not Found"}</h1>
-        <p className="p-4">
-          {errorPageData ? (
-            <>
-              <span>
-                There was an error on the server. Try refreshing your browser.
-                If that doesn&apos;t work, come back at a later time. If the
-                problem persists,
-              </span>{" "}
-              <a href="https://github.com/LemmyNet/lemmy/issues">
-                consider opening an issue.
-              </a>
-            </>
-          ) : (
-            "The page you are looking for does not exist."
-          )}
-        </p>
+      <div className="error-page container-lg text-center">
+        <h1>
+          {errorPageData
+            ? I18NextService.i18n.t("error_page_title")
+            : I18NextService.i18n.t("not_found_page_title")}
+        </h1>
+        {errorPageData ? (
+          <T i18nKey="error_page_paragraph" className="p-4" parent="p">
+            #<a href="https://lemmy.ml/c/lemmy_support">#</a>#
+            <a href="https://matrix.to/#/#lemmy-space:matrix.org">#</a>#
+          </T>
+        ) : (
+          <p>{I18NextService.i18n.t("not_found_page_message")}</p>
+        )}
         {!errorPageData && (
           <Link to="/" replace>
-            Click here to return to your home page.
+            {I18NextService.i18n.t("not_found_return_home_button")}
           </Link>
         )}
         {errorPageData?.adminMatrixIds &&
           errorPageData.adminMatrixIds.length > 0 && (
             <>
               <div>
-                If you would like to reach out to one of{" "}
-                {this.isoData.site_res?.site_view.site.name ?? "this instance"}
-                &apos;s admins for support, try the following Matrix addresses:
+                {I18NextService.i18n.t("error_page_admin_matrix", {
+                  instance:
+                    this.isoData.site_res?.site_view.site.name ??
+                    "this instance",
+                })}
               </div>
               <ul className="mx-auto mt-2" style={{ width: "fit-content" }}>
                 {errorPageData.adminMatrixIds.map(matrixId => (
@@ -55,12 +56,13 @@ export class ErrorPage extends Component<any, any> {
             </>
           )}
         {errorPageData?.error && (
-          <code
-            style={{ "text-align": "start" }}
-            className="d-block bg-dark text-light p-2 mt-4"
+          <T
+            i18nKey="error_code_message"
+            parent="p"
+            interpolation={{ error: removeAuthParam(errorPageData.error) }}
           >
-            {errorPageData.error}
-          </code>
+            #<strong className="text-danger">#</strong>#
+          </T>
         )}
       </div>
     );