Skip to content

Commit

Permalink
Merge pull request #333 from hyperlane-xyz/rossy/migration-fixes
Browse files Browse the repository at this point in the history
- Fix errors in TransfersDetailsModal when metadata is missing
- Remove dead code in consts/values
- Avoid cosmoshub inclusion in chain picker
- Simplify footer links markup
  • Loading branch information
jmrossy authored Nov 20, 2024
2 parents 2a66df3 + e685bad commit f678adb
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 34 deletions.
15 changes: 5 additions & 10 deletions src/components/nav/Footer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -52,26 +52,21 @@ function FooterLogo() {

function FooterNav() {
return (
<nav className="flex text-md font-medium">
<ul className={`${styles.linkGrid}`}>
<nav className="text-md font-medium">
<ul style={{ gridTemplateColumns: 'auto auto auto' }} className="grid gap-x-7 gap-y-1.5">
{footerLinks.map((item) => (
<li key={item.title}>
<Link
className={styles.linkItem}
className="flex items-center capitalize underline-offset-2 hover:underline"
target={item.external ? '_blank' : '_self'}
href={item.url}
>
{item?.icon && <div className="mr-4 w-5">{item?.icon}</div>}
<div className="">{item.title}</div>
{item?.icon && <div className="mr-3 mt-1 w-4">{item?.icon}</div>}
{!item?.icon && <div>{item.title}</div>}
</Link>
</li>
))}
</ul>
</nav>
);
}

const styles = {
linkGrid: 'grid grid-cols-3 gap-x-6 gap-y-1.5',
linkItem: 'flex items-center capitalize text-decoration-none hover:underline underline-offset-2',
};
7 changes: 0 additions & 7 deletions src/consts/values.ts

This file was deleted.

7 changes: 1 addition & 6 deletions src/features/chains/metadata.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
import {
IRegistry,
cosmoshub,
chainMetadata as publishedChainMetadata,
} from '@hyperlane-xyz/registry';
import { IRegistry, chainMetadata as publishedChainMetadata } from '@hyperlane-xyz/registry';
import {
ChainMap,
ChainMetadata,
Expand All @@ -23,7 +19,6 @@ export async function assembleChainMetadata(
) {
// Chains must include a cosmos chain or CosmosKit throws errors
const result = z.record(ChainMetadataSchema).safeParse({
cosmoshub,
...ChainsYaml,
...ChainsTS,
});
Expand Down
2 changes: 1 addition & 1 deletion src/features/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ async function initWarpContext(
) {
try {
const coreConfig = await assembleWarpCoreConfig();
const chainsInTokens = coreConfig.tokens.map((t) => t.chainName);
const chainsInTokens = Array.from(new Set(coreConfig.tokens.map((t) => t.chainName)));
// Pre-load registry content to avoid repeated requests
await registry.listRegistryContent();
const { chainMetadata, chainMetadataWithOverrides } = await assembleChainMetadata(
Expand Down
11 changes: 6 additions & 5 deletions src/features/transfer/TransfersDetailsModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ import {
} from '../../utils/transfer';
import { useMultiProvider } from '../chains/hooks';
import { getChainDisplayName, hasPermissionlessChain } from '../chains/utils';
import { useWarpCore } from '../tokens/hooks';
import { tryFindToken, useWarpCore } from '../tokens/hooks';
import { TransferContext, TransferStatus } from './types';

export function TransfersDetailsModal({
Expand Down Expand Up @@ -58,7 +58,10 @@ export function TransfersDetailsModal({
} = transfer || {};

const multiProvider = useMultiProvider();
const account = useAccountForChain(multiProvider, origin);
const warpCore = useWarpCore();

const isChainKnown = multiProvider.hasChain(origin);
const account = useAccountForChain(multiProvider, isChainKnown ? origin : undefined);
const walletDetails = useWalletDetails()[account?.protocol || ProtocolType.Ethereum];

const getMessageUrls = useCallback(async () => {
Expand Down Expand Up @@ -87,10 +90,8 @@ export function TransfersDetailsModal({

const isAccountReady = !!account?.isReady;
const connectorName = walletDetails.name || 'wallet';
const token = useWarpCore().findToken(origin, originTokenAddressOrDenom);

const token = tryFindToken(warpCore, origin, originTokenAddressOrDenom);
const isPermissionlessRoute = hasPermissionlessChain(multiProvider, [destination, origin]);

const isSent = isTransferSent(status);
const isFailed = isTransferFailed(status);
const isFinal = isSent || isFailed;
Expand Down
12 changes: 7 additions & 5 deletions src/features/wallet/context/CosmosWalletContext.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ import { wallets as cosmostationWallets } from '@cosmos-kit/cosmostation';
import { wallets as keplrWallets } from '@cosmos-kit/keplr';
import { wallets as leapWallets } from '@cosmos-kit/leap';
import { ChainProvider } from '@cosmos-kit/react';
import { cosmoshub } from '@hyperlane-xyz/registry';
import { MultiProtocolProvider } from '@hyperlane-xyz/sdk';
import { getCosmosKitChainConfigs } from '@hyperlane-xyz/widgets';
import '@interchain-ui/react/styles';
import { PropsWithChildren, useMemo } from 'react';
Expand All @@ -19,11 +21,11 @@ const theme = extendTheme({
});

export function CosmosWalletContext({ children }: PropsWithChildren<unknown>) {
const multiProvider = useMultiProvider();
const { chains, assets } = useMemo(
() => getCosmosKitChainConfigs(multiProvider),
[multiProvider],
);
const chainMetadata = useMultiProvider().metadata;
const { chains, assets } = useMemo(() => {
const multiProvider = new MultiProtocolProvider({ ...chainMetadata, cosmoshub });
return getCosmosKitChainConfigs(multiProvider);
}, [chainMetadata]);
const leapWithoutSnap = leapWallets.filter((wallet) => !wallet.walletName.includes('snap'));
// TODO replace Chakra here with a custom modal for ChainProvider
// Using Chakra + @cosmos-kit/react instead of @cosmos-kit/react-lite adds about 600Kb to the bundle
Expand Down

0 comments on commit f678adb

Please sign in to comment.