Skip to content

Commit

Permalink
chore: update wagmi example to latest version (#504)
Browse files Browse the repository at this point in the history
* yarn.lock cleanup

* bump dev dependencies
  • Loading branch information
dasanra authored Aug 9, 2023
1 parent a492a63 commit ad80482
Show file tree
Hide file tree
Showing 8 changed files with 1,055 additions and 1,631 deletions.
2 changes: 1 addition & 1 deletion examples/wagmi/.env.example
Original file line number Diff line number Diff line change
@@ -1 +1 @@
REACT_APP_ALCHEMY_ID=
REACT_APP_WALLETCONNECT_PROJECT_ID=
16 changes: 7 additions & 9 deletions examples/wagmi/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,22 +3,20 @@
"version": "0.2.0",
"private": true,
"dependencies": {
"@safe-global/safe-apps-provider": "^0.18.0",
"@safe-global/safe-apps-sdk": "^8.1.0",
"@gnosis.pm/safe-apps-wagmi": "2.1.0",
"@types/react": "^18.0.27",
"@types/react-dom": "^18.0.10",
"@wagmi/core": "^0.8.19",
"buffer": "^6.0.3",
"ethers": "^5.7.2",
"events": "^3.3.0",
"process": "^0.11.10",
"react": "^18.2.0",
"react-dom": "^18.2.0",
"react-scripts": "5.0.1",
"util": "^0.12.5",
"wagmi": "^0.10.15",
"web-vitals": "^3.1.0"
"viem": "^1.0.0",
"wagmi": "^1.3.9",
"web-vitals": "^3.4.0"
},
"devDependencies": {
"@types/react": "^18.0.27",
"@types/react-dom": "^18.0.10"
},
"scripts": {
"start": "react-scripts start",
Expand Down
2 changes: 1 addition & 1 deletion examples/wagmi/src/components/Account.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { useAccount, useEnsName } from 'wagmi';

export function Account() {
const { address } = useAccount();
const { data: ensNameData } = useEnsName({ address: address });
const { data: ensNameData } = useEnsName({ address });

return (
<div>
Expand Down
6 changes: 2 additions & 4 deletions examples/wagmi/src/components/Connect.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,8 @@ export function Connect() {
const { isConnecting, connector: activeConnector } = useAccount();
const { disconnect } = useDisconnect();
const { config } = usePrepareSendTransaction({
request: {
to: '0x000000000000000000000000000000000000beef',
value: '0',
},
to: '0x000000000000000000000000000000000000beef',
value: BigInt('0'),
});

const { sendTransactionAsync } = useSendTransaction(config);
Expand Down
50 changes: 30 additions & 20 deletions examples/wagmi/src/index.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import * as React from 'react';
import * as ReactDOM from 'react-dom/client';

import { WagmiConfig, configureChains, createClient } from 'wagmi';
import { WagmiConfig, createConfig, configureChains, Connector } from 'wagmi';
import { mainnet, goerli } from 'wagmi/chains';
import { alchemyProvider } from 'wagmi/providers/alchemy';
import { SafeConnector } from '@gnosis.pm/safe-apps-wagmi';
import { publicProvider } from 'wagmi/providers/public';
import { SafeConnector } from 'wagmi/connectors/safe';
import { InjectedConnector } from 'wagmi/connectors/injected';
import { MetaMaskConnector } from 'wagmi/connectors/metaMask';
import { WalletConnectConnector } from 'wagmi/connectors/walletConnect';
Expand All @@ -19,36 +19,46 @@ if (!window.Buffer) {
window.Buffer = Buffer;
}

const WALLETCONNECT_PROJECT_ID = process.env.REACT_APP_WALLETCONNECT_PROJECT_ID

const defaultChains = [mainnet, goerli];
const alchemyId = process.env.REACT_APP_ALCHEMY_ID || 'UuUIg4H93f-Bz5qs91SuBrro7TW3UShO';

const { chains, provider } = configureChains(defaultChains, [alchemyProvider({ apiKey: alchemyId })]);
const { chains, publicClient } = configureChains(defaultChains, [publicProvider()]);

let connectors: Connector[] = [
new SafeConnector({ chains }),
new MetaMaskConnector({ chains }),
new InjectedConnector({
chains,
options: {
name: 'Injected',
shimDisconnect: true,
},
}),
];

const client = createClient({
connectors: [
new SafeConnector({ chains }),
new MetaMaskConnector({ chains }),
if (WALLETCONNECT_PROJECT_ID) {
// A WalletConnect ID is provided so we add the Connector for testing purposes
connectors = [
...connectors,
new WalletConnectConnector({
chains,
options: {
qrcode: true,
},
}),
new InjectedConnector({
chains,
options: {
name: 'Injected',
shimDisconnect: true,
projectId: WALLETCONNECT_PROJECT_ID,
},
}),
],
provider,
];
}

const config = createConfig({
connectors: connectors,
publicClient,
});

const root = ReactDOM.createRoot(document.getElementById('root') as HTMLElement);
root.render(
<React.StrictMode>
<WagmiConfig client={client}>
<WagmiConfig config={config}>
<App />
</WagmiConfig>
</React.StrictMode>,
Expand Down
8 changes: 4 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,12 @@
"@types/node": "^18.11.18",
"@typescript-eslint/eslint-plugin": "^5.49.0",
"@typescript-eslint/parser": "^5.49.0",
"eslint": "8.45.0",
"eslint": "^8.46.0",
"eslint-config-prettier": "^8.8.0",
"eslint-plugin-import": "^2.27.5",
"eslint-plugin-import": "^2.28.0",
"eslint-plugin-prettier": "^5.0.0",
"jest": "^29.6.1",
"jest-environment-jsdom": "^29.6.1",
"jest": "^29.6.2",
"jest-environment-jsdom": "^29.6.2",
"lerna": "^7.1.4",
"prettier": "^3.0.0",
"rimraf": "^5.0.1",
Expand Down
10 changes: 5 additions & 5 deletions packages/safe-apps-wagmi/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,26 +5,26 @@ A connector for the wagmi library. The source code is available in the `wagmi/re
## Installation

```bash
yarn add @wagmi/connectors
yarn add wagmi

npm i @wagmi/connectors
npm i wagmi
```

## Integration steps

1. Import `SafeConnector` and include it in the wagmi client configuration options

```js
import { SafeConnector } from '@wagmi/connectors/safe';
import { SafeConnector } from 'wagmi/connectors/safe';

const chains = [];

const client = createClient({
const config = createConfig({
connectors: [
new SafeConnector({
chains,
options: {
allowedDomains: [/gnosis-safe.io$/, /app.safe.global$/],
allowedDomains: [/app.safe.global$/],
debug: false,
},
}),
Expand Down
Loading

0 comments on commit ad80482

Please sign in to comment.