Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ST-492: wallet-kit integration #418

Merged
merged 9 commits into from
Jul 5, 2023
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
911 changes: 176 additions & 735 deletions package-lock.json

Large diffs are not rendered by default.

8 changes: 3 additions & 5 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,13 @@
"@mui/icons-material": "^5.8.0",
"@mui/material": "^5.9.1",
"@sentry/react": "^7.53.1",
"@terra-money/feather.js": "^1.0.6",
"@terra-money/ledger-station-js": "^1.3.7",
"@terra-money/feather.js": "^1.0.8",
"@terra-money/ledger-station-js": "^1.3.8",
"@terra-money/log-finder-ruleset": "^3.0.0",
"@terra-money/terra-utils": "^1.0.9",
"@terra-money/terra.js": "^3.1.9",
"@terra-money/terra.proto": "^2.0.0",
"@terra-money/use-wallet": "4.0.0-beta.3",
"@terra-money/wallet-controller": "4.0.0-beta.3",
"@terra-money/wallet-provider": "4.0.0-beta.3",
"@terra-money/wallet-kit": "^1.0.4",
"@tippyjs/react": "^4.2.6",
"axios": "^0.27.2",
"bech32": "^2.0.0",
Expand Down
5 changes: 2 additions & 3 deletions src/app/InitWallet.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { PropsWithChildren, useEffect } from "react"
import { WalletStatus } from "@terra-money/wallet-types"
import { useWallet } from "@terra-money/use-wallet"
import { WalletStatus, useWallet } from "@terra-money/wallet-kit"
import { isWallet, useAuth } from "auth"
import Online from "./containers/Online"
import NetworkLoading from "./NetworkLoading"
Expand All @@ -15,7 +14,7 @@ const InitWallet = ({ children }: PropsWithChildren<{}>) => {
timeout={{
time: 3000,
fallback: () => {
localStorage.removeItem("__terra_extension_router_session__")
localStorage.removeItem("__wallet_kit_connected_wallet")
window.location.reload()
},
}}
Expand Down
24 changes: 13 additions & 11 deletions src/app/sections/ConnectWallet.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { useTranslation } from "react-i18next"
import UsbIcon from "@mui/icons-material/Usb"
import { useWallet } from "@terra-money/wallet-provider"
import { useWallet } from "@terra-money/wallet-kit"
import { STATION } from "config/constants"
import { RenderButton } from "types/components"
import { useAddress } from "data/wallet"
Expand All @@ -20,7 +20,7 @@ interface Props {
const ConnectWallet = ({ renderButton }: Props) => {
const { t } = useTranslation()

const { connect, availableConnections, availableInstallations } = useWallet()
const { connect, availableWallets } = useWallet()

const { available } = useAuth()

Expand All @@ -34,23 +34,25 @@ const ConnectWallet = ({ renderButton }: Props) => {
)

const list = [
...availableConnections
.filter(({ type }) => type !== "READONLY")
.map(({ type, identifier, name, icon }) => ({
...availableWallets
.filter(({ isInstalled }) => isInstalled)
.map(({ id, name, icon }) => ({
src: icon,
children: name,
onClick: () => connect(type, identifier),
onClick: () => connect(id),
})),
{
icon: <UsbIcon />,
to: "/auth/ledger",
children: t("Access with ledger"),
},
...availableInstallations.map(({ name, icon, url }) => ({
src: icon,
children: t(`Install ${name}`),
href: url,
})),
...availableWallets
.filter(({ isInstalled, website }) => !isInstalled && website)
.map(({ name, icon, website }) => ({
src: icon,
children: t(`Install ${name}`),
href: website ?? "",
})),
Comment on lines +49 to +55
Copy link
Contributor

@terran6 terran6 Jul 4, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Current

image

On Station Web

Screen.Recording.2023-07-04.at.4.45.22.PM.mov

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Most of the available extensions that we are currently showing don't even work with station web, and if they do they don't have interchain functionalities.

They can make a PR to wallet-kit if they want to fix their integration.

Copy link
Contributor

@terran6 terran6 Jul 4, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@alecande11 ok. And is there a reason we only have 2 staking assets to choose from to Stake on Mainnet if we are connected with a ledger? this is because of not allowing Alliance with ledger usage?

image

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it's because you imported only your 330 (Terra) account and not the 118 (using the cosmos app)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@alecande11 cool. so if we don't want the "Install Wallet" options, shouldn't we just take out that code then?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@terran6 which install wallet option?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@alecande11 The options in the video I posted which are in Station, but not this branch.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh, that code was on wallet-provider, it's already removed and replaced with wallet-kit

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nvm @terran6 I see what you mean, we still need the code that shows the install link since we are still using it.
If a user doesn't have the extension installed we want to redirect them to the installation page.

]

return (
Expand Down
7 changes: 5 additions & 2 deletions src/app/sections/Connected.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import styles from "./Connected.module.scss"
import { useRecoilState } from "recoil"
import { isWalletBarOpen, walletBarRoute, Path } from "pages/wallet/Wallet"
import { useNavigate } from "react-router-dom"
import { useWallet } from "@terra-money/use-wallet"
import { useConnectedWallet, useWallet } from "@terra-money/wallet-kit"
import {
Contacts as ContactsIcon,
Logout as LogoutIcon,
Expand All @@ -30,6 +30,7 @@ const Connected = () => {
const navigate = useNavigate()
const { wallet, getLedgerKey, disconnect: disconnectLedger } = useAuth()
const { disconnect } = useWallet()
const connectedWallet = useConnectedWallet()
const { data: name } = useTnsName(address ?? "")
const [, setWalletIsOpen] = useRecoilState(isWalletBarOpen)
const [, setWalletRoute] = useRecoilState(walletBarRoute)
Expand Down Expand Up @@ -117,7 +118,9 @@ const Connected = () => {
className={styles.button}
>
<span className={styles.button__text}>
{isWallet.local(wallet) ? wallet.name : truncate(name ?? address)}
{isWallet.local(wallet)
? wallet.name
: connectedWallet?.name ?? truncate(name ?? address)}
</span>
</Button>
</Popover>
Expand Down
5 changes: 2 additions & 3 deletions src/app/sections/Preferences.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import NetworkSetting from "./NetworkSetting"
import DisplayChainsSetting from "./DisplayChainsSetting"
import LanguageSetting from "./LanguageSetting"
import CurrencySetting from "./CurrencySetting"
import { useWallet, WalletStatus } from "@terra-money/wallet-provider"
import { useWallet, WalletStatus } from "@terra-money/wallet-kit"
import { ModalButton } from "components/feedback"
import SettingsButton from "components/layout/SettingsButton"
import { useNetwork, useNetworkName } from "data/wallet"
Expand Down Expand Up @@ -70,8 +70,7 @@ const Preferences = () => {
key: "network",
tab: t("Network"),
value: capitalize(networkName),
disabled:
!sandbox && connectedWallet.status === WalletStatus.WALLET_CONNECTED,
disabled: !sandbox && connectedWallet.status === WalletStatus.CONNECTED,
},
lang: {
key: "lang",
Expand Down
2 changes: 1 addition & 1 deletion src/auth/hooks/useAddress.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { useConnectedWallet } from "@terra-money/use-wallet"
import { useConnectedWallet } from "@terra-money/wallet-kit"
import { useNetworks } from "app/InitNetworks"
import { addressFromWords } from "utils/bech32"
import useAuth from "./useAuth"
Expand Down
4 changes: 2 additions & 2 deletions src/auth/hooks/useNetwork.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { atom, useRecoilState, useRecoilValue } from "recoil"
import { useNetworks } from "app/InitNetworks"
import { getStoredNetwork, storeNetwork } from "../scripts/network"
import { useWallet, WalletStatus } from "@terra-money/wallet-provider"
import { useWallet, WalletStatus } from "@terra-money/wallet-kit"
import { walletState } from "./useAuth"
import is from "../scripts/is"
import { useCustomLCDs } from "utils/localStorage"
Expand Down Expand Up @@ -51,7 +51,7 @@ export const useNetwork = (): Record<ChainID, InterchainNetwork> => {
}

// check connected wallet
if (connectedWallet.status === WalletStatus.WALLET_CONNECTED) {
if (connectedWallet.status === WalletStatus.CONNECTED) {
if (network !== "mainnet" && "phoenix-1" in connectedWallet.network) {
setNetwork("mainnet")
} else if (network !== "testnet" && "pisco-1" in connectedWallet.network) {
Expand Down
2 changes: 1 addition & 1 deletion src/auth/modules/select/SwitchWallet.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import useAuth from "../../hooks/useAuth"
import is from "../../scripts/is"
import SelectPreconfigured from "./SelectPreconfigured"
import styles from "./SwitchWallet.module.scss"
import { useWallet } from "@terra-money/use-wallet"
import { useWallet } from "@terra-money/wallet-kit"

const SwitchWallet = () => {
const { disconnect } = useWallet()
Expand Down
9 changes: 3 additions & 6 deletions src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,12 @@ import { render } from "react-dom"
import { BrowserRouter } from "react-router-dom"
import { ReactQueryDevtools } from "react-query/devtools"
import { RecoilRoot } from "recoil"
import { getChainOptions } from "@terra-money/wallet-controller"
import { WalletProvider } from "@terra-money/wallet-provider"
import { WalletProvider, getInitialConfig } from "@terra-money/wallet-kit"
import "tippy.js/dist/tippy.css"
import { initSentry } from "utils/analytics/setupSentry"
import { createAmplitudeClient } from "utils/analytics/setupAmplitude"

import "config/lang"
import { BRIDGE } from "config/constants"
import { debug } from "utils/env"

import "index.scss"
Expand All @@ -24,17 +22,16 @@ import InitChains from "app/InitChains"
import WithNodeInfo from "app/WithNodeInfo"
import InitQueryClient from "app/InitQueryClient"

const connectorOpts = { bridge: BRIDGE }
initSentry()
createAmplitudeClient()

getChainOptions().then((chainOptions) =>
getInitialConfig().then((defaultNetworks) =>
render(
<StrictMode>
<RecoilRoot>
<BrowserRouter>
<ScrollToTop />
<WalletProvider {...chainOptions} connectorOpts={connectorOpts}>
<WalletProvider defaultNetworks={defaultNetworks}>
<InitQueryClient>
<InitNetworks>
<WithNodeInfo>
Expand Down
14 changes: 3 additions & 11 deletions src/pages/stake/QuickStake.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,7 @@ import TokenSelector, {
TokenInterface,
} from "components/form/Selectors/TokenSelector/TokenSelector"
import { useState } from "react"
import { useAuth } from "auth"
import is from "auth/scripts/is"
import { useIsLedger } from "utils/ledger"

export enum QuickStakeAction {
DELEGATE = "Delegate",
Expand Down Expand Up @@ -89,7 +88,7 @@ const QuickStake = () => {
const readNativeDenom = useNativeDenoms()
const networks = useNetwork()
const [token, setToken] = useState<string | undefined>("uluna")
const { wallet } = useAuth()
const isLedger = useIsLedger()

const alliancesData = useAllAlliances()
const alliances = alliancesData.reduce(
Expand Down Expand Up @@ -242,13 +241,6 @@ const QuickStake = () => {
)
},
},
/*{
title: t("Chain"),
dataIndex: "chainID",
defaultSortOrder: "desc",
sorter: ({ chainID: a }, { chainID: b }) => a.localeCompare(b),
render: (chainID) => networks[chainID]?.name || chainID,
},*/
{
title: (
<span>
Expand Down Expand Up @@ -316,7 +308,7 @@ const QuickStake = () => {
<ModalButton
title={t("Staking Details")}
renderButton={(open) =>
is.ledger(wallet) && isAlliance ? (
isLedger && isAlliance ? (
<InlineFlex gap={4} start>
<Tooltip
content={
Expand Down
44 changes: 16 additions & 28 deletions src/txs/Tx.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,7 @@ import ErrorOutlineIcon from "@mui/icons-material/ErrorOutline"
import { isDenom } from "@terra-money/terra-utils"
import { Coin, Coins, CreateTxOptions } from "@terra-money/feather.js"
import { Fee } from "@terra-money/feather.js"
import { ConnectType, UserDenied } from "@terra-money/wallet-types"
import { CreateTxFailed, TxFailed } from "@terra-money/wallet-types"
import { useWallet, useConnectedWallet } from "@terra-money/use-wallet"
import { useWallet, useConnectedWallet } from "@terra-money/wallet-kit"

import { Contents } from "types/components"
import { has } from "utils/num"
Expand Down Expand Up @@ -137,7 +135,7 @@ function Tx<TxValues>(props: Props<TxValues>) {
[queryKey.tx.create, key, isWalletEmpty],
async () => {
if (!key.address || isWalletEmpty) return 0
if (!(wallet || connectedWallet?.availablePost)) return 0
if (!(wallet || connectedWallet)) return 0
if (!simulationTx || !simulationTx.msgs.length) return 0
try {
const unsignedTx = await lcd.tx.create([{ address: key.address }], {
Expand Down Expand Up @@ -279,6 +277,7 @@ function Tx<TxValues>(props: Props<TxValues>) {
!hideLoader && setLatestTx({ txhash, ...latestTxBase })
} else {
const { result } = await post({ ...tx, fee })
if (!result) throw new Error("Tx failed")
!hideLoader && setLatestTx({ txhash: result.txhash, ...latestTxBase })
}

Expand Down Expand Up @@ -414,14 +413,11 @@ function Tx<TxValues>(props: Props<TxValues>) {
)
}

const walletError =
connectedWallet?.connectType === ConnectType.READONLY
? t("Wallet is connected as read-only mode")
: !availableGasDenoms.length
? t("Insufficient balance to pay transaction fee")
: isWalletEmpty
? t("Coins required to post transactions")
: ""
const walletError = !availableGasDenoms.length
? t("Insufficient balance to pay transaction fee")
: isWalletEmpty
? t("Coins required to post transactions")
: ""

const submitButton = (
<>
Expand Down Expand Up @@ -468,22 +464,14 @@ function Tx<TxValues>(props: Props<TxValues>) {
const modal = !error
? undefined
: {
title:
error instanceof UserDenied ||
error?.toString().includes("UserDenied")
? t("Transaction was denied by user")
: error instanceof CreateTxFailed
? t("Failed to create tx")
: error instanceof TxFailed
? t("Tx failed")
: t("Error"),
children:
error instanceof UserDenied ||
error?.toString().includes("UserDenied") ? null : (
<Pre height={120} normal break>
{error?.message}
</Pre>
),
title: error?.toString().includes("UserDenied")
? t("Transaction was denied by user")
: t("Error"),
children: error?.toString().includes("UserDenied") ? null : (
<Pre height={120} normal break>
{error?.message}
</Pre>
),
}

return (
Expand Down
10 changes: 10 additions & 0 deletions src/utils/ledger.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
import BluetoothTransport from "@ledgerhq/hw-transport-web-ble"
import { LEDGER_TRANSPORT_TIMEOUT } from "config/constants"
import is from "auth/scripts/is"
import { useAuth } from "auth"
import { useConnectedWallet } from "@terra-money/wallet-kit"

export async function isBleAvailable() {
const n: any = navigator
Expand All @@ -9,3 +12,10 @@ export async function isBleAvailable() {
export async function createBleTransport() {
return await BluetoothTransport.create(LEDGER_TRANSPORT_TIMEOUT)
}

export function useIsLedger(): boolean {
const { wallet } = useAuth()
const connectedWallet = useConnectedWallet()

return connectedWallet?.ledger || is.ledger(wallet)
}