Skip to content

Commit

Permalink
Merge branch 'main' of github.com:cosmology-tech/cosmos-kit
Browse files Browse the repository at this point in the history
  • Loading branch information
liujun93 committed Sep 15, 2023
2 parents 60eedef + 0cde489 commit ed60791
Show file tree
Hide file tree
Showing 9 changed files with 37 additions and 30 deletions.
2 changes: 1 addition & 1 deletion packages/core/src/types/wallet.ts
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ export interface Wallet {
connectEventNamesOnWindow?: string[];
connectEventNamesOnClient?: string[];
downloads?: DownloadInfo[];
logo?: string;
logo?: string | { major: string; minor: string };
walletconnect?: {
name: string;
projectId: string;
Expand Down
1 change: 0 additions & 1 deletion packages/example/pages/_app.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,6 @@ function MyApp({ Component, pageProps }: AppProps) {
...frontierWallets,
...coin98Wallets,
...finWallets,
...leapCosmosMetamask,
]}
throwErrors={false}
subscribeConnectEvents={false}
Expand Down
6 changes: 3 additions & 3 deletions packages/react/src/modal/components/views/WalletList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ function DynamicWalletList({ wallets, onClose }: DynamicWalletListProps) {
};
}, []);

const walletsData: ConnectModalWalletListProps['wallets'] = useMemo(
const walletsData = useMemo(
() =>
wallets
.sort((a, b) => {
Expand All @@ -61,9 +61,9 @@ function DynamicWalletList({ wallets, onClose }: DynamicWalletListProps) {
wallet.walletInfo.mode === 'wallet-connect'
? 'walletConnect'
: undefined,
btmLogo: wallet.walletInfo.extends,
btmLogo: typeof wallet.walletInfo.logo === 'object' ? wallet.walletInfo.logo.minor : wallet.walletInfo.extends,
badge: ({ MetaMask: 'SNAP' })[wallet.walletInfo.extends],
shape: i < 2 && isLargeScreen ? 'square' : 'list',
shape: (i < 2 && isLargeScreen ? 'square' : 'list') as ('square' | 'list'),
downloadUrl: '',
originalWallet: wallet,
};
Expand Down
21 changes: 10 additions & 11 deletions packages/react/src/modal/components/views/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,23 +22,22 @@ export type ModalViewImplGetter = (
props: WalletViewProps | WalletListViewProps
) => ModalViewImpl;

export const defaultModalViews: Record<keyof ModalViews, ModalViewImplGetter> =
{
Connecting: ConnectingView,
Connected: ConnectedView,
Error: ErrorView,
NotExist: NotExistView,
Rejected: RejectedView,
QRCode: QRCodeView,
WalletList: WalletListView,
};
export const defaultModalViews: Record<keyof ModalViews, ModalViewImplGetter> = {
Connecting: ConnectingView,
Connected: ConnectedView,
Error: ErrorView,
NotExist: NotExistView,
Rejected: RejectedView,
QRCode: QRCodeView,
WalletList: WalletListView,
};

export function getWalletProp(wallet: Wallet) {
const { prettyName, mode, name, logo, mobileDisabled } = wallet;
return {
name,
prettyName,
logo,
logo: typeof logo === 'object' ? logo.major : logo,
mobileDisabled:
typeof mobileDisabled === 'boolean' ? mobileDisabled : mobileDisabled(),
isMobile: mode === 'wallet-connect',
Expand Down
2 changes: 1 addition & 1 deletion wallets/leap-metamask-cosmos-snap/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
"dependencies": {
"@chain-registry/keplr": "1.8.0",
"@cosmos-kit/core": "^2.6.2",
"@leapwallet/cosmos-snap-provider": "0.1.21",
"@leapwallet/cosmos-snap-provider": "0.1.22",
"@metamask/providers": "^11.1.1"
},
"peerDependencies": {
Expand Down
5 changes: 4 additions & 1 deletion wallets/leap-metamask-cosmos-snap/src/constant.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1,5 @@
export const ICON =
export const LEAP_LOGO =
'';

export const METAMASK_LOGO =
''
16 changes: 11 additions & 5 deletions wallets/leap-metamask-cosmos-snap/src/extension/client.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { AminoSignResponse, OfflineAminoSigner, StdSignature, StdSignDoc } from '@cosmjs/amino';
import { Algo, DirectSignResponse } from '@cosmjs/proto-signing';
import { SignType } from '@cosmos-kit/core';
import { ChainRecord, SignType } from '@cosmos-kit/core';
import { SignOptions, WalletClient } from '@cosmos-kit/core';

import { ChainInfo, CosmjsOfflineSigner, experimentalSuggestChain, signArbitrary } from '@leapwallet/cosmos-snap-provider';
Expand Down Expand Up @@ -82,11 +82,11 @@ export class CosmosSnapClient implements WalletClient {
authInfoBytes?: Uint8Array | null;
chainId?: string | null;
accountNumber?: ProviderLong | null;
}) {
}): Promise<DirectSignResponse> {
const signature = (requestSignature(
chainId,
signer,
signDoc // @ts-nocheck
signDoc
) as unknown) as DirectSignResponse;

const accountNumber = signDoc.accountNumber;
Expand All @@ -100,7 +100,7 @@ export class CosmosSnapClient implements WalletClient {
signature: signature.signature,
signed: {
...signature.signed,
accountNumber: `${modifiedAccountNumber.toString()}`,
accountNumber: modifiedAccountNumber,
authInfoBytes: new Uint8Array(
Object.values(signature.signed.authInfoBytes)
),
Expand All @@ -121,7 +121,13 @@ export class CosmosSnapClient implements WalletClient {
)) as unknown as StdSignature;
}

async addChain(chainInfo: ChainInfo) {
async addChain(chainRecord: ChainRecord): Promise<void> {
const chainInfo: ChainInfo = {
chainId: chainRecord?.chain?.chain_id,
chainName: chainRecord?.chain?.chain_name,
bip44: { coinType: chainRecord?.chain?.slip44 },
bech32Config: { bech32PrefixAccAddr: chainRecord?.chain?.bech32_prefix },
}
await experimentalSuggestChain(chainInfo);
}
}
6 changes: 3 additions & 3 deletions wallets/leap-metamask-cosmos-snap/src/extension/registry.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import { Wallet } from '@cosmos-kit/core';

import { ICON } from '../constant';
import { LEAP_LOGO, METAMASK_LOGO } from '../constant';

export const metamaskCosmosSnapInfo: Wallet = {
name: 'leap-metamask-cosmos-snap',
description:
'The Leap Cosmos MetaMask Snap allows signing of Cosmos transactions using MetaMask.',
prettyName: 'Leap Cosmos MetaMask Snap',
logo: ICON,
prettyName: 'Leap Cosmos MetaMask',
logo: { major: METAMASK_LOGO, minor: LEAP_LOGO },
mode: 'extension',
extends: 'MetaMask',
mobileDisabled: () => !('ethereum' in window),
Expand Down
8 changes: 4 additions & 4 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -3039,10 +3039,10 @@
big-integer "^1.6.48"
utility-types "^3.10.0"

"@leapwallet/[email protected].20":
version "0.1.20"
resolved "https://registry.yarnpkg.com/@leapwallet/cosmos-snap-provider/-/cosmos-snap-provider-0.1.20.tgz#b0c36f3b0e2cfa441769c6ed93bd4238f62a66d4"
integrity sha512-VUoxun5prJdLTjkCRU3EBLwx2CNnvYnP9deSiffwCx4lQQzcN38gSIHs3rfXpdyLdPv1jIi6nVVsqIVKFzvB1w==
"@leapwallet/[email protected].22":
version "0.1.22"
resolved "https://registry.yarnpkg.com/@leapwallet/cosmos-snap-provider/-/cosmos-snap-provider-0.1.22.tgz#684bf04c23721268803ae9fea7a88c6d3bbbea27"
integrity sha512-4shW8JU6bRMwY1HGey7dQeFnL7yL1bU9V8wJ1Y6LcFv2XDxQx3pNpaXsmUNAcf3G/EViZkdrFm++KmmDmLAyIA==
dependencies:
"@cosmjs/amino" "^0.31.0"
"@cosmjs/proto-signing" "^0.31.0"
Expand Down

0 comments on commit ed60791

Please sign in to comment.