From 5f29aef85f7e39208bdbad04a1c9c7d3e49449fd Mon Sep 17 00:00:00 2001 From: Todd Kao Date: Tue, 7 Jan 2025 11:23:25 -0500 Subject: [PATCH] Revert "Merge branch 'staging' into sentry-integration" This reverts commit b9ace74afc46a71f36d335f60156d3f7282807a1, reversing changes made to 6d95bf1f0d53777490f142e5ff689efecc554e3e. --- .changeset/clean-weeks-cheer.md | 5 -- .changeset/good-pans-unite.md | 5 ++ .changeset/popular-donkeys-behave.md | 5 -- .changeset/serious-readers-beam.md | 5 ++ .changeset/smooth-zoos-itch.md | 5 -- .changeset/thick-cherries-provide.md | 5 -- ...altime-transaction-and-packet-tracking.mdx | 1 + examples/nextjs/CHANGELOG.md | 46 ---------------- examples/nextjs/package.json | 2 +- packages/client/CHANGELOG.md | 24 --------- packages/client/package.json | 2 +- packages/client/src/client.ts | 19 +++++++ packages/client/src/types/converters.ts | 37 ------------- packages/client/src/types/lifecycle.ts | 2 +- packages/client/src/types/shared.ts | 40 -------------- packages/widget/CHANGELOG.md | 52 ------------------- packages/widget/package.json | 2 +- .../src/components/RenderWalletList.tsx | 38 +++----------- packages/widget/src/constants/wagmi.ts | 9 ++-- .../src/hooks/useCreateCosmosWallets.tsx | 14 ++--- .../AssetAndChainSelectorModalSearchInput.tsx | 1 - .../SwapExecutionPage/SwapExecutionPage.tsx | 9 ++-- packages/widget/src/utils/os.ts | 2 +- .../src/widget/ShadowDomAndProviders.tsx | 5 +- packages/widget/web-component/package.json | 2 +- 25 files changed, 63 insertions(+), 274 deletions(-) delete mode 100644 .changeset/clean-weeks-cheer.md create mode 100644 .changeset/good-pans-unite.md delete mode 100644 .changeset/popular-donkeys-behave.md create mode 100644 .changeset/serious-readers-beam.md delete mode 100644 .changeset/smooth-zoos-itch.md delete mode 100644 .changeset/thick-cherries-provide.md diff --git a/.changeset/clean-weeks-cheer.md b/.changeset/clean-weeks-cheer.md deleted file mode 100644 index e6b868b0d..000000000 --- a/.changeset/clean-weeks-cheer.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -'@skip-go/widget': patch ---- - -Convert globalStyles to stylesheet before passing to react-shadow-scope diff --git a/.changeset/good-pans-unite.md b/.changeset/good-pans-unite.md new file mode 100644 index 000000000..362deb904 --- /dev/null +++ b/.changeset/good-pans-unite.md @@ -0,0 +1,5 @@ +--- +'@skip-go/widget': patch +--- + +fix balance loading display state diff --git a/.changeset/popular-donkeys-behave.md b/.changeset/popular-donkeys-behave.md deleted file mode 100644 index c1b622cae..000000000 --- a/.changeset/popular-donkeys-behave.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -'@skip-go/client': patch ---- - -no longer override timeout in signCosmosMessageAmino diff --git a/.changeset/serious-readers-beam.md b/.changeset/serious-readers-beam.md new file mode 100644 index 000000000..6d3d3a06a --- /dev/null +++ b/.changeset/serious-readers-beam.md @@ -0,0 +1,5 @@ +--- +'@skip-go/widget': patch +--- + +exclude assets programatically diff --git a/.changeset/smooth-zoos-itch.md b/.changeset/smooth-zoos-itch.md deleted file mode 100644 index c781220d3..000000000 --- a/.changeset/smooth-zoos-itch.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -'@skip-go/widget': patch ---- - -enable evm walletconnect for desktop diff --git a/.changeset/thick-cherries-provide.md b/.changeset/thick-cherries-provide.md deleted file mode 100644 index 8dad69e27..000000000 --- a/.changeset/thick-cherries-provide.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -'@skip-go/client': patch ---- - -update stargate fee types diff --git a/docs/general/multi-chain-realtime-transaction-and-packet-tracking.mdx b/docs/general/multi-chain-realtime-transaction-and-packet-tracking.mdx index a5746f88d..962910636 100644 --- a/docs/general/multi-chain-realtime-transaction-and-packet-tracking.mdx +++ b/docs/general/multi-chain-realtime-transaction-and-packet-tracking.mdx @@ -189,6 +189,7 @@ Below are detailed explanations of the different fields and their purposes: * `orderRefundedTx`: The transaction where the user received a refund on the source chain, if applicable. * `orderTimeoutTx`: The transaction indicating a timeout occurred in the transfer process. + When tracking a Go Fast transfer, you can use the `GoFastTransferInfo` to monitor the progress and status of your asset transfer between chains. For instance, if the state is `GO_FAST_TRANSFER_FILLED`, you know that the transfer was successful and your assets should be available on the destination chain. If the state is `GO_FAST_TRANSFER_TIMEOUT`, you can check the `orderTimeoutTx` for details on the timeout event. diff --git a/examples/nextjs/CHANGELOG.md b/examples/nextjs/CHANGELOG.md index 197741f9c..70b9b841d 100644 --- a/examples/nextjs/CHANGELOG.md +++ b/examples/nextjs/CHANGELOG.md @@ -1,51 +1,5 @@ # nextjs -## 0.1.32 - -### Patch Changes - -- Updated dependencies [c7d3743] - - @skip-go/widget@3.1.4 - -## 0.1.31 - -### Patch Changes - -- @skip-go/widget@3.1.3 - -## 0.1.30 - -### Patch Changes - -- Updated dependencies [40a9229] -- Updated dependencies [ea59c36] -- Updated dependencies [7caf0cb] -- Updated dependencies [2cff22b] -- Updated dependencies [9628165] -- Updated dependencies [afb37b6] - - @skip-go/widget@3.1.2 - -## 0.1.29 - -### Patch Changes - -- Updated dependencies [bc373bd] - - @skip-go/widget@3.1.1 - -## 0.1.28 - -### Patch Changes - -- dacf973: fix example default route and client asset search -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] - - @skip-go/widget@3.1.0 - ## 0.1.27 ### Patch Changes diff --git a/examples/nextjs/package.json b/examples/nextjs/package.json index dc3652a43..2a35124ba 100644 --- a/examples/nextjs/package.json +++ b/examples/nextjs/package.json @@ -1,6 +1,6 @@ { "name": "nextjs", - "version": "0.1.32", + "version": "0.1.27", "private": true, "scripts": { "dev": "next dev", diff --git a/packages/client/CHANGELOG.md b/packages/client/CHANGELOG.md index 2684eb8d3..8e3f3082e 100644 --- a/packages/client/CHANGELOG.md +++ b/packages/client/CHANGELOG.md @@ -1,29 +1,5 @@ # @skip-go/client -## 0.16.2 - -### Patch Changes - -- 8a1ae46: no longer override timeout in signCosmosMessageAmino - -## 0.16.1 - -### Patch Changes - -- fa9b9c9: add error message field on GoFastTransferInfo -- 9628165: update registries -- afb37b6: fix build - -## 0.16.0 - -### Minor Changes - -- dacf973: stargate transfer types - -### Patch Changes - -- dacf973: update getCosmosSigner type - ## 0.15.6 ### Patch Changes diff --git a/packages/client/package.json b/packages/client/package.json index b4a6ae7b1..a15917055 100644 --- a/packages/client/package.json +++ b/packages/client/package.json @@ -1,7 +1,7 @@ { "name": "@skip-go/client", "description": "JavaScript SDK for Skip Go API", - "version": "0.16.2", + "version": "0.15.6", "repository": "https://github.com/skip-mev/skip-go", "main": "dist/index.js", "types": "dist/index.d.ts", diff --git a/packages/client/src/client.ts b/packages/client/src/client.ts index 41d06cd14..2e014345f 100644 --- a/packages/client/src/client.ts +++ b/packages/client/src/client.ts @@ -884,6 +884,25 @@ export class SkipClient { getEncodeObjectFromCosmosMessage(cosmosMsg) ); + const aminoMsgTransferIndex = messages.findIndex( + (x) => x.typeUrl === '/ibc.applications.transfer.v1.MsgTransfer' + ); + if (aminoMsgTransferIndex !== -1) { + const endpoint = await this.getRpcEndpointForChain(chainID); + const client = await StargateClient.connect(endpoint, { + accountParser, + }); + + const currentHeight = await client.getHeight(); + + messages[aminoMsgTransferIndex]!.value.timeoutHeight = { + revisionHeight: currentHeight + 100, + revisionNumber: currentHeight + 100, + }; + + messages[aminoMsgTransferIndex]!.value.timeoutTimestamp = 0; + } + const signMode = SignMode.SIGN_MODE_LEGACY_AMINO_JSON; const msgs = messages.map((msg) => this.aminoTypes.toAmino(msg)); diff --git a/packages/client/src/types/converters.ts b/packages/client/src/types/converters.ts index 685d72160..05754ec9e 100644 --- a/packages/client/src/types/converters.ts +++ b/packages/client/src/types/converters.ts @@ -878,43 +878,6 @@ export function goFastTransferFromJSON(goFastJSON: GoFastTransferJSON): GoFastTr destinationDomain: goFastJSON.destination_domain, }; } - -export function stargateTransferFromJSON(stargateTransferJSON: StargateTransferJSON): StargateTransfer { - return { - fromChainID: stargateTransferJSON.from_chain_id, - toChainID: stargateTransferJSON.to_chain_id, - denomIn: stargateTransferJSON.denom_in, - denomOut: stargateTransferJSON.denom_out, - poolAddress: stargateTransferJSON.pool_address, - destinationEndpointID: stargateTransferJSON.destination_endpoint_id, - oftFeeAsset: assetFromJSON(stargateTransferJSON.oft_fee_asset), - oftFeeAmount: stargateTransferJSON.oft_fee_amount, - oftFeeAmountUSD: stargateTransferJSON.oft_fee_amount_usd, - messagingFeeAsset: assetFromJSON(stargateTransferJSON.messaging_fee_asset), - messagingFeeAmount: stargateTransferJSON.messaging_fee_amount, - messagingFeeAmountUSD: stargateTransferJSON.messaging_fee_amount_usd, - bridgeID: stargateTransferJSON.bridge_id, - } -} - -export function stargateTransferToJSON(stargateTransfer: StargateTransfer): StargateTransferJSON { - return { - from_chain_id: stargateTransfer.fromChainID, - to_chain_id: stargateTransfer.toChainID, - denom_in: stargateTransfer.denomIn, - denom_out: stargateTransfer.denomOut, - pool_address: stargateTransfer.poolAddress, - destination_endpoint_id: stargateTransfer.destinationEndpointID, - oft_fee_asset: assetToJSON(stargateTransfer.oftFeeAsset), - oft_fee_amount: stargateTransfer.oftFeeAmount, - oft_fee_amount_usd: stargateTransfer.oftFeeAmountUSD, - messaging_fee_asset: assetToJSON(stargateTransfer.messagingFeeAsset), - messaging_fee_amount: stargateTransfer.messagingFeeAmount, - messaging_fee_amount_usd: stargateTransfer.messagingFeeAmountUSD, - bridge_id: stargateTransfer.bridgeID, - } -} - export function operationFromJSON(operationJSON: OperationJSON): Operation { const commonProps = { txIndex: operationJSON.tx_index, diff --git a/packages/client/src/types/lifecycle.ts b/packages/client/src/types/lifecycle.ts index e10a58ca1..2207c516a 100644 --- a/packages/client/src/types/lifecycle.ts +++ b/packages/client/src/types/lifecycle.ts @@ -515,4 +515,4 @@ export interface TransactionCallbacks { allowance?: ERC20Approval, status: CallbackStatus }) => Promise; -} +} \ No newline at end of file diff --git a/packages/client/src/types/shared.ts b/packages/client/src/types/shared.ts index 49ec68dd2..e8020c909 100644 --- a/packages/client/src/types/shared.ts +++ b/packages/client/src/types/shared.ts @@ -198,46 +198,6 @@ export type GoFastTransferJSON = { destination_domain: string; } -export type StargateTransferJSON = { - from_chain_id: string; - to_chain_id: string; - denom_in: string; - denom_out: string; - - pool_address: string; - destination_endpoint_id: number; - - oft_fee_asset: AssetJSON; - oft_fee_amount: string; - oft_fee_amount_usd: string; - - messaging_fee_asset: AssetJSON; - messaging_fee_amount: string; - messaging_fee_amount_usd: string; - - bridge_id: BridgeType; -}; - -export type StargateTransfer = { - fromChainID: string; - toChainID: string; - denomIn: string; - denomOut: string; - - poolAddress: string; - destinationEndpointID: number; - - oftFeeAsset: Asset; - oftFeeAmount: string; - oftFeeAmountUSD: string; - - messagingFeeAsset: Asset; - messagingFeeAmount: string; - messagingFeeAmountUSD: string; - - bridgeID: BridgeType; -}; - export type BankSendJSON = { chain_id: string; denom: string; diff --git a/packages/widget/CHANGELOG.md b/packages/widget/CHANGELOG.md index a6a9268c2..a40b4ccc7 100644 --- a/packages/widget/CHANGELOG.md +++ b/packages/widget/CHANGELOG.md @@ -1,57 +1,5 @@ ## 0.0.15 -## 3.1.4 - -### Patch Changes - -- c7d3743: fix edit desintation address - -## 3.1.3 - -### Patch Changes - -- Updated dependencies [8a1ae46] - - @skip-go/client@0.16.2 - -## 3.1.2 - -### Patch Changes - -- 40a9229: show warning if ends in ibc transfer -- ea59c36: Update post tx button to Go again -- 7caf0cb: filter cosmos wallets for is available items -- 2cff22b: remove evm wallet connect -- 9628165: update registries -- afb37b6: fix build -- Updated dependencies [fa9b9c9] -- Updated dependencies [9628165] -- Updated dependencies [afb37b6] - - @skip-go/client@0.16.1 - -## 3.1.1 - -### Patch Changes - -- bc373bd: fix keplr in app browser issue - -## 3.1.0 - -### Minor Changes - -- dacf973: evm mobile wallet support - -### Patch Changes - -- dacf973: ability to pass signer and account -- dacf973: fix balance loading display state -- dacf973: fix loading indicator -- dacf973: Add callback functions for wallet connect/disconnect and transaction broadcasted / completed / failed -- dacf973: exclude assets programatically -- dacf973: add daodao iframe wallet -- Updated dependencies [dacf973] -- Updated dependencies [dacf973] - - @skip-go/client@0.16.0 - ## 3.0.25 ### Patch Changes diff --git a/packages/widget/package.json b/packages/widget/package.json index 512eaabd4..30017a40f 100644 --- a/packages/widget/package.json +++ b/packages/widget/package.json @@ -1,7 +1,7 @@ { "name": "@skip-go/widget", "description": "Swap widget", - "version": "3.1.4", + "version": "3.0.25", "repository": { "url": "https://github.com/skip-mev/skip-go", "directory": "packages/widget" diff --git a/packages/widget/src/components/RenderWalletList.tsx b/packages/widget/src/components/RenderWalletList.tsx index 5b7f3da2f..b37b88814 100644 --- a/packages/widget/src/components/RenderWalletList.tsx +++ b/packages/widget/src/components/RenderWalletList.tsx @@ -61,14 +61,6 @@ export const RenderWalletList = ({ const theme = useTheme(); const setChainAddresses = useSetAtom(chainAddressesAtom); - const displayWallets = useMemo(() => { - const filteredWallets = walletList.filter( - (wallet) => isManualWalletEntry(wallet) || wallet?.isAvailable !== false - ); - - return filteredWallets.length === 1 ? walletList : filteredWallets; - }, [walletList]); - const clearAssetInputAmounts = useSetAtom(clearAssetInputAmountsAtom); const connectMutation = useMutation({ @@ -114,25 +106,10 @@ export const RenderWalletList = ({ const renderItem = useCallback( (wallet: ManualWalletEntry | MinimalWallet) => { - const name = isMinimalWallet(wallet) - ? wallet.walletPrettyName ?? wallet.walletName - : wallet.walletName; - - const imageUrl = isMinimalWallet(wallet) ? wallet?.walletInfo?.logo : undefined; - const rightContent = isManualWalletEntry(wallet) ? wallet?.rightContent : undefined; - const isAvailable = isMinimalWallet(wallet) ? wallet?.isAvailable : undefined; - - const renderedRightContent = rightContent?.() ?? <>; - - const imageElement = imageUrl ? ( - {`${name}-logo`} - ) : null; + const name = isMinimalWallet(wallet) ? wallet.walletPrettyName ?? wallet.walletName : wallet.walletName; + const imageUrl = isMinimalWallet(wallet) ? wallet.walletInfo.logo : undefined; + const rightContent = isManualWalletEntry(wallet) ? wallet.rightContent : undefined; + const isAvailable = isMinimalWallet(wallet) ? wallet.isAvailable : undefined; const onClickConnectWallet = () => { if (isMinimalWallet(wallet)) { @@ -198,9 +175,8 @@ export const RenderWalletList = ({ ); const height = useMemo(() => { - return Math.min(530, displayWallets.length * (ITEM_HEIGHT + ITEM_GAP)); - }, [displayWallets.length]); - + return Math.min(530, walletList.length * (ITEM_HEIGHT + ITEM_GAP)); + }, [walletList]); const renderWalletListOrWalletConnectionStatus = useMemo(() => { if (connectMutation.isError || connectMutation.isPending) { @@ -262,7 +238,7 @@ export const RenderWalletList = ({ renderItem, theme.primary.text.lowContrast, theme.primary.text.normal, - displayWallets, + walletList, ]); return ( diff --git a/packages/widget/src/constants/wagmi.ts b/packages/widget/src/constants/wagmi.ts index 882ef359e..4ed729ea1 100644 --- a/packages/widget/src/constants/wagmi.ts +++ b/packages/widget/src/constants/wagmi.ts @@ -32,8 +32,9 @@ import { forma } from "wagmi/chains"; import { defineChain } from "viem"; -import { walletConnect } from "wagmi/connectors"; -import { isMobile, isBrowser } from "@/utils/os"; +import { walletConnect } from "wagmi/connectors" + +const isBrowser = typeof window !== "undefined"; export const formaTestnet = defineChain({ id: 984_123, @@ -128,7 +129,7 @@ export const config: Config = createConfig({ storage: isBrowser ? localStorage : undefined, // Use a fallback for SSR key: "skip-go-widget-wagmi", }), - connectors: isMobile() ? undefined : [ + connectors: [ walletConnect({ projectId: "ff1b9e9bd6329cfb07642bd7f4d11a8c", showQrModal: true @@ -136,4 +137,4 @@ export const config: Config = createConfig({ ] }); -export const walletConnectLogo = ""; +export const walletConnectLogo = "" diff --git a/packages/widget/src/hooks/useCreateCosmosWallets.tsx b/packages/widget/src/hooks/useCreateCosmosWallets.tsx index 58af0d674..8989ad310 100644 --- a/packages/widget/src/hooks/useCreateCosmosWallets.tsx +++ b/packages/widget/src/hooks/useCreateCosmosWallets.tsx @@ -128,13 +128,15 @@ export const useCreateCosmosWallets = () => { for (const wallet of cosmosWallets) { const isWC = isWalletConnect(wallet); - const mobile = isMobile() + const walletInfo = getCosmosWalletInfo(wallet); - const initialChainIds = (() => { - if (isWC) return walletConnectMainnetChainIdsInitialConnect - if (wallet === WalletType.KEPLR && !mobile) return keplrMainnetChainIdsInitialConnect - return walletMainnetChainIdsInitialConnect - })().filter( + const initialChainIds = ( + isWC + ? walletConnectMainnetChainIdsInitialConnect + : wallet === WalletType.KEPLR + ? keplrMainnetChainIdsInitialConnect + : walletMainnetChainIdsInitialConnect + ).filter( (x) => chains ?.filter((z) => z.chainType === ChainType.Cosmos) diff --git a/packages/widget/src/modals/AssetAndChainSelectorModal/AssetAndChainSelectorModalSearchInput.tsx b/packages/widget/src/modals/AssetAndChainSelectorModal/AssetAndChainSelectorModalSearchInput.tsx index 73178f14e..7993c70f4 100644 --- a/packages/widget/src/modals/AssetAndChainSelectorModal/AssetAndChainSelectorModalSearchInput.tsx +++ b/packages/widget/src/modals/AssetAndChainSelectorModal/AssetAndChainSelectorModalSearchInput.tsx @@ -93,7 +93,6 @@ export const AssetAndChainSelectorModalSearchInput = ({ const StyledLeftArrowIcon = styled(LeftArrowIcon)` width: 25px; opacity: 0.5; - transform: rotate(180deg); `; const StyledSelectedAsset = styled(StyledAssetLabel)` diff --git a/packages/widget/src/pages/SwapExecutionPage/SwapExecutionPage.tsx b/packages/widget/src/pages/SwapExecutionPage/SwapExecutionPage.tsx index 027d8a19c..40e2774e2 100644 --- a/packages/widget/src/pages/SwapExecutionPage/SwapExecutionPage.tsx +++ b/packages/widget/src/pages/SwapExecutionPage/SwapExecutionPage.tsx @@ -98,15 +98,16 @@ export const SwapExecutionPage = () => { }, [signaturesRemaining, shouldDisplaySignaturesRemaining]); const onClickEditDestinationWallet = useMemo(() => { + const lastIndex = chainAddresses ? Object.keys(chainAddresses).length - 1 : 0; + const destinationAddress = chainAddresses?.[lastIndex]?.address; const loadingStates = [ SwapExecutionState.pending, SwapExecutionState.waitingForSigning, SwapExecutionState.validatingGasBalance, - SwapExecutionState.confirmed, - SwapExecutionState.signaturesRemaining, + SwapExecutionState.confirmed ]; - if (loadingStates.includes(swapExecutionState)) { + if (loadingStates.includes(swapExecutionState) || !destinationAddress) { return undefined; } @@ -115,7 +116,7 @@ export const SwapExecutionPage = () => { chainId: route?.destAssetChainID, }); }; - }, [swapExecutionState, route?.destAssetChainID]); + }, [chainAddresses, swapExecutionState, route?.destAssetChainID]); diff --git a/packages/widget/src/utils/os.ts b/packages/widget/src/utils/os.ts index 329a0d85d..4c90eee71 100644 --- a/packages/widget/src/utils/os.ts +++ b/packages/widget/src/utils/os.ts @@ -1,4 +1,4 @@ -export const isBrowser = typeof window !== "undefined" && typeof window.navigator !== "undefined"; +const isBrowser = typeof window !== "undefined" && typeof window.navigator !== "undefined"; export function isAndroid() { if (!isBrowser) { diff --git a/packages/widget/src/widget/ShadowDomAndProviders.tsx b/packages/widget/src/widget/ShadowDomAndProviders.tsx index 7157ab768..b8b860ea8 100644 --- a/packages/widget/src/widget/ShadowDomAndProviders.tsx +++ b/packages/widget/src/widget/ShadowDomAndProviders.tsx @@ -7,7 +7,7 @@ import { useState, } from "react"; import { StyleSheetManager, ThemeProvider } from "styled-components"; -import { useCSS, Scope } from "react-shadow-scope"; +import { Scope } from "react-shadow-scope"; import { defaultTheme, PartialTheme } from "./theme"; import isPropValid from "@emotion/is-prop-valid"; import { useInjectFontsToDocumentHead } from "@/hooks/useInjectFontsToDocumentHead"; @@ -31,7 +31,6 @@ export const ShadowDomAndProviders = ({ theme?: PartialTheme; }) => { useInjectFontsToDocumentHead(); - const css = useCSS(); const [, setShadowDom] = useState(); const [styledComponentContainer, setStyledComponentContainer] = @@ -58,7 +57,7 @@ export const ShadowDomAndProviders = ({ return ( - +