Skip to content

Commit

Permalink
refactor: more cleanup
Browse files Browse the repository at this point in the history
  • Loading branch information
fbwoolf committed Dec 13, 2024
1 parent dbf7a7a commit d85cfc1
Show file tree
Hide file tree
Showing 17 changed files with 75 additions and 172 deletions.
2 changes: 1 addition & 1 deletion config/wallet-config.json
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@
"enabled": true,
"contracts": {
"mainnet": {
"address": "currently-unknown"
"address": "SM3VDXK3WZZSA84XXFKAFAF15NNZX32CTSG82JFQ4.sbtc-token::sbtc-token"
},
"testnet": {
"address": "SNGWPN3XDAQE673MXYXF81016M50NHF5X5PWWM70.sbtc-token::sbtc-token"
Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -248,7 +248,7 @@
"redux-persist": "6.0.0",
"remark-gfm": "4.0.0",
"rxjs": "7.8.1",
"sbtc": "0.2.4",
"sbtc": "0.2.5",
"style-loader": "3.3.4",
"ts-debounce": "4.0.0",
"url": "0.11.3",
Expand Down
10 changes: 5 additions & 5 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,6 @@ export function SbtcDepositTransactionItem({ deposit }: SbtcDepositTransactionIt
openTxLink={openTxLink}
txCaption={truncateMiddle(deposit.bitcoinTxid, 4)}
txIcon={
// Replace with sBTC avatar icon
<Avatar.Root>
<Avatar.Image alt="ST" src={SbtcAvatarIconSrc} />
</Avatar.Root>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ export function Sip10TokenAssetItem({
const { isTokenEnabled } = useManageTokens();

const { contractId, imageCanonicalUri, name, symbol } = info;
// This can be removed once an img is available directly from the sip10 token
const isSbtc = symbol === 'sBTC';

const icon = (
Expand Down
5 changes: 4 additions & 1 deletion src/app/pages/home/home.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import { useTotalBalance } from '@app/common/hooks/balance/use-total-balance';
import { useOnMount } from '@app/common/hooks/use-on-mount';
import { useSwitchAccountSheet } from '@app/common/switch-account/use-switch-account-sheet-context';
import { whenPageMode } from '@app/common/utils';
import { openInNewTab } from '@app/common/utils/open-in-new-tab';
import { ActivityList } from '@app/features/activity-list/activity-list';
import { FeedbackButton } from '@app/features/feedback-button/feedback-button';
import { SbtcPromoCard } from '@app/features/sbtc-promo-card/sbtc-promo-card';
Expand All @@ -27,6 +28,8 @@ import { AccountCard } from '@app/ui/components/account/account.card';
import { AccountActions } from './components/account-actions';
import { HomeTabs } from './components/home-tabs';

const leatherEarnUrl = 'https://earn.leather.io';

export function Home() {
const { decodedAuthRequest } = useOnboardingState();
const { toggleSwitchAccount } = useSwitchAccountSheet();
Expand Down Expand Up @@ -76,7 +79,7 @@ export function Home() {
>
<AccountActions />
</AccountCard>
<SbtcPromoCard mt="space.05" onClick={() => navigate('test-deposit-sbtc')} />
<SbtcPromoCard mt="space.05" onClick={() => openInNewTab(leatherEarnUrl)} />
</Box>
{whenPageMode({ full: <FeedbackButton />, popup: null })}
<HomeTabs>
Expand Down
5 changes: 2 additions & 3 deletions src/app/pages/swap/bitflow-swap-container.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -77,10 +77,9 @@ function BitflowSwapContainer() {
onSetSwapSubmissionData({
...swapData,
fee: satToBtc(sBtcDepositData?.fee ?? 0).toNumber(),
txData: sBtcDepositData?.deposit,
txData: { deposit: sBtcDepositData?.deposit },
});
swapNavigate(RouteUrls.SwapReview);
return;
return swapNavigate(RouteUrls.SwapReview);
}

const routeQuote = await fetchRouteQuote(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import {
import type { SwapFormValues } from '@shared/models/form.model';
import { RouteUrls } from '@shared/route-urls';

// import { bitflow } from '@shared/utils/bitflow-sdk';
import { useSwapContext } from '@app/pages/swap/swap.context';

import type { SwapAssetListProps } from './swap-asset-list';
Expand All @@ -29,13 +28,6 @@ export function useSwapAssetList({ assets, type }: SwapAssetListProps) {
const isBaseList = type === 'base';
const isQuoteList = type === 'quote';

// async function getBtcToken() {
// // const tokens = await bitflow.getAvailableTokens();
// // console.log(tokens.filter(token => token.tokenId === 'token-xbtc'));
// const result = await bitflow.getQuoteForRoute('token-stx', 'token-xbtc', 1);
// console.log(result);
// }

// Filter out selected asset from selectable assets
const selectableAssets = assets
.filter(
Expand Down Expand Up @@ -77,9 +69,8 @@ export function useSwapAssetList({ assets, type }: SwapAssetListProps) {

const onFetchQuoteAmount = useCallback(
async (baseAsset: SwapAsset, quoteAsset: SwapAsset) => {
// await getBtcToken();
const quoteAmount = await fetchQuoteAmount(baseAsset, quoteAsset, values.swapAmountBase);
// Handle race condition; make sure quote amount is 1:1 for BTC swap
// Handle race condition; make sure quote amount is 1:1
if (baseAsset.name === 'BTC') {
void setFieldValue('swapAmountQuote', values.swapAmountBase);
return;
Expand Down
17 changes: 10 additions & 7 deletions src/app/pages/swap/hooks/use-bitcoin-bridge-assets.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,10 @@ import { createMoney, getPrincipalFromContractId } from '@leather.io/utils';

import { castBitcoinMarketDataToSbtcMarketData } from '@app/common/hooks/use-calculate-sip10-fiat-value';
import { useBtcCryptoAssetBalanceNativeSegwit } from '@app/query/bitcoin/balance/btc-balance-native-segwit.hooks';
import { useConfigSbtc } from '@app/query/common/remote-config/remote-config.query';
import { useCurrentAccountNativeSegwitIndexZeroSigner } from '@app/store/accounts/blockchain/bitcoin/native-segwit-account.hooks';
import { useCurrentStacksAccountAddress } from '@app/store/accounts/blockchain/stacks/stacks-account.hooks';
import { useCurrentNetwork } from '@app/store/networks/networks.selectors';

export function useBtcSwapAsset() {
const nativeSegwitSigner = useCurrentAccountNativeSegwitIndexZeroSigner();
Expand All @@ -36,13 +38,14 @@ export function useBtcSwapAsset() {
}, [balance.availableBalance, bitcoinMarketData]);
}

// Testnet only
const tempContractIdForSbtcTesting =
'SNGWPN3XDAQE673MXYXF81016M50NHF5X5PWWM70.sbtc-token::sbtc-token';

export function useSbtcSwapAsset() {
const stxAddress = useCurrentStacksAccountAddress();
const token = useSip10Token(stxAddress, tempContractIdForSbtcTesting);
const { contractIdMainnet, contractIdTestnet } = useConfigSbtc();
const network = useCurrentNetwork();
const contractId =
network.chain.bitcoin.mode === 'mainnet' ? contractIdMainnet : contractIdTestnet;

const token = useSip10Token(stxAddress, contractId);
const bitcoinMarketData = useCryptoCurrencyMarketDataMeanAverage('BTC');

return useCallback((): SwapAsset => {
Expand All @@ -54,7 +57,7 @@ export function useSbtcSwapAsset() {
icon: SbtcAvatarIconSrc,
name: 'sBTC',
marketData: castBitcoinMarketDataToSbtcMarketData(bitcoinMarketData),
principal: getPrincipalFromContractId(token?.info.contractId ?? ''),
principal: getPrincipalFromContractId(contractId),
};
}, [bitcoinMarketData, token?.balance.availableBalance, token?.info.contractId]);
}, [bitcoinMarketData, contractId, token?.balance.availableBalance]);
}
14 changes: 2 additions & 12 deletions src/app/pages/swap/hooks/use-bitflow-swap.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -44,20 +44,10 @@ export function useBitflowSwap() {
baseAmount: string
): Promise<RouteQuote | undefined> => {
if (!baseAmount || !base || !quote || isCrossChainSwap) return;
let baseTokenId = base.tokenId;
let quoteTokenId = quote.tokenId;
// Temporarily handle sBTC exchange rate; force as BTC
// TODO: Remove once Bitflow supports sBTC exchange rate
if (base.tokenId === 'token-sbtc') {
baseTokenId = 'token-xbtc';
}
if (quote.tokenId === 'token-sbtc') {
quoteTokenId = 'token-xbtc';
}
try {
const result = await bitflow.getQuoteForRoute(
baseTokenId,
quoteTokenId,
base.tokenId,
quote.tokenId,
Number(baseAmount)
);
if (!result.bestRoute) {
Expand Down
29 changes: 25 additions & 4 deletions src/app/pages/swap/hooks/use-sbtc-deposit-transaction.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,18 @@
/* eslint-disable */
// TODO: Enable eslint and remove test logs
import { useMemo } from 'react';
import { useNavigate } from 'react-router-dom';

import * as btc from '@scure/btc-signer';
import type { P2TROut } from '@scure/btc-signer/payment';
import { MAINNET, REGTEST, SbtcApiClientTestnet, TESTNET, buildSbtcDepositTx } from 'sbtc';
import {
MAINNET,
REGTEST,
SbtcApiClient,
SbtcApiClientTestnet,
TESTNET,
buildSbtcDepositTx,
} from 'sbtc';

import type { BitcoinNetworkModes } from '@leather.io/models';
import { useAverageBitcoinFeeRates } from '@leather.io/query';
Expand All @@ -24,6 +33,7 @@ import { useCurrentNetwork } from '@app/store/networks/networks.selectors';

import type { SwapSubmissionData } from '../swap.context';

// Suggested to use as defaults
const maxSignerFee = 80_000;
const reclaimLockTime = 6_000;

Expand All @@ -35,9 +45,6 @@ interface SbtcDeposit {
trOut: P2TROut;
}

// Check network for correct client
const client = new SbtcApiClientTestnet();

function getSbtcNetworkConfig(network: BitcoinNetworkModes) {
const networkMap = {
mainnet: MAINNET,
Expand All @@ -49,6 +56,15 @@ function getSbtcNetworkConfig(network: BitcoinNetworkModes) {
return networkMap[network];
}

// TODO: Set config paths, or likely remove when defaults are published
const clientMainnet = new SbtcApiClient({
sbtcContract: '',
btcApiUrl: '',
stxApiUrl: '',
sbtcApiUrl: '',
});
const clientTestnet = new SbtcApiClientTestnet();

export function useSbtcDepositTransaction() {
const toast = useToast();
const { setIsIdle } = useLoading(LoadingKeys.SUBMIT_SWAP_TRANSACTION);
Expand All @@ -60,6 +76,11 @@ export function useSbtcDepositTransaction() {
const navigate = useNavigate();
const network = useCurrentNetwork();

const client = useMemo(
() => (network.chain.bitcoin.mode === 'mainnet' ? clientMainnet : clientTestnet),
[network]
);

// Check if the signer is compliant
useBreakOnNonCompliantEntity();

Expand Down
109 changes: 0 additions & 109 deletions src/app/pages/test-deposit-sbtc/test-deposit-sbtc.tsx

This file was deleted.

7 changes: 5 additions & 2 deletions src/app/query/common/remote-config/remote-config.query.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,12 +42,15 @@ export function useConfigBitcoinSendEnabled() {

export function useConfigSbtc() {
const config = useRemoteConfig();
// TODO: Update with new mono version
const sbtc = config?.sbtc;
const network = useCurrentNetwork();
const sbtc = config?.sbtc;

return useMemo(() => {
const displayPromoCardOnNetworks = (sbtc as any)?.showPromoLinkOnNetworks ?? [];
return {
enabled: sbtc?.enabled ?? false,
contractIdMainnet: sbtc?.contracts.mainnet.address ?? '',
contractIdTestnet: sbtc?.contracts.testnet.address ?? '',
isSbtcContract(contract: string) {
return (
contract === getPrincipalFromContractId(sbtc?.contracts.mainnet.address ?? '') ||
Expand Down
Loading

0 comments on commit d85cfc1

Please sign in to comment.