Skip to content

Commit

Permalink
feat: show error when QR scanning is not supported in browser (#768)
Browse files Browse the repository at this point in the history
* feat: show error when QR scanning is not supported in browser

* chore: add missing strings

---------

Co-authored-by: Kilian <[email protected]>
  • Loading branch information
michael1011 and kilrau authored Dec 6, 2024
1 parent ef48ad4 commit e64874d
Show file tree
Hide file tree
Showing 3 changed files with 71 additions and 29 deletions.
7 changes: 7 additions & 0 deletions src/i18n/i18n.ts
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,7 @@ const dict = {
will_receive: "Will receive",
refund_available_in: "Refund will be available in {{ blocks }} blocks",
no_wallet_connected: "No wallet connected",
qr_scan_supported: "This browser doesn't support refunds via QR",
},
de: {
language: "Deutsch",
Expand Down Expand Up @@ -462,6 +463,8 @@ const dict = {
will_receive: "Sie erhalten",
refund_available_in: "Rückerstattung möglich in {{ blocks }} Blöcken",
no_wallet_connected: "Kein Wallet verbunden",
qr_scan_supported:
"Dieser Browser unterstützt keine Erstattungen über QR",
},
es: {
language: "Español",
Expand Down Expand Up @@ -695,6 +698,8 @@ const dict = {
will_receive: "Recibirá",
refund_available_in: "Reembolso disponible en {{ blocks }} bloques",
no_wallet_connected: "No hay monedero conectado",
qr_scan_supported:
"Este navegador no admite devoluciones a través de QR",
},
zh: {
language: "中文",
Expand Down Expand Up @@ -902,6 +907,7 @@ const dict = {
will_receive: "将收到",
refund_available_in: "退款将分 {{ blocks }} 区块提供",
no_wallet_connected: "未连接钱包",
qr_scan_supported: "此浏览器不支持通过 QR 退款",
},
ja: {
language: "日本語",
Expand Down Expand Up @@ -1134,6 +1140,7 @@ const dict = {
will_receive: "受信予定",
refund_available_in: "返金は {{ blocks }} つのブロックに分かれる",
no_wallet_connected: "財布はつながっていない!",
qr_scan_supported: "このブラウザはQRによる払い戻しに対応していません。",
},
};

Expand Down
74 changes: 45 additions & 29 deletions src/pages/Refund.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,18 +20,26 @@ import {
LogRefundData,
scanLogsForPossibleRefunds,
} from "../utils/contractLogs";
import { qrScanProbe } from "../utils/qrScanProbe";
import { validateRefundFile } from "../utils/refundFile";
import { SomeSwap } from "../utils/swapCreator";
import ErrorWasm from "./ErrorWasm";

enum RefundError {
InvalidData,
QrScanNotSupported,
}

const Refund = () => {
const navigate = useNavigate();
const { getSwap, getSwaps, updateSwapStatus, wasmSupported, t } =
useGlobalContext();
const { signer, providers, getEtherSwap } = useWeb3Signer();

const [swapFound, setSwapFound] = createSignal(null);
const [refundInvalid, setRefundInvalid] = createSignal(false);
const [refundInvalid, setRefundInvalid] = createSignal<
RefundError | undefined
>(undefined);
const [refundJson, setRefundJson] = createSignal(null);
const [refundTxId, setRefundTxId] = createSignal<string>("");

Expand All @@ -52,47 +60,47 @@ const Refund = () => {
}

setRefundJson(data);
setRefundInvalid(false);
setRefundInvalid(undefined);
} catch (e) {
log.warn("Refund json validation failed", e);
setRefundInvalid(true);
setRefundInvalid(RefundError.InvalidData);
input.setCustomValidity(t("invalid_refund_file"));
}
};

const uploadChange = (e: Event) => {
const uploadChange = async (e: Event) => {
const input = e.currentTarget as HTMLInputElement;
const inputFile = input.files[0];
input.setCustomValidity("");
setRefundJson(null);
setSwapFound(null);
setRefundInvalid(false);
setRefundInvalid(undefined);

if (["image/png", "image/jpg", "image/jpeg"].includes(inputFile.type)) {
QrScanner.scanImage(inputFile, { returnDetailedScanResult: true })
.then(
async (result) =>
await checkRefundJsonKeys(
input,
JSON.parse(result.data),
),
)
.catch((e) => {
log.error("invalid QR code upload", e);
setRefundInvalid(true);
input.setCustomValidity(t("invalid_refund_file"));
if (!(await qrScanProbe())) {
setRefundInvalid(RefundError.QrScanNotSupported);
return;
}

try {
const res = await QrScanner.scanImage(inputFile, {
returnDetailedScanResult: true,
});
await checkRefundJsonKeys(input, JSON.parse(res.data));
} catch (e) {
log.error("invalid QR code upload", e);
setRefundInvalid(RefundError.InvalidData);
input.setCustomValidity(t("invalid_refund_file"));
}
} else {
inputFile
.text()
.then(async (result) => {
await checkRefundJsonKeys(input, JSON.parse(result));
})
.catch((e) => {
log.error("invalid file upload", e);
setRefundInvalid(true);
input.setCustomValidity(t("invalid_refund_file"));
});
try {
const data = await inputFile.text();
await checkRefundJsonKeys(input, JSON.parse(data));
} catch (e) {
log.error("invalid file upload", e);
setRefundInvalid(RefundError.InvalidData);
input.setCustomValidity(t("invalid_refund_file"));
}
}
};

Expand Down Expand Up @@ -249,10 +257,18 @@ const Refund = () => {
{t("open_swap")}
</button>
</Show>
<Show when={refundInvalid()}>
<Show when={refundInvalid() !== undefined}>
<hr />
<button class="btn" disabled={true}>
{t("invalid_refund_file")}
{(() => {
switch (refundInvalid()) {
case RefundError.InvalidData:
return t("invalid_refund_file");

case RefundError.QrScanNotSupported:
return t("qr_scan_supported");
}
})()}
</button>
</Show>
<Show when={refundTxId() === "" && refundJson() !== null}>
Expand Down
19 changes: 19 additions & 0 deletions src/utils/qrScanProbe.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import log from "loglevel";
import QrScanner from "qr-scanner";

import { formatError } from "./errors";

const image =
"";

export const qrScanProbe = async () => {
try {
const res = await QrScanner.scanImage(new URL(image), {
returnDetailedScanResult: true,
});
return res.data === "21";
} catch (e) {
log.warn(`QR code scanning probe failed: ${formatError(e)}`);
return false;
}
};

0 comments on commit e64874d

Please sign in to comment.