From 21ebfdce9c135fed1f78b2bab53f7e5ebc6ae75b Mon Sep 17 00:00:00 2001 From: Matthew Foyle Date: Fri, 12 Jul 2024 10:04:16 +0200 Subject: [PATCH] chore: readme update --- README.md | 71 ++++++++++++------------------- packages/nextjs/app/safe/page.tsx | 10 +++-- packages/nextjs/lib/networks.ts | 16 +++++++ 3 files changed, 50 insertions(+), 47 deletions(-) diff --git a/README.md b/README.md index ccd69d1..08a8ad9 100644 --- a/README.md +++ b/README.md @@ -3,23 +3,10 @@ ![](./banner.png)

- Documentation | - Website + Video Walkthrough

-πŸ§ͺ An open-source, up-to-date toolkit for building decentralized applications (dapps) on the Ethereum blockchain. It's designed to make it easier for developers to create and deploy smart contracts and build user interfaces that interact with those contracts. - -βš™οΈ Built using NextJS, Dynamic, Hardhat, Wagmi, Viem, and Typescript. - -- βœ… **Contract Hot Reload**: Your frontend auto-adapts to your smart contract as you edit it. -- πŸͺ **[Custom hooks](https://docs.scaffoldeth.io/hooks/)**: Collection of React hooks wrapper around [wagmi](https://wagmi.sh/) to simplify interactions with smart contracts with typescript autocompletion. -- 🧱 [**Components**](https://docs.scaffoldeth.io/components/): Collection of common web3 components to quickly build your frontend. -- πŸ”₯ **Burner Wallet & Local Faucet**: Quickly test your application with a burner wallet and local faucet. - -![Debug Contracts tab](https://github.com/scaffold-eth/scaffold-eth-2/assets/55535804/b237af0c-5027-4849-a5c1-2e31495cccb1) - -πŸ” Authentication & User Management with [Dynamic](https://dynamic.xyz/) -- Ethereum, Base, Polygon, Arbitrum, Scroll, Zircuit, ZERΟ΄, Morph & Rootstock enabled by default +πŸ§ͺ An open-source, up-to-date toolkit for building decentralized applications (dapps) on the Ethereum blockchain. It's designed to make it easier for developers to create and deploy smart contracts and build user interfaces that interact with those contracts as well as add EthGlobal partner technology such as account abstraction, chain abstraction, onboarding, transaction exploring, EVM networks, custom chains and much more! ## Requirements @@ -29,6 +16,12 @@ Before you begin, you need to install the following tools: - Yarn ([v1](https://classic.yarnpkg.com/en/docs/install/) or [v2+](https://yarnpkg.com/getting-started/install)) - [Git](https://git-scm.com/downloads) +- You have to get a [Pimlico API key](https://dashboard.pimlico.io/sign-in) and put it in your env file (`NEXT_PUBLIC_PIMLICO_API_KEY`). + +- You should send some ERC20 (USDC is better) to your Safe smart wallet in order to use the transfer and cross-chain transfer capabilities. + +- You can use the default Dynamic environment ID to test, but we recommend you add your own as soon as possible in the env file (NEXT_PUBLIC_DYNAMIC_ENVIRONMENT_ID) + ## Quickstart To get started with Scaffold-ETH 2 Hacker Edition, follow the steps below: @@ -65,24 +58,19 @@ yarn start Visit your app on: `http://localhost:3000`. You can interact with your smart contract using the `Debug Contracts` page. You can tweak the app config in `packages/nextjs/scaffold.config.ts`. -**What's next**: -- Edit your smart contract `YourContract.sol` in `packages/hardhat/contracts` -- Edit your frontend homepage at `packages/nextjs/app/page.tsx`. For guidance on [routing](https://nextjs.org/docs/app/building-your-application/routing/defining-routes) and configuring [pages/layouts](https://nextjs.org/docs/app/building-your-application/routing/pages-and-layouts) checkout the Next.js documentation. -- Edit your deployment scripts in `packages/hardhat/deploy` -- Edit your smart contract test in: `packages/hardhat/test`. To run test use `yarn hardhat:test` +## Features Overview -## Documentation - -Visit our [docs](https://docs.scaffoldeth.io) to learn how to start building with Scaffold-ETH 2. - -To know more about its features, check out our [website](https://scaffoldeth.io). +βš™οΈ Built using NextJS, Dynamic, Hardhat, Wagmi, Viem, and Typescript. -# Hacker Kit Implementation +- βœ… **Contract Hot Reload**: Your frontend auto-adapts to your smart contract as you edit it. +- πŸͺ **[Custom hooks](https://docs.scaffoldeth.io/hooks/)**: Collection of React hooks wrapper around [wagmi](https://wagmi.sh/) to simplify interactions with smart contracts with typescript autocompletion. +- 🧱 [**Components**](https://docs.scaffoldeth.io/components/): Collection of common web3 components to quickly build your frontend. +- πŸ”₯ **Burner Wallet & Local Faucet**: Quickly test your application with a burner wallet and local faucet. -## Overview +![Debug Contracts tab](https://github.com/scaffold-eth/scaffold-eth-2/assets/55535804/b237af0c-5027-4849-a5c1-2e31495cccb1) -- βœ… **Dynamic widget**: Provides an interactive and responsive widget for interacting with your embedded wallet. You can create your embedded wallet using social logins or connecting an existing wallet. +- 🀝 **Dynamic onboarding**: Provides an interactive and responsive widget for interacting with your embedded wallet. You can create your embedded wallet using social logins or connecting an existing wallet. - πŸ”₯ **Safe Smart Wallet**: Provides the most battle-tested ERC-4337 compatible smart wallet, improving users' UX. - πŸ“± **Permissionless.js (Pimlico) for gasless transactions**: Facilitates transactions without requiring users to pay gas fees. Pimlico is the world's most popular ERC-4337 account abstraction infrastructure platform. - β›“ **Chainlink CCIP for cross-chain transactions**: Enables seamless transfers across different blockchain networks. @@ -102,25 +90,20 @@ Out of the box with the Dynamic implementation you get: You can add many more via [the dashboard](https://app.dynamic.xyz/dashboard/chains-and-networks), or using [custom EVM Networks](https://docs.dynamic.xyz/chains/evmNetwork)! -## Requirements +*This means you can instantly plug in any local chain you have running, like from Arbitrum Orbit, Polygon CDK etc!* -- You have to get a [Pimlico API key](https://dashboard.pimlico.io/sign-in) and put it in your env file (`NEXT_PUBLIC_PIMLICO_API_KEY`). -- Run `yarn chain` on a chain different from "local" to leverage the Smart wallet features. `yarn chain` runs on base-sepolia by default in this repo. You can easily change it in `/nextjs/scaffold.config.ts`. -- You should send some ERC20 (USDC is better) to your Safe smart wallet in order to use the transfer and cross-chain transfer capabilities. -- You can use the default Dynamic environment ID to test, but we recommend you add your own as soon as possible in the env file (NEXT_PUBLIC_DYNAMIC_ENVIRONMENT_ID) - -## Safe Smart Wallet and Permissionless.js (Pimlico) +### Safe Smart Wallet and Permissionless.js (Pimlico) Navigate to the "Smart Wallet" section and click on "Deploy Safe Account". This action calls the `createSmartAccountClient` function from Permissionless.js. More details can be found [here](https://docs.pimlico.io/permissionless/how-to/signers/privy#create-the-smartaccountclient). The Safe address is calculated deterministically based on your Dynamic embedded wallet address. The actual deployment of the Safe wallet occurs when you initiate your first transaction, such as a transfer. -### Executing a Transfer: +#### Executing a Transfer: You can perform a transfer of ERC-20 tokens in a gasless way. The app uses `smartAccountClient.writeContract` from Permissionless.js ([source](https://docs.pimlico.io/permissionless/reference/smart-account-actions/writeContract)). This allows for gasless transfers, sponsored by the Pimlico Paymaster on testnets. ERC-20 transfers are supported on any chain supported by Pimlico. Refer to the supported chains documentation [here](https://docs.pimlico.io/infra/bundler/bundler-errors/chain-not-supported#adding-new-chains). -## Chainlink CCIP for Cross-Chain Transactions +### Chainlink CCIP for Cross-Chain Transactions A custom Chainlink CCIP cross-chain transfer smart contract has been deployed, allowing for USDC (only!) transfers. The contract has ETH on Base Sepolia to cover CCIP fees. @@ -133,13 +116,15 @@ The app uses `smartAccountClient.writeContract` ([source](https://docs.pimlico.i The implementation is flexible, allowing for easy extension to support additional chains or rewriting the contract. If your allowance is lower than the amount to transfer, you are asked to execute an approve too. -## Blockscout for Checking Transactions +### Blockscout for Checking Transactions In the "Transactions" section, users can view all transactions executed by the Safe smart wallet within the session. The app integrates the [Blockscout API](https://docs.blockscout.com/for-users/api) to fetch and display transaction details, providing a transparent and user-friendly way to track activities. -## Contributing to Scaffold-ETH 2 - -We welcome contributions to Scaffold-ETH 2! - -Please see [CONTRIBUTING.MD](https://github.com/scaffold-eth/scaffold-eth-2/blob/main/CONTRIBUTING.md) for more information and guidelines for contributing to Scaffold-ETH 2. +## Further Documentation +- [Dynamic](https://docs.dynamic.xyz/) +- [Original Scaffold Eth 2](https://scaffold-eth-2-docs.vercel.app/) +- [Pimlico](https://docs.pimlico.io/) +- [Safe](https://docs.safe.global/) +- [Chainlink](https://docs.chain.link/) +- [Blockscout](https://docs.blockscout.com/for-users/api/rpc-endpoints) diff --git a/packages/nextjs/app/safe/page.tsx b/packages/nextjs/app/safe/page.tsx index d38f894..4bbe55d 100644 --- a/packages/nextjs/app/safe/page.tsx +++ b/packages/nextjs/app/safe/page.tsx @@ -167,8 +167,8 @@ const SafePage = () => { const transactions = await getTransactionsOnBaseSepolia(primaryWallet.address); const transfers = await getTokenTransfersOnBaseSepolia(primaryWallet.address); - for (const txHash of transactions) { - const transactionDetail = await getTransactionOnBaseSepoliaByHash(txHash); + for (const tx of transactions) { + const transactionDetail = await getTransactionOnBaseSepoliaByHash(tx.hash); txDetails.push(transactionDetail); setTransactionDetails(txDetails); } @@ -179,6 +179,8 @@ const SafePage = () => { setTransferDetails(transferDetails); } + console.log(transactionDetails, transferDetails); + setRefreshingTransactions(false); }; @@ -434,7 +436,7 @@ const SafePage = () => {
- {`${tx.hash.substring(0, 8)}...${tx.hash.substring(tx.hash.length - 8)}`} + {tx.hash && `${tx.hash.substring(0, 8)}...${tx.hash.substring(tx.hash.length - 8)}`}
@@ -447,7 +449,7 @@ const SafePage = () => {
- {`${tx.hash.substring(0, 8)}...${tx.hash.substring(tx.hash.length - 8)}`} + {tx.hash && `${tx.hash.substring(0, 8)}...${tx.hash.substring(tx.hash.length - 8)}`}
diff --git a/packages/nextjs/lib/networks.ts b/packages/nextjs/lib/networks.ts index 3455401..ef55615 100644 --- a/packages/nextjs/lib/networks.ts +++ b/packages/nextjs/lib/networks.ts @@ -1,4 +1,20 @@ export const customEvmNetworks = [ + { + blockExplorerUrls: ["http://localhost"], + chainId: 43490458484, + chainName: "My Arbitrum L3 Chain", + iconUrls: ["https://www.shutterstock.com/image-vector/moon-icon-vector-star-logo-600nw-1403123270.jpg"], + name: "My Arbitrum L3 Chain", + nativeCurrency: { + decimals: 18, + name: "Ether", + symbol: "ETH", + }, + networkId: 43490458484, + + rpcUrls: ["http://127.0.0.1:8449"], + vanityName: "Into Orbit", + }, { blockExplorerUrls: ["https://explorer-holesky.morphl2.io/"], chainId: 2810,