From 11af60a50e8ed801e0cc6677562fd845f797fb7e Mon Sep 17 00:00:00 2001 From: J M Rossy Date: Mon, 25 Nov 2024 16:10:46 -0500 Subject: [PATCH 1/9] chore: More cleanup and stricter lint rules (#337) --- eslint.config.mjs | 9 +++++-- src/components/icons/Identicon.tsx | 41 ------------------------------ src/components/icons/types.ts | 6 ----- src/consts/app.ts | 4 +-- src/features/chains/utils.ts | 8 ------ 5 files changed, 9 insertions(+), 59 deletions(-) delete mode 100644 src/components/icons/Identicon.tsx delete mode 100644 src/components/icons/types.ts diff --git a/eslint.config.mjs b/eslint.config.mjs index 7d570005..54c8e85f 100644 --- a/eslint.config.mjs +++ b/eslint.config.mjs @@ -56,12 +56,18 @@ export default [ }, rules: { + 'camelcase': ['error'], + 'guard-for-in': ['error'], + 'import/no-cycle': ['error'], + 'import/no-self-import': ['error'], 'no-console': ['warn'], 'no-eval': ['error'], 'no-ex-assign': ['error'], 'no-extra-boolean-cast': ['error'], 'no-constant-condition': ['off'], - 'guard-for-in': ['error'], + 'no-multiple-empty-lines': ['error'], + 'jsx-a11y/alt-text': ['off'], + '@typescript-eslint/ban-ts-comment': ['off'], '@typescript-eslint/explicit-module-boundary-types': ['off'], '@typescript-eslint/no-explicit-any': ['off'], @@ -77,7 +83,6 @@ export default [ }, ], - 'jsx-a11y/alt-text': ['off'], '@next/next/no-img-element': ['off'], }, }, diff --git a/src/components/icons/Identicon.tsx b/src/components/icons/Identicon.tsx deleted file mode 100644 index 344b7f3c..00000000 --- a/src/components/icons/Identicon.tsx +++ /dev/null @@ -1,41 +0,0 @@ -import { isValidAddressEvm, normalizeAddressEvm } from '@hyperlane-xyz/utils'; -import { Circle } from '@hyperlane-xyz/widgets'; -import jazzicon from '@metamask/jazzicon'; -import { memo } from 'react'; - -type Props = { - address?: string; - size?: number; -}; - -// This should match metamask: https://github.com/MetaMask/metamask-extension/blob/master/ui/helpers/utils/icon-factory.js#L84 -function addressToSeed(address: string) { - const addrStub = normalizeAddressEvm(address).slice(2, 10); - return parseInt(addrStub, 16); -} - -// TODO move to widgets lib -function _Identicon({ address, size: _size }: Props) { - const size = _size ?? 34; - - // TODO better handling of non-evm addresses here - if (!address || !isValidAddressEvm(address)) { - return ; - } - - const jazziconResult = jazzicon(size, addressToSeed(address)); - - return ( -
{ - if (nodeElement) { - nodeElement.innerHTML = ''; - nodeElement.appendChild(jazziconResult); - } - }} - >
- ); -} - -export const Identicon = memo(_Identicon); diff --git a/src/components/icons/types.ts b/src/components/icons/types.ts deleted file mode 100644 index 71146814..00000000 --- a/src/components/icons/types.ts +++ /dev/null @@ -1,6 +0,0 @@ -import { SVGProps } from 'react'; - -// TODO: Replace with DefaultIconProps in widgets lib -export type IconProps = SVGProps & { - color?: string; -}; diff --git a/src/consts/app.ts b/src/consts/app.ts index 8f7b5a56..2f235bdc 100644 --- a/src/consts/app.ts +++ b/src/consts/app.ts @@ -1,7 +1,7 @@ -import { Space_Grotesk } from 'next/font/google'; +import { Space_Grotesk as SpaceGrotesk } from 'next/font/google'; import { Color } from '../styles/Color'; -export const MAIN_FONT = Space_Grotesk({ +export const MAIN_FONT = SpaceGrotesk({ subsets: ['latin'], variable: '--font-main', preload: true, diff --git a/src/features/chains/utils.ts b/src/features/chains/utils.ts index d67f7d0a..be11c771 100644 --- a/src/features/chains/utils.ts +++ b/src/features/chains/utils.ts @@ -25,14 +25,6 @@ export function hasPermissionlessChain(multiProvider: MultiProtocolProvider, ids return !ids.every((c) => !isPermissionlessChain(multiProvider, c)); } -export function getChainByRpcUrl(multiProvider: MultiProtocolProvider, url?: string) { - if (!url) return undefined; - const allMetadata = Object.values(multiProvider.metadata); - return allMetadata.find( - (m) => !!m.rpcUrls.find((rpc) => rpc.http.toLowerCase().includes(url.toLowerCase())), - ); -} - /** * Returns an object that contains the amount of * routes from a single chain to every other chain From 4868292d1f62f9be648cd33e1e542964d7c63af0 Mon Sep 17 00:00:00 2001 From: Frank <963688200@qq.com> Date: Fri, 29 Nov 2024 09:59:41 +0800 Subject: [PATCH 2/9] feat: Add NEXT_PUBLIC_REGISTRY_BRANCH (#341) --- src/consts/config.ts | 3 +++ src/features/store.ts | 6 +++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/consts/config.ts b/src/consts/config.ts index d46f8ac6..a6bdaac1 100644 --- a/src/consts/config.ts +++ b/src/consts/config.ts @@ -4,6 +4,7 @@ import { ADDRESS_BLACKLIST } from './blacklist'; const isDevMode = process?.env?.NODE_ENV === 'development'; const version = process?.env?.NEXT_PUBLIC_VERSION || '0.0.0'; const registryUrl = process?.env?.NEXT_PUBLIC_REGISTRY_URL || undefined; +const registryBranch = process?.env?.NEXT_PUBLIC_REGISTRY_BRANCH || undefined; const registryProxyUrl = process?.env?.NEXT_PUBLIC_GITHUB_PROXY || 'https://proxy.hyperlane.xyz'; const explorerApiKeys = JSON.parse(process?.env?.EXPLORER_API_KEYS || '{}'); const walletConnectProjectId = process?.env?.NEXT_PUBLIC_WALLET_CONNECT_ID || ''; @@ -18,6 +19,7 @@ interface Config { explorerApiKeys: Record; // Optional map of API keys for block explorer isDevMode: boolean; // Enables some debug features in the app registryUrl: string | undefined; // Optional URL to use a custom registry instead of the published canonical version + registryBranch?: string | undefined; // Optional customization of the registry branch instead of main registryProxyUrl?: string; // Optional URL to use a custom proxy for the GithubRegistry showDisabledTokens: boolean; // Show/Hide invalid token options in the selection modal showTipBox: boolean; // Show/Hide the blue tip box above the transfer form @@ -34,6 +36,7 @@ export const config: Config = Object.freeze({ explorerApiKeys, isDevMode, registryUrl, + registryBranch, registryProxyUrl, showDisabledTokens: false, showTipBox: true, diff --git a/src/features/store.ts b/src/features/store.ts index e634529b..dc90b9a4 100644 --- a/src/features/store.ts +++ b/src/features/store.ts @@ -66,7 +66,11 @@ export const useStore = create()( set({ chainMetadataOverrides: filtered, multiProvider }); }, multiProvider: new MultiProtocolProvider({}), - registry: new GithubRegistry({ uri: config.registryUrl, proxyUrl: config.registryProxyUrl }), + registry: new GithubRegistry({ + uri: config.registryUrl, + branch: config.registryBranch, + proxyUrl: config.registryProxyUrl, + }), warpCore: new WarpCore(new MultiProtocolProvider({}), []), setWarpContext: ({ registry, chainMetadata, multiProvider, warpCore }) => { logger.debug('Setting warp context in store'); From 6d2c88c55769d624c16c68523c4bc8a271a70bbb Mon Sep 17 00:00:00 2001 From: J M Rossy Date: Sat, 30 Nov 2024 14:04:45 -0500 Subject: [PATCH 3/9] chore: Yet more cleanup of dead code / cruft (#344) Discovered during the copy of this codebase to the new deployment app --- README.md | 17 ++--- package.json | 1 - public/logos/cosmos.svg | 1 - public/logos/cosmwasm.svg | 1 - public/logos/solana.svg | 1 - public/logos/weth.png | Bin 2984 -> 0 bytes src/consts/config.ts | 6 -- .../transfer/TransfersDetailsModal.tsx | 10 +-- src/features/transfer/utils.ts | 66 +++++++++++++++++ src/features/wallet/SideBarMenu.tsx | 2 +- src/utils/transfer.ts | 69 ------------------ yarn.lock | 17 ----- 12 files changed, 79 insertions(+), 112 deletions(-) delete mode 100644 public/logos/cosmos.svg delete mode 100644 public/logos/cosmwasm.svg delete mode 100644 public/logos/solana.svg delete mode 100644 public/logos/weth.png delete mode 100644 src/utils/transfer.ts diff --git a/README.md b/README.md index ba78f469..ac531f8d 100644 --- a/README.md +++ b/README.md @@ -18,7 +18,12 @@ See [CUSTOMIZE.md](./CUSTOMIZE.md) for details about adjusting the tokens and br ### Setup +#### Configure + +You need a `projectId` from the WalletConnect Cloud to run the Hyperlane Warp Route UI. Sign up to [WalletConnect Cloud](https://cloud.walletconnect.com) to create a new project. + #### Build + ```sh # Install dependencies yarn @@ -27,22 +32,14 @@ yarn yarn build ``` -#### Configure - -You need a `projectId` from the WalletConnect Cloud to run the Hyperlane Warp Route UI successfully. -Sign up to [WalletConnect Cloud](https://cloud.walletconnect.com/), create -new project with AppKit and Next.js and copy the `projectId` from there. - ### Run You can add `.env.local` file next to `.env.example` where you set `projectId` copied from WalletConnect Cloud. + ```sh # Start the Next dev server yarn dev -``` - -Or you can set the WalletConnect Cloud `projectId` to use as follows: -``` +# Or with a custom projectId NEXT_PUBLIC_WALLET_CONNECT_ID= yarn dev ``` diff --git a/package.json b/package.json index edd317dc..ddebef4f 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,6 @@ "@hyperlane-xyz/utils": "7.1.0", "@hyperlane-xyz/widgets": "7.1.0", "@interchain-ui/react": "^1.23.28", - "@metamask/jazzicon": "https://github.com/jmrossy/jazzicon#7a8df28974b4e81129bfbe3cab76308b889032a6", "@metamask/post-message-stream": "6.1.2", "@metamask/providers": "10.2.1", "@rainbow-me/rainbowkit": "^2.2.0", diff --git a/public/logos/cosmos.svg b/public/logos/cosmos.svg deleted file mode 100644 index 6023d57e..00000000 --- a/public/logos/cosmos.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/public/logos/cosmwasm.svg b/public/logos/cosmwasm.svg deleted file mode 100644 index 21df9439..00000000 --- a/public/logos/cosmwasm.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/public/logos/solana.svg b/public/logos/solana.svg deleted file mode 100644 index 39609684..00000000 --- a/public/logos/solana.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/public/logos/weth.png b/public/logos/weth.png deleted file mode 100644 index bf957d38c766d5e73df222d2f55eff5c8d00fac0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2984 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 Ca`wOg diff --git a/src/consts/config.ts b/src/consts/config.ts index a6bdaac1..ee80b349 100644 --- a/src/consts/config.ts +++ b/src/consts/config.ts @@ -6,9 +6,7 @@ const version = process?.env?.NEXT_PUBLIC_VERSION || '0.0.0'; const registryUrl = process?.env?.NEXT_PUBLIC_REGISTRY_URL || undefined; const registryBranch = process?.env?.NEXT_PUBLIC_REGISTRY_BRANCH || undefined; const registryProxyUrl = process?.env?.NEXT_PUBLIC_GITHUB_PROXY || 'https://proxy.hyperlane.xyz'; -const explorerApiKeys = JSON.parse(process?.env?.EXPLORER_API_KEYS || '{}'); const walletConnectProjectId = process?.env?.NEXT_PUBLIC_WALLET_CONNECT_ID || ''; -const withdrawalWhitelist = process?.env?.NEXT_PUBLIC_BLOCK_WITHDRAWAL_WHITELIST || ''; const transferBlacklist = process?.env?.NEXT_PUBLIC_TRANSFER_BLACKLIST || ''; const chainWalletWhitelists = JSON.parse(process?.env?.NEXT_PUBLIC_CHAIN_WALLET_WHITELISTS || '{}'); @@ -16,7 +14,6 @@ interface Config { addressBlacklist: string[]; // A list of addresses that are blacklisted and cannot be used in the app chainWalletWhitelists: ChainMap; // A map of chain names to a list of wallet names that work for it enableExplorerLink: boolean; // Include a link to the hyperlane explorer in the transfer modal - explorerApiKeys: Record; // Optional map of API keys for block explorer isDevMode: boolean; // Enables some debug features in the app registryUrl: string | undefined; // Optional URL to use a custom registry instead of the published canonical version registryBranch?: string | undefined; // Optional customization of the registry branch instead of main @@ -26,14 +23,12 @@ interface Config { transferBlacklist: string; // comma-separated list of routes between which transfers are disabled. Expects Caip2Id-Caip2Id (e.g. ethereum:1-sealevel:1399811149) version: string; // Matches version number in package.json walletConnectProjectId: string; // Project ID provided by walletconnect - withdrawalWhitelist: string; // comma-separated list of CAIP2 chain IDs to which transfers are supported } export const config: Config = Object.freeze({ addressBlacklist: ADDRESS_BLACKLIST.map((address) => address.toLowerCase()), chainWalletWhitelists, enableExplorerLink: false, - explorerApiKeys, isDevMode, registryUrl, registryBranch, @@ -43,5 +38,4 @@ export const config: Config = Object.freeze({ version, transferBlacklist, walletConnectProjectId, - withdrawalWhitelist, }); diff --git a/src/features/transfer/TransfersDetailsModal.tsx b/src/features/transfer/TransfersDetailsModal.tsx index 1c1c22b5..e0b0bad8 100644 --- a/src/features/transfer/TransfersDetailsModal.tsx +++ b/src/features/transfer/TransfersDetailsModal.tsx @@ -20,16 +20,16 @@ import { Color } from '../../styles/Color'; import { formatTimestamp } from '../../utils/date'; import { getHypExplorerLink } from '../../utils/links'; import { logger } from '../../utils/logger'; +import { useMultiProvider } from '../chains/hooks'; +import { getChainDisplayName, hasPermissionlessChain } from '../chains/utils'; +import { tryFindToken, useWarpCore } from '../tokens/hooks'; +import { TransferContext, TransferStatus } from './types'; import { getIconByTransferStatus, getTransferStatusLabel, isTransferFailed, isTransferSent, -} from '../../utils/transfer'; -import { useMultiProvider } from '../chains/hooks'; -import { getChainDisplayName, hasPermissionlessChain } from '../chains/utils'; -import { tryFindToken, useWarpCore } from '../tokens/hooks'; -import { TransferContext, TransferStatus } from './types'; +} from './utils'; export function TransfersDetailsModal({ isOpen, diff --git a/src/features/transfer/utils.ts b/src/features/transfer/utils.ts index ad8bb4fb..7d713529 100644 --- a/src/features/transfer/utils.ts +++ b/src/features/transfer/utils.ts @@ -1,3 +1,69 @@ +import ConfirmedIcon from '../../images/icons/confirmed-icon.svg'; +import DeliveredIcon from '../../images/icons/delivered-icon.svg'; +import ErrorCircleIcon from '../../images/icons/error-circle.svg'; +import { FinalTransferStatuses, SentTransferStatuses, TransferStatus } from './types'; + +export function getTransferStatusLabel( + status: TransferStatus, + connectorName: string, + isPermissionlessRoute: boolean, + isAccountReady: boolean, +) { + let statusDescription = '...'; + if (!isAccountReady && !FinalTransferStatuses.includes(status)) + statusDescription = 'Please connect wallet to continue'; + else if (status === TransferStatus.Preparing) + statusDescription = 'Preparing for token transfer...'; + else if (status === TransferStatus.CreatingTxs) statusDescription = 'Creating transactions...'; + else if (status === TransferStatus.SigningApprove) + statusDescription = `Sign approve transaction in ${connectorName} to continue.`; + else if (status === TransferStatus.ConfirmingApprove) + statusDescription = 'Confirming approve transaction...'; + else if (status === TransferStatus.SigningTransfer) + statusDescription = `Sign transfer transaction in ${connectorName} to continue.`; + else if (status === TransferStatus.ConfirmingTransfer) + statusDescription = 'Confirming transfer transaction...'; + else if (status === TransferStatus.ConfirmedTransfer) + if (!isPermissionlessRoute) + statusDescription = 'Transfer transaction confirmed, delivering message...'; + else + statusDescription = + 'Transfer confirmed, the funds will arrive when the message is delivered.'; + else if (status === TransferStatus.Delivered) + statusDescription = 'Delivery complete, transfer successful!'; + else if (status === TransferStatus.Failed) + statusDescription = 'Transfer failed, please try again.'; + + return statusDescription; +} + +export function isTransferSent(status: TransferStatus) { + return SentTransferStatuses.includes(status); +} + +export function isTransferFailed(status: TransferStatus) { + return status === TransferStatus.Failed; +} + +export const STATUSES_WITH_ICON = [ + TransferStatus.Delivered, + TransferStatus.ConfirmedTransfer, + TransferStatus.Failed, +]; + +export function getIconByTransferStatus(status: TransferStatus) { + switch (status) { + case TransferStatus.Delivered: + return DeliveredIcon; + case TransferStatus.ConfirmedTransfer: + return ConfirmedIcon; + case TransferStatus.Failed: + return ErrorCircleIcon; + default: + return ErrorCircleIcon; + } +} + import { ChainMap, CoreAddresses, diff --git a/src/features/wallet/SideBarMenu.tsx b/src/features/wallet/SideBarMenu.tsx index 9e436fbf..508bcd60 100644 --- a/src/features/wallet/SideBarMenu.tsx +++ b/src/features/wallet/SideBarMenu.tsx @@ -6,13 +6,13 @@ import { ChainLogo } from '../../components/icons/ChainLogo'; import ArrowRightIcon from '../../images/icons/arrow-right.svg'; import CollapseIcon from '../../images/icons/collapse-icon.svg'; import ResetIcon from '../../images/icons/reset-icon.svg'; -import { getIconByTransferStatus, STATUSES_WITH_ICON } from '../../utils/transfer'; import { useMultiProvider } from '../chains/hooks'; import { getChainDisplayName } from '../chains/utils'; import { useStore } from '../store'; import { tryFindToken, useWarpCore } from '../tokens/hooks'; import { TransfersDetailsModal } from '../transfer/TransfersDetailsModal'; import { TransferContext } from '../transfer/types'; +import { getIconByTransferStatus, STATUSES_WITH_ICON } from '../transfer/utils'; export function SideBarMenu({ onClickConnectWallet, diff --git a/src/utils/transfer.ts b/src/utils/transfer.ts deleted file mode 100644 index 90dceae0..00000000 --- a/src/utils/transfer.ts +++ /dev/null @@ -1,69 +0,0 @@ -import { - FinalTransferStatuses, - SentTransferStatuses, - TransferStatus, -} from '../features/transfer/types'; -import ConfirmedIcon from '../images/icons/confirmed-icon.svg'; -import DeliveredIcon from '../images/icons/delivered-icon.svg'; -import ErrorCircleIcon from '../images/icons/error-circle.svg'; - -export function getTransferStatusLabel( - status: TransferStatus, - connectorName: string, - isPermissionlessRoute: boolean, - isAccountReady: boolean, -) { - let statusDescription = '...'; - if (!isAccountReady && !FinalTransferStatuses.includes(status)) - statusDescription = 'Please connect wallet to continue'; - else if (status === TransferStatus.Preparing) - statusDescription = 'Preparing for token transfer...'; - else if (status === TransferStatus.CreatingTxs) statusDescription = 'Creating transactions...'; - else if (status === TransferStatus.SigningApprove) - statusDescription = `Sign approve transaction in ${connectorName} to continue.`; - else if (status === TransferStatus.ConfirmingApprove) - statusDescription = 'Confirming approve transaction...'; - else if (status === TransferStatus.SigningTransfer) - statusDescription = `Sign transfer transaction in ${connectorName} to continue.`; - else if (status === TransferStatus.ConfirmingTransfer) - statusDescription = 'Confirming transfer transaction...'; - else if (status === TransferStatus.ConfirmedTransfer) - if (!isPermissionlessRoute) - statusDescription = 'Transfer transaction confirmed, delivering message...'; - else - statusDescription = - 'Transfer confirmed, the funds will arrive when the message is delivered.'; - else if (status === TransferStatus.Delivered) - statusDescription = 'Delivery complete, transfer successful!'; - else if (status === TransferStatus.Failed) - statusDescription = 'Transfer failed, please try again.'; - - return statusDescription; -} - -export function isTransferSent(status: TransferStatus) { - return SentTransferStatuses.includes(status); -} - -export function isTransferFailed(status: TransferStatus) { - return status === TransferStatus.Failed; -} - -export const STATUSES_WITH_ICON = [ - TransferStatus.Delivered, - TransferStatus.ConfirmedTransfer, - TransferStatus.Failed, -]; - -export function getIconByTransferStatus(status: TransferStatus) { - switch (status) { - case TransferStatus.Delivered: - return DeliveredIcon; - case TransferStatus.ConfirmedTransfer: - return ConfirmedIcon; - case TransferStatus.Failed: - return ErrorCircleIcon; - default: - return ErrorCircleIcon; - } -} diff --git a/yarn.lock b/yarn.lock index cd31cab4..821a40d6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3958,7 +3958,6 @@ __metadata: "@hyperlane-xyz/utils": "npm:7.1.0" "@hyperlane-xyz/widgets": "npm:7.1.0" "@interchain-ui/react": "npm:^1.23.28" - "@metamask/jazzicon": "https://github.com/jmrossy/jazzicon#7a8df28974b4e81129bfbe3cab76308b889032a6" "@metamask/post-message-stream": "npm:6.1.2" "@metamask/providers": "npm:10.2.1" "@next/bundle-analyzer": "npm:^15.0.2" @@ -4793,15 +4792,6 @@ __metadata: languageName: node linkType: hard -"@metamask/jazzicon@https://github.com/jmrossy/jazzicon#7a8df28974b4e81129bfbe3cab76308b889032a6": - version: 2.1.0 - resolution: "@metamask/jazzicon@https://github.com/jmrossy/jazzicon.git#commit=7a8df28974b4e81129bfbe3cab76308b889032a6" - dependencies: - mersenne-twister: "npm:^1.1.0" - checksum: 10/5e56251b375eade58294334783fb37a15e8fd48d792f6dc93f7247b8897541324f9cf2d3f1d9b1cffdac1d932a8bc48a89dee7cdbd6e4a312ca2ff85df90131b - languageName: node - linkType: hard - "@metamask/json-rpc-engine@npm:^7.0.0": version: 7.3.3 resolution: "@metamask/json-rpc-engine@npm:7.3.3" @@ -17646,13 +17636,6 @@ __metadata: languageName: node linkType: hard -"mersenne-twister@npm:^1.1.0": - version: 1.1.0 - resolution: "mersenne-twister@npm:1.1.0" - checksum: 10/1123526199091097102f2f91639ad7d5b3df4b098de9a4a72c835920e11ef0ce08e25737d5af1d363325a60da8804365eae8a41e03b7a46a1acc22e18fa8f261 - languageName: node - linkType: hard - "methods@npm:~1.1.2": version: 1.1.2 resolution: "methods@npm:1.1.2" From b2c1d084afcab638b90d44727090f3060155d403 Mon Sep 17 00:00:00 2001 From: Trevor Porter Date: Fri, 6 Dec 2024 19:01:34 +0000 Subject: [PATCH 4/9] feat: use 5 decimals for the displayed balance (#345) From https://github.com/hyperlane-xyz/hyperlane-warp-ui-template/pull/342 --- src/features/transfer/TransferTokenForm.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/features/transfer/TransferTokenForm.tsx b/src/features/transfer/TransferTokenForm.tsx index 68f50121..4318670f 100644 --- a/src/features/transfer/TransferTokenForm.tsx +++ b/src/features/transfer/TransferTokenForm.tsx @@ -222,7 +222,7 @@ function RecipientSection({ isReview }: { isReview: boolean }) { } function TokenBalance({ label, balance }: { label: string; balance?: TokenAmount | null }) { - const value = balance?.getDecimalFormattedAmount().toFixed(4) || '0'; + const value = balance?.getDecimalFormattedAmount().toFixed(5) || '0'; return
{`${label}: ${value}`}
; } From 39cbd476f520298c1b6ac4d780553d8a5a1981fa Mon Sep 17 00:00:00 2001 From: J M Rossy Date: Fri, 6 Dec 2024 17:23:30 -0500 Subject: [PATCH 5/9] Fix: Bug with Tailwind gray color extension (#347) --- src/consts/app.ts | 4 ++-- src/features/transfer/TransfersDetailsModal.tsx | 2 +- src/features/wallet/WalletFloatingButtons.tsx | 4 ++-- src/features/wallet/context/EvmWalletContext.tsx | 2 +- src/styles/Color.ts | 9 ++++----- tailwind.config.js | 3 ++- 6 files changed, 12 insertions(+), 12 deletions(-) diff --git a/src/consts/app.ts b/src/consts/app.ts index 2f235bdc..2dc51e86 100644 --- a/src/consts/app.ts +++ b/src/consts/app.ts @@ -10,6 +10,6 @@ export const MAIN_FONT = SpaceGrotesk({ export const APP_NAME = 'Hyperlane Warp UI Template'; export const APP_DESCRIPTION = 'A DApp for Hyperlane Warp Route transfers'; export const APP_URL = 'hyperlane-warp-template.vercel.app'; -export const BRAND_COLOR = Color.primary; -export const BACKGROUND_COLOR = Color.primary; +export const BRAND_COLOR = Color.primary['500']; +export const BACKGROUND_COLOR = Color.primary['500']; export const BACKGROUND_IMAGE = 'url(/backgrounds/main.svg)'; diff --git a/src/features/transfer/TransfersDetailsModal.tsx b/src/features/transfer/TransfersDetailsModal.tsx index e0b0bad8..aa859430 100644 --- a/src/features/transfer/TransfersDetailsModal.tsx +++ b/src/features/transfer/TransfersDetailsModal.tsx @@ -263,7 +263,7 @@ function WideChevron() { width="16" height="100%" direction="e" - color={Color.lightGray} + color={Color.gray['300']} rounded={true} /> ); diff --git a/src/features/wallet/WalletFloatingButtons.tsx b/src/features/wallet/WalletFloatingButtons.tsx index c0ab5b24..e93093e9 100644 --- a/src/features/wallet/WalletFloatingButtons.tsx +++ b/src/features/wallet/WalletFloatingButtons.tsx @@ -18,14 +18,14 @@ export function WalletFloatingButtons() { title="History" onClick={() => setIsSideBarOpen(!isSideBarOpen)} > - + - + ); diff --git a/src/features/wallet/context/EvmWalletContext.tsx b/src/features/wallet/context/EvmWalletContext.tsx index d8f802da..830948f6 100644 --- a/src/features/wallet/context/EvmWalletContext.tsx +++ b/src/features/wallet/context/EvmWalletContext.tsx @@ -68,7 +68,7 @@ export function EvmWalletContext({ children }: PropsWithChildren) { ; export const Color = { black: themeColors.black, white: themeColors.white, - gray: themeColors.gray[500], - lightGray: themeColors.gray[200], - primary: themeColors.primary[500], - accent: themeColors.accent[500], - red: themeColors.red[500], + gray: themeColors.gray, + primary: themeColors.primary, + accent: themeColors.accent, + red: themeColors.red, } as const; diff --git a/tailwind.config.js b/tailwind.config.js index 66adf091..17ea7efc 100644 --- a/tailwind.config.js +++ b/tailwind.config.js @@ -1,6 +1,7 @@ /** @type {import('tailwindcss').Config} */ const defaultTheme = require('tailwindcss/defaultTheme'); +const defaultColors = require('tailwindcss/colors'); module.exports = { content: ['./src/**/*.{js,ts,jsx,tsx}'], @@ -19,7 +20,7 @@ module.exports = { colors: { black: '#010101', white: '#ffffff', - gray: { ...defaultTheme.colors.gray, 150: '#EBEDF0', 250: '#404040', 350: '#6B6B6B' }, + gray: { ...defaultColors.gray, '150': '#EBEDF0', '250': '#404040', '350': '#6B6B6B' }, primary: { 50: '#E6EDF9', 100: '#CDDCF4', From 784a0c7cae0ad63ebb71453760fc97cd3f1d0197 Mon Sep 17 00:00:00 2001 From: leonarddt05 <139609434+leonarddt05@users.noreply.github.com> Date: Fri, 3 Jan 2025 11:35:32 +0300 Subject: [PATCH 6/9] Typo fixed in: Update README.md MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Hi and happy new year. Here is a typo in this text: "permisionlessly" → should be "permissionlessly" (Typo in the word "permissionlessly") Thanks. --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index ac531f8d..f4674595 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ # Hyperlane Warp Route UI Template -This repo contains an example web interface for interchain tokens built with [Hyperlane Warp Route](https://docs.hyperlane.xyz/docs/reference/applications/warp-routes). Warp is a framework to permisionlessly bridge tokens to any chain. +This repo contains an example web interface for interchain tokens built with [Hyperlane Warp Route](https://docs.hyperlane.xyz/docs/reference/applications/warp-routes). Warp is a framework to permissionlessly bridge tokens to any chain. ## Architecture From 51cd772c5008061587006a2a877c11771252b751 Mon Sep 17 00:00:00 2001 From: Yorke Rhodes Date: Mon, 6 Jan 2025 16:54:02 -0500 Subject: [PATCH 7/9] Bump registry to 6.11.0 --- package.json | 2 +- yarn.lock | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/package.json b/package.json index ddebef4f..ad6c5b30 100644 --- a/package.json +++ b/package.json @@ -17,7 +17,7 @@ "@emotion/react": "^11.13.3", "@emotion/styled": "^11.13.0", "@headlessui/react": "^2.2.0", - "@hyperlane-xyz/registry": "6.1.0", + "@hyperlane-xyz/registry": "6.11.0", "@hyperlane-xyz/sdk": "7.1.0", "@hyperlane-xyz/utils": "7.1.0", "@hyperlane-xyz/widgets": "7.1.0", diff --git a/yarn.lock b/yarn.lock index 821a40d6..fe9a8660 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3881,13 +3881,13 @@ __metadata: languageName: node linkType: hard -"@hyperlane-xyz/registry@npm:6.1.0": - version: 6.1.0 - resolution: "@hyperlane-xyz/registry@npm:6.1.0" +"@hyperlane-xyz/registry@npm:6.11.0": + version: 6.11.0 + resolution: "@hyperlane-xyz/registry@npm:6.11.0" dependencies: yaml: "npm:2.4.5" zod: "npm:^3.21.2" - checksum: 10/a0e1ecc02d83604793ddda0a3e00a9ffcaa38b1cddf9883b47cf8f1919b4474abd6cc2ee84846e6a35e1bc7539299b9bec92bfdf06be72beecff6aa44b73d382 + checksum: 10/25019fbc8ff07b06e34c1ad55af556623fbd4676c12b40060bee89d468f8b3d57a2559286b500e1aae21e19c2ff7ca07bd00a2df7386340bfa1208790b47e8b7 languageName: node linkType: hard @@ -3953,7 +3953,7 @@ __metadata: "@emotion/react": "npm:^11.13.3" "@emotion/styled": "npm:^11.13.0" "@headlessui/react": "npm:^2.2.0" - "@hyperlane-xyz/registry": "npm:6.1.0" + "@hyperlane-xyz/registry": "npm:6.11.0" "@hyperlane-xyz/sdk": "npm:7.1.0" "@hyperlane-xyz/utils": "npm:7.1.0" "@hyperlane-xyz/widgets": "npm:7.1.0" From d31c8b1a1a01b39b72d0bc894c1adb7f574cc7b7 Mon Sep 17 00:00:00 2001 From: Yauheni Kryshneu <124672279+sergeypanin1994@users.noreply.github.com> Date: Wed, 8 Jan 2025 03:36:04 +0300 Subject: [PATCH 8/9] Fix typo: "These are images" -> "These images"fix: update Twitter URL to x.com format (#372) Fix typo: "These are images" -> "These images" fix: update Twitter URL to x.com format --- CUSTOMIZE.md | 2 +- src/consts/links.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CUSTOMIZE.md b/CUSTOMIZE.md index 4872b8d0..8f87e0ee 100644 --- a/CUSTOMIZE.md +++ b/CUSTOMIZE.md @@ -48,7 +48,7 @@ The logo images you should change are: - `./src/images/logos/app-name.svg` - `./src/images/logos/app-title.svg` -These are images are primarily used in the header and footer files: +These images are primarily used in the header and footer files: - `./src/components/nav/Header.tsx` - `./src/components/nav/Footer.tsx` diff --git a/src/consts/links.ts b/src/consts/links.ts index ab16f7df..7c5568ae 100644 --- a/src/consts/links.ts +++ b/src/consts/links.ts @@ -7,7 +7,7 @@ export const links = { warpDocs: 'https://docs.hyperlane.xyz/docs/reference/applications/warp-routes', gasDocs: 'https://docs.hyperlane.xyz/docs/reference/hooks/interchain-gas', chains: 'https://docs.hyperlane.xyz/docs/resources/domains', - twitter: 'https://twitter.com/hyperlane', + twitter: 'https://x.com/hyperlane', blog: 'https://medium.com/hyperlane', tos: 'https://hyperlane.xyz/terms-of-service', privacyPolicy: 'https://hyperlane.xyz/privacy-policy', From 9d90974761d840670c0c2f0035692c3adb159820 Mon Sep 17 00:00:00 2001 From: Le Yu <6251863+ltyu@users.noreply.github.com> Date: Thu, 9 Jan 2025 17:09:28 -0500 Subject: [PATCH 9/9] Up registry to 6.12 --- package.json | 2 +- yarn.lock | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/package.json b/package.json index ad6c5b30..b99b183b 100644 --- a/package.json +++ b/package.json @@ -17,7 +17,7 @@ "@emotion/react": "^11.13.3", "@emotion/styled": "^11.13.0", "@headlessui/react": "^2.2.0", - "@hyperlane-xyz/registry": "6.11.0", + "@hyperlane-xyz/registry": "6.12.0", "@hyperlane-xyz/sdk": "7.1.0", "@hyperlane-xyz/utils": "7.1.0", "@hyperlane-xyz/widgets": "7.1.0", diff --git a/yarn.lock b/yarn.lock index fe9a8660..cf3fb826 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3881,13 +3881,13 @@ __metadata: languageName: node linkType: hard -"@hyperlane-xyz/registry@npm:6.11.0": - version: 6.11.0 - resolution: "@hyperlane-xyz/registry@npm:6.11.0" +"@hyperlane-xyz/registry@npm:6.12.0": + version: 6.12.0 + resolution: "@hyperlane-xyz/registry@npm:6.12.0" dependencies: yaml: "npm:2.4.5" zod: "npm:^3.21.2" - checksum: 10/25019fbc8ff07b06e34c1ad55af556623fbd4676c12b40060bee89d468f8b3d57a2559286b500e1aae21e19c2ff7ca07bd00a2df7386340bfa1208790b47e8b7 + checksum: 10/94d5141c2b4e1496d4eab74153c998590c986794eaae0404434f0235e7c3de1936c108937bda60006c57422c709dd5539658ca8cddd6504f59f5553f68b0e252 languageName: node linkType: hard @@ -3953,7 +3953,7 @@ __metadata: "@emotion/react": "npm:^11.13.3" "@emotion/styled": "npm:^11.13.0" "@headlessui/react": "npm:^2.2.0" - "@hyperlane-xyz/registry": "npm:6.11.0" + "@hyperlane-xyz/registry": "npm:6.12.0" "@hyperlane-xyz/sdk": "npm:7.1.0" "@hyperlane-xyz/utils": "npm:7.1.0" "@hyperlane-xyz/widgets": "npm:7.1.0"