Skip to content

Commit

Permalink
feat: add error page
Browse files Browse the repository at this point in the history
fix: use i18n

chore: logs

chore: changeset
  • Loading branch information
liviuciulinaru committed Jan 3, 2025
1 parent 8d2cf10 commit 74ce7a7
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 8 deletions.
5 changes: 5 additions & 0 deletions .changeset/honest-badgers-develop.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"live-mobile": minor
---

LLM add error page
6 changes: 6 additions & 0 deletions apps/ledger-live-mobile/src/locales/en/common.json
Original file line number Diff line number Diff line change
Expand Up @@ -1019,6 +1019,12 @@
"ScannedNewImportQrCode": {
"title": "Update required",
"description": "To sync your apps, please make sure both are updated to the latest version."
},
"AppManifestUnknownError": {
"title": "Swap Live App not found"
},
"AppManifestNotFoundError": {
"title": "Failed to load Swap Live App"
}
},
"crash": {
Expand Down
8 changes: 5 additions & 3 deletions apps/ledger-live-mobile/src/screens/Swap/LiveApp/WebView.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,18 @@
import React from "react";
import { LiveAppManifest } from "@ledgerhq/live-common/platform/types";
import React from "react";
import TabBarSafeAreaView from "~/components/TabBar/TabBarSafeAreaView";
import { Web3AppWebview } from "~/components/Web3AppWebview";
import { WebviewState } from "~/components/Web3AppWebview/types";

type Props = {
manifest: LiveAppManifest;
setWebviewState: React.Dispatch<React.SetStateAction<WebviewState>>;
};

export function WebView({ manifest }: Props) {
export function WebView({ manifest, setWebviewState }: Props) {
return (
<TabBarSafeAreaView>
<Web3AppWebview manifest={manifest} customHandlers={{}} />
<Web3AppWebview manifest={manifest} customHandlers={{}} onStateChange={setWebviewState} />
</TabBarSafeAreaView>
);
}
22 changes: 17 additions & 5 deletions apps/ledger-live-mobile/src/screens/Swap/LiveApp/index.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React from "react";
import React, { useState } from "react";

import {
useRemoteLiveAppContext,
Expand All @@ -7,27 +7,39 @@ import {
import { LiveAppManifest } from "@ledgerhq/live-common/platform/types";
import { useLocalLiveAppManifest } from "@ledgerhq/live-common/wallet-api/LocalLiveAppProvider/index";
import { Flex, InfiniteLoader } from "@ledgerhq/native-ui";
import { useTranslation } from "react-i18next";
import GenericErrorView from "~/components/GenericErrorView";
import TabBarSafeAreaView from "~/components/TabBar/TabBarSafeAreaView";
import { initialWebviewState } from "~/components/Web3AppWebview/helpers";
import { WebviewState } from "~/components/Web3AppWebview/types";
import { WebView } from "./WebView";

const DEFAULT_SWAP_APP_ID = "swap-live-app-demo-3";
const APP_MANIFEST_NOT_FOUND_ERROR = new Error("Swap Live App not found");

export function SwapLiveApp() {
const { t } = useTranslation();

const APP_MANIFEST_NOT_FOUND_ERROR = new Error(t("errors.AppManifestUnknown.title"));
const APP_MANIFEST_UNKNOWN_ERROR = new Error(t("errors.AppManifestNotFoundError.title"));

const localManifest: LiveAppManifest | undefined = useLocalLiveAppManifest(DEFAULT_SWAP_APP_ID);
const remoteManifest: LiveAppManifest | undefined = useRemoteLiveAppManifest(DEFAULT_SWAP_APP_ID);
const { state: remoteLiveAppState } = useRemoteLiveAppContext();

const [webviewState, setWebviewState] = useState<WebviewState>(initialWebviewState);
const isWebviewError = webviewState?.url.includes("/unknown-error");

const manifest: LiveAppManifest | undefined = !localManifest ? remoteManifest : localManifest;

if (!manifest) {
if (!manifest || isWebviewError) {
return (
<Flex flex={1} p={10} justifyContent="center" alignItems="center">
{remoteLiveAppState.isLoading ? (
<InfiniteLoader />
) : (
<GenericErrorView error={APP_MANIFEST_NOT_FOUND_ERROR} />
<GenericErrorView
error={isWebviewError ? APP_MANIFEST_UNKNOWN_ERROR : APP_MANIFEST_NOT_FOUND_ERROR}
/>
)}
</Flex>
);
Expand All @@ -36,7 +48,7 @@ export function SwapLiveApp() {
return (
<>
<TabBarSafeAreaView>
<WebView manifest={manifest} />
<WebView manifest={manifest} setWebviewState={setWebviewState} />
</TabBarSafeAreaView>
</>
);
Expand Down

0 comments on commit 74ce7a7

Please sign in to comment.