Skip to content

Commit

Permalink
refactor: refund address input
Browse files Browse the repository at this point in the history
  • Loading branch information
jackstar12 committed Jan 12, 2025
1 parent 2b820b6 commit 24b5fc1
Showing 1 changed file with 58 additions and 66 deletions.
124 changes: 58 additions & 66 deletions src/components/RefundButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,15 +3,7 @@ import { OutputType } from "boltz-core";
import { Signature, TransactionResponse } from "ethers";
import { Network as LiquidNetwork } from "liquidjs-lib/src/networks";
import log from "loglevel";
import {
Accessor,
Match,
Setter,
Show,
Switch,
createResource,
createSignal,
} from "solid-js";
import { Accessor, Setter, Show, createResource, createSignal } from "solid-js";
import { ChainSwap, SubmarineSwap } from "src/utils/swapCreator";

import RefundEta from "../components/RefundEta";
Expand Down Expand Up @@ -136,14 +128,15 @@ export const RefundBtc = (props: {
const input = evt.currentTarget as HTMLInputElement;
const inputValue = input.value.trim();

setRefundAddress(inputValue);

const lockupAddress =
props.swap().type === SwapType.Submarine
? (props.swap() as SubmarineSwap).address
: (props.swap() as ChainSwap).lockupDetails.lockupAddress;

if (inputValue === lockupAddress) {
log.debug("refunds to lockup address are blocked");
input.setCustomValidity("lockup address");
return false;
}
try {
Expand All @@ -152,14 +145,12 @@ export const RefundBtc = (props: {
getNetwork(asset) as LiquidNetwork,
);
input.setCustomValidity("");
setRefundAddress(inputValue);
return true;
} catch (e) {
log.debug("parsing refund address failed", e);
input.setCustomValidity("invalid address");
return false;
}

return false;
};

const refundAction = async () => {
Expand Down Expand Up @@ -235,62 +226,63 @@ export const RefundBtc = (props: {
return transactionToRefund;
});

const buttonMessage = () => {
if (lockupTransaction.state == "errored") {
return t("no_lockup_transaction");
}
if (valid() || !refundAddress() || !props.swap()) {
return t("refund");
}
return t("invalid_address", { asset: props.swap()?.assetSend });
};

return (
<Switch>
<Match
when={
lockupTransaction.state === "ready" ||
lockupTransaction.state == "unresolved"
}>
<Show when={timeoutEta() > 0 || timeoutBlockheight() > 0}>
<RefundEta
timeoutEta={timeoutEta}
timeoutBlockHeight={timeoutBlockheight}
/>
</Show>
<h3 style={{ color: "#fff" }}>
{props.swap()
? t("refund_address_header", {
<Show
when={
lockupTransaction.state === "ready" ||
lockupTransaction.state == "unresolved" ||
lockupTransaction.state == "errored"
}
fallback={<LoadingSpinner />}>
<Show when={timeoutEta() > 0 || timeoutBlockheight() > 0}>
<RefundEta
timeoutEta={timeoutEta}
timeoutBlockHeight={timeoutBlockheight}
/>
</Show>
<h3 style={{ color: "#fff" }}>
{props.swap()
? t("refund_address_header", {
asset: props.swap()?.assetSend,
})
: t("refund_address_header_no_asset")}
</h3>
<input
data-testid="refundAddress"
id="refundAddress"
disabled={lockupTransaction.state == "errored"}
value={refundAddress()}
onInput={(e) =>
setValid(refundAddressChange(e, props.swap()?.assetSend))
}
type="text"
name="refundAddress"
placeholder={
props.swap()
? t("onchain_address", {
asset: props.swap()?.assetSend,
})
: t("refund_address_header_no_asset")}
</h3>
<input
data-testid="refundAddress"
id="refundAddress"
disabled={props.swap() === null}
onInput={(e) =>
setValid(
refundAddressChange(e, props.swap()?.assetSend),
)
}
type="text"
name="refundAddress"
placeholder={
props.swap()
? t("onchain_address", {
asset: props.swap()?.assetSend,
})
: t("onchain_address_no_asset")
}
/>
<button
data-testid="refundButton"
class="btn"
disabled={!valid() || refundRunning()}
onClick={() => refundAction()}>
{props.buttonOverride ?? t("refund")}
</button>
</Match>
<Match when={lockupTransaction.state === "pending"}>
<LoadingSpinner />
</Match>
<Match when={lockupTransaction.state === "errored"}>
<button class="btn" disabled={true}>
{t("no_lockup_transaction")}
</button>
</Match>
</Switch>
: t("onchain_address_no_asset")
}
/>
<button
data-testid="refundButton"
class="btn"
disabled={!valid() || refundRunning()}
onClick={() => refundAction()}>
{props.buttonOverride ?? buttonMessage()}
</button>
</Show>
);
};

Expand Down

0 comments on commit 24b5fc1

Please sign in to comment.