Skip to content

Commit

Permalink
chore: readme update
Browse files Browse the repository at this point in the history
  • Loading branch information
matthew1809 committed Jul 12, 2024
1 parent 503f15f commit 21ebfdc
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 47 deletions.
71 changes: 28 additions & 43 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,23 +3,10 @@
![](./banner.png)

<h4 align="center">
<a href="https://docs.scaffoldeth.io">Documentation</a> |
<a href="https://scaffoldeth.io">Website</a>
<a href="https://www.youtube.com/watch?v=dkONR9dJD2g">Video Walkthrough</a>
</h4>

🧪 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

Expand All @@ -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:
Expand Down Expand Up @@ -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.
Expand All @@ -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.
Expand All @@ -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)
10 changes: 6 additions & 4 deletions packages/nextjs/app/safe/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -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);
}
Expand All @@ -179,6 +179,8 @@ const SafePage = () => {
setTransferDetails(transferDetails);
}

console.log(transactionDetails, transferDetails);

setRefreshingTransactions(false);
};

Expand Down Expand Up @@ -434,7 +436,7 @@ const SafePage = () => {
<div className="flex flex-row gap-8">
<a target="_blank" href={`${BASE_SEPOLIA_BLOCKSCOUT_TX_BASE_URL}/${tx.hash}`}>
<div className="flex flex-row gap-2 items-center">
{`${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)}`}
<ExternalLinkIcon />
</div>
</a>
Expand All @@ -447,7 +449,7 @@ const SafePage = () => {
<div className="flex flex-row gap-8">
<a target="_blank" href={`${BASE_SEPOLIA_BLOCKSCOUT_TX_BASE_URL}/${tx.hash}`}>
<div className="flex flex-row gap-2 items-center">
{`${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)}`}
<ExternalLinkIcon />
</div>
</a>
Expand Down
16 changes: 16 additions & 0 deletions packages/nextjs/lib/networks.ts
Original file line number Diff line number Diff line change
@@ -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,
Expand Down

0 comments on commit 21ebfdc

Please sign in to comment.