Skip to content

Commit

Permalink
fix: account addresses separator
Browse files Browse the repository at this point in the history
  • Loading branch information
alter-eggo committed Dec 23, 2024
1 parent 281d3a5 commit 54bd421
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 18 deletions.
14 changes: 6 additions & 8 deletions src/app/components/account/account-addresses.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,20 @@ import { HStack } from 'leather-styles/jsx';
import { BulletSeparator, Caption } from '@leather.io/ui';
import { truncateMiddle } from '@leather.io/utils';

import { BitcoinNativeSegwitAccountLoader } from '../loaders/bitcoin-account-loader';
import { StacksAccountLoader } from '../loaders/stacks-account-loader';
import { useBitcoinNativeSegwitAccountLoader } from '../loaders/bitcoin-account-loader';
import { useStacksAccountLoader } from '../loaders/stacks-account-loader';

interface AccountAddressesProps {
index: number;
}
export function AcccountAddresses({ index }: AccountAddressesProps) {
const account = useStacksAccountLoader({ index });
const signer = useBitcoinNativeSegwitAccountLoader({ index });
return (
<HStack alignItems="center" gap="space.02" whiteSpace="nowrap">
<BulletSeparator>
<StacksAccountLoader index={index}>
{account => <Caption>{truncateMiddle(account.address, 4)}</Caption>}
</StacksAccountLoader>
<BitcoinNativeSegwitAccountLoader index={index}>
{signer => <Caption>{truncateMiddle(signer.address, 4)}</Caption>}
</BitcoinNativeSegwitAccountLoader>
{account ? <Caption>{truncateMiddle(account.address, 4)}</Caption> : null}
{signer ? <Caption>{truncateMiddle(signer.address, 4)}</Caption> : null}
</BulletSeparator>
</HStack>
);
Expand Down
23 changes: 16 additions & 7 deletions src/app/components/loaders/bitcoin-account-loader.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { P2Ret } from '@scure/btc-signer/payment';
import type { DistributiveOmit } from 'leather-styles/types';

import { useConfigBitcoinEnabled } from '@app/query/common/remote-config/remote-config.query';
import { useCurrentAccountIndex } from '@app/store/accounts/account';
Expand All @@ -20,11 +21,9 @@ interface BtcAccountLoaderIndexProps extends BitcoinAccountLoaderBaseProps {

type BtcAccountLoaderProps = BtcAccountLoaderCurrentProps | BtcAccountLoaderIndexProps;

export function BitcoinNativeSegwitAccountLoader({
children,
fallback,
...props
}: BtcAccountLoaderProps) {
export function useBitcoinNativeSegwitAccountLoader(
props: DistributiveOmit<BtcAccountLoaderProps, 'children' | 'fallback'>
) {
const isBitcoinEnabled = useConfigBitcoinEnabled();

const currentAccountIndex = useCurrentAccountIndex();
Expand All @@ -33,8 +32,18 @@ export function BitcoinNativeSegwitAccountLoader({

const signer = useNativeSegwitSigner(properIndex);

if (!signer || !isBitcoinEnabled) return fallback;
return children(signer(0));
if (!signer || !isBitcoinEnabled) return null;
return signer(0);
}

export function BitcoinNativeSegwitAccountLoader({
children,
fallback,
...props
}: BtcAccountLoaderProps) {
const signer = useBitcoinNativeSegwitAccountLoader(props);
if (!signer) return fallback;
return children(signer);
}

export function BitcoinTaprootAccountLoader({ children, ...props }: BtcAccountLoaderProps) {
Expand Down
8 changes: 6 additions & 2 deletions src/app/components/loaders/stacks-account-loader.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { ReactNode } from 'react';

import type { DistributiveOmit } from 'leather-styles/types';

import { useCurrentAccountIndex } from '@app/store/accounts/account';
import {
useCurrentStacksAccount,
Expand Down Expand Up @@ -34,12 +36,14 @@ interface StacksAccountIndexLoaderProps extends StacksAccountBaseLoaderProps {

type StacksAccountLoaderProps = StacksAccountCurrentLoaderProps | StacksAccountIndexLoaderProps;

export function StacksAccountLoader({ children, ...props }: StacksAccountLoaderProps) {
export function useStacksAccountLoader(
props: DistributiveOmit<StacksAccountLoaderProps, 'children'>
) {
const stacksAccounts = useStacksAccounts();
const currentAccountIndex = useCurrentAccountIndex();
const properIndex = 'current' in props ? currentAccountIndex : props.index;

const account = stacksAccounts[properIndex];
if (!account) return null;
return children(account);
return account;
}
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ export function ConnectLedgerButton({ chain }: ConnectLedgerButtonProps) {
};

return (
<Button variant="outline" onClick={onClick}>
<Button variant="outline" size="sm" onClick={onClick}>
<HStack>
<LedgerIcon />
<styled.span textStyle="label.02">Connect&nbsp;{capitalize(chain)}</styled.span>
Expand Down

0 comments on commit 54bd421

Please sign in to comment.