Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ethereum-boilerplate/ethereum-react-native-boilerplate
The ultimate full-stack Ethereum React Native Dapp Boilerplate which gives you maximum flexibility and speed. Feel free to fork and contribute. Although this repo is called "Ethereum Boilerplate" it works with any EVM system! Happy BUIDL!👷♂️
https://github.com/ethereum-boilerplate/ethereum-react-native-boilerplate
ethereum react-native walletconnect
Last synced: about 7 hours ago
JSON representation
The ultimate full-stack Ethereum React Native Dapp Boilerplate which gives you maximum flexibility and speed. Feel free to fork and contribute. Although this repo is called "Ethereum Boilerplate" it works with any EVM system! Happy BUIDL!👷♂️
- Host: GitHub
- URL: https://github.com/ethereum-boilerplate/ethereum-react-native-boilerplate
- Owner: ethereum-boilerplate
- License: mit
- Created: 2021-10-25T20:24:38.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-09-10T17:13:35.000Z (over 2 years ago)
- Last Synced: 2025-01-04T05:18:02.243Z (7 days ago)
- Topics: ethereum, react-native, walletconnect
- Language: JavaScript
- Homepage:
- Size: 20.9 MB
- Stars: 547
- Watchers: 19
- Forks: 284
- Open Issues: 29
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome - ethereum-boilerplate/ethereum-react-native-boilerplate - The ultimate full-stack Ethereum React Native Dapp Boilerplate which gives you maximum flexibility and speed. Feel free to fork and contribute. Although this repo is called "Ethereum Boilerplate" it works with any EVM system! Happy BUIDL!👷♂️ (JavaScript)
README
# ethereum-react-native-boilerplate
> React Native components and hooks for fast building dApps without running own backend
[![Discord](https://img.shields.io/badge/discord-join%20chat-blue.svg?style=for-the-badge&logo=discord)](https://discord.com/invite/wV7nkDYGyZ)
[![Discourse topics](https://img.shields.io/discourse/topics?label=Forum%20Support&logo=Moralis&server=https%3A%2F%2Fforum.moralis.io&style=for-the-badge)](https://forum.moralis.io/t/ethereum-react-native-boilerplate-questions/4511)
[![GitHub last commit](https://img.shields.io/github/last-commit/ethereum-boilerplate/ethereum-react-native-boilerplate?color=informational&style=for-the-badge)](https://github.com/ethereum-boilerplate/ethereum-react-native-boilerplate/commits/main)![GitHub Repo stars](https://img.shields.io/github/stars/ethereum-boilerplate/ethereum-react-native-boilerplate?style=social)
[![Twitter URL](https://img.shields.io/twitter/url?style=social&url=https%3A%2F%2Ftwitter.com%2FMoralisWeb3)](https://twitter.com/MoralisWeb3)This project is using:
- [create-react-native-dapp](https://github.com/cawfree/create-react-native-dapp) to bootstrap the project.
- [WalletConnect v1 react-native integration](https://docs.walletconnect.com/1.0/quick-start/dapps/react-native) for authenthication (we use a slightly modiefied version, located in `./src/WalletConnect` to allow to modify the `enable` function of Moralis).
- [react-moralis](https://github.com/MoralisWeb3/react-moralis) for react hooksThere are many components in this boilerplate that do not require an active web3 provider, they use Moralis Web3 API. Moralis supports the most popular blockchains and their test networks. You can find a list of all available networks in [Moralis Supported Chains](https://docs.moralis.io/moralis-server/web3-sdk/intro#supported-chains)
Please check the [official documentation of Moralis](https://docs.moralis.io/#user) for all the functionalities of Moralis.
Check the corresponding docs for additional information and help.
![Iphone demo 2 (2)](https://user-images.githubusercontent.com/9363303/152293950-b0ddd2e9-2c6e-43d2-81ef-60dad43f21a5.gif)
# ⭐️ `Star us`
If this boilerplate helps you build Ethereum mobile dapps faster - please star this project, every star makes us very happy!
# 🤝 `Need help?`
If you need help with setting up the boilerplate or have other questions - don't hesitate to write in our community forum and we will check asap. [Forum link](https://forum.moralis.io/t/ethereum-react-native-boilerplate-questions/4511). The best thing about this boilerplate is the super active community ready to help at any time! We help each other.
# 🚀 Quick Start
💿 Install all dependencies:
```sh
cd ethereum-react-native-boilerplate
yarn installcd ios
pod installcd ..
```🚴♂️ Run your App:
IMPORTANT:
- To run the app and be able to actually login do the following:
- Make sure to have Xcode installed on your machine if you wish to run it in iOS development and Android Studio if you want it in Android.
- For M1 users: Access apps folder then right click on Xcode and click on more info. Then select "Open Using Rosetta".
- Connect a physical phone device. Open terminal/cmd and run `adb devices` and see if your android device id is listed.
- Install your preferred wallet on your device: (Metamask, Trust Wallet etc..)- IOS:
- Command
`react-native run-ios` for react-native-cli package users or
`npx react-native run-ios` if you're using the latest recommended version of node.js
- Android:
- Command
`react-native run-android` for react-native-cli package users or
`npx react-native run-android` if you're using the latest recommended version of node.jsWhat's New:
- React Native Debugger. Debugging your dapp in a browser is straightforward with React Native Debugger. Simply open the simulator on iOS and press `cmd + d`; for the Android emulator, `press cmd + m` and pick Debug from the React Native Debug menu. If you're using a physical device, simply shake it until the debugger menu appears.
# 🧭 Table of contents
- [ethereum-react-native-boilerplate](#ethereum-react-native-boilerplate)
`](#address-)
- [⭐️ `Star us`](#️-star-us)
- [🤝 `Need help?`](#-need-help)
- [🚀 Quick Start](#-quick-start)
- [🧭 Table of contents](#-table-of-contents)
- [🏗 Ethereum Components](#-ethereum-components)
- [``](#cryptoauth-)
- [``](#nativebalance-)
- [``](#erc20balance-)
- [``](#assets-)
- [``](#recenttransactions-)
- [``](#transactiondetails-)
- [``](#blockie-)
- [`
- [🧰 Ethereum Hooks](#-ethereum-hooks)
- [`useERC20balance()`](#useerc20balance)
- [`useNativeBalance()`](#usenativebalance)
- [`useERC20Transfers()`](#useerc20transfers)
- [`useNativeTransactions()`](#usenativetransactions)
- [`useTokenPrice()`](#usetokenprice)
- [`useNFTTransfers()`](#usenfttransfers)
- [`useNFTBalance()`](#usenftbalance)# 🏗 Ethereum Components
🛠 The ready for use react-native-components are located in `frontend/Components`. They are designed to be used anywhere in your dApp.
### ``
📒 `` : Easy web3 authentication via WalletConnect.
### ``
**Options**:
- chain: chain to fetch data from.
### ``
📨 `` : Displays all ERC20 Balances with Price.
**Options**:- `chain`: chain to fetch data from.
### ``
💰 `` : Screen to display all Chain ERC20 and NAtive Assets with Prices
### ``
💰 `` : Screen to display all Chain ERC20 Transactions
### ``
`` : Modal to display all ERC20 Transaction related content
### ``
A custom Blockie indenticon generator for React Native.
**Options**:
- `address`: Address to generate Blockie Icon from.
- `size`: Size of the Icon. _For more custom sizes, edit the component as to your liking_### `
`Displays The user address that is copyable
# 🧰 Ethereum Hooks
### `useERC20balance()`
💰 Gets all token balances of a current user or specified address.
**Options**:
- `chain` (optional): The blockchain to get data from. Valid values are listed on the intro page in the Transactions and Balances section. Default value: current chain.
- `address` (optional): A user address (i.e. 0x1a2b3x...). If specified, the user attached to the query is ignored and the address will be used instead.
- `to_block` (optional): The block number on which the balances should be checked**Returns** (Object) : number of tokens and the array of token objects
```jsx
const {fetchERC20Balance, assets} = useERC20Balance({chain: 'eth'});
```### `useNativeBalance()`
💰 Gets native balance for a current user or specified address.
**Options**:
- `chain` (optional): The blockchain to get data from. Default value: current chain.
**Example**:
```jsx
import useNativeBalance from './hooks/useNativeBalance';function NativeBalance() {
const {nativeBalance} = useNativeBalance(chain);return (
{nativeBalance}
);
}
```**Example return of nativeBalance** (string)
```jsx
'0.1581 BNB';```
### `useERC20Transfers()`
🧾 Gets ERC20 token transfers of a current user or specified address.
**Options**:
- `chain` (optional): The blockchain to get data from. Valid values are listed on the intro page in the Transactions and Balances section. Default value: current chain.
- `address` (optional): A user address (i.e. 0x1a2b3x...). If specified, the user attached to the query is ignored and the address will be used instead.
- `from_date` (optional): The date from where to get the transactions (any format that is accepted by momentjs). Provide the param 'from_block' or 'from_date' If 'from_date' and 'from_block' are provided, 'from_block' will be used.
- `to_date` (optional): Get the transactions to this date (any format that is accepted by momentjs). Provide the param 'to_block' or 'to_date' If 'to_date' and 'to_block' are provided, 'to_block' will be used.
- `from_block` (optional): The minimum block number from where to get the transactions Provide the param 'from_block' or 'from_date' If 'from_date' and 'from_block' are provided, 'from_block' will be used.
- `to_block` (optional): The maximum block number from where to get the transactions. Provide the param 'to_block' or 'to_date' If 'to_date' and 'to_block' are provided, 'to_block' will be used.
- `offset` (optional): Offset.
- `limit` (optional): Limit.**Returns** (Array) : ERC20 token transfers
### `useNativeTransactions()`
🧾 Gets the transactions from the current user or specified address. Returns an object with the number of transactions and the array of native transactions
**Options**:
- `chain` (optional): The blockchain to get data from. Valid values are listed on the intro page in the Transactions and Balances section. Default value: current chain.
- `address` (optional): A user address (i.e. 0x1a2b3x...). If specified, the user attached to the query is ignored and the address will be used instead.
- `from_date` (optional): The date from where to get the transactions (any format that is accepted by momentjs). Provide the param 'from_block' or 'from_date' If 'from_date' and 'from_block' are provided, 'from_block' will be used.
- `to_date` (optional): Get the transactions to this date (any format that is accepted by momentjs). Provide the param 'to_block' or 'to_date' If 'to_date' and 'to_block' are provided, 'to_block' will be used.
- `from_block` (optional): The minimum block number from where to get the transactions Provide the param 'from_block' or 'from_date' If 'from_date' and 'from_block' are provided, 'from_block' will be used.
- `to_block` (optional): The maximum block number from where to get the transactions. Provide the param 'to_block' or 'to_date' If 'to_date' and 'to_block' are provided, 'to_block' will be used.
- `offset` (optional): Offset.
- `limit` (optional): Limit.**Returns** (Array) : native transactions
### `useTokenPrice()`
💰 Gets the price nominated in the native token and usd for a given token contract address
**Options**:
- `chain` (optional): The blockchain to get data from. Valid values are listed on the intro page in the Transactions and Balances section. Default value: current chain (if the chain is not supported it will use the Eth chain).
- `address` (optional): A user address (i.e. 0x1a2b3x...). If specified, the user attached to the query is ignored and the address will be used instead.
- `exchange` (optional): The factory name or address of the token exchange. Possible exchanges, for different chains are: ETH mainnet: `uniswap-v3`, `sushiswap`, `uniswap-v2`, BSC mainnet: `pancakeswap-v2`, `pancakeswap-v1`. Polygon mainnet: `quickswap`. _If no exchange is specified, all exchanges are checked (in the order as listed above) until a valid pool has been found. Note that this request can take more time. So specifying the exchange will result in faster responses most of the time._
- `to_block` (optional): Returns the price for a given blocknumber (historical price-data).**Example**
```jsx
import {useTokenPrice} from './hooks/useTokenPrice';const TokenPrice = () => {
const {tokenPrice} = useTokenPrice({chain, tokenAddress});return (
{tokenPrice.usdPrice}
);
};
```**Example return** (Object)
```json
{
"exchangeAddress": "0x5757371414417b8C6CAad45bAeF941aBc7d3Ab32",
"exchangeName": "Quickswap",
"nativePrice": "0.0003 MATIC",
"usdPrice": "$1.08"
}
``````json
{
"exchangeAddress": "0xcA143Ce32Fe78f1f7019d7d551a6402fC5350c73",
"exchangeName": "PancakeSwap v2",
"nativePrice": "0.0005 BNB",
"usdPrice": "$0.28"
}
```### `useNFTTransfers()`
### `useNFTBalance()`
🎨 Gets all NFTs from the current user or address. Supports both ERC721 and ERC1155. Returns an object with the number of NFT objects and the array of NFT objects.
**Options**:
- `chain` (optional): The blockchain to get data from. Valid values are listed on the intro page in the Transactions and Balances section. Default value: current chain (if the chain is not supported it will use the Eth chain).
- `address` (optional): A user address (i.e. 0x1a2b3x...). If specified, the user attached to the query is ignored and the address will be used instead.**Example return** (Object)
```json
[
{
"amount": "1",
"block_number": "9449788",
"block_number_minted": "9449091",
"contract_type": "ERC1155",
"frozen": 0,
"image": "https://nyc-feb-19-2020.s3.amazonaws.com/skin-slip-animation.gif",
"is_valid": 1,
"metadata": {
"description": "On February 19th, we will introduce the future of b̶l̶o̶c̶k̶c̶h̶a̶i̶n̶ gaming. And you’ll see why Kitties were just the start.",
"external_url": "https://www.nycfeb192020.com/",
"image": "https://nyc-feb-19-2020.s3.amazonaws.com/skin-slip-animation.gif",
"name": "NYC Feb 19th 2020"
},
"name": "NYC February 19th 2020",
"owner_of": "0x71a11bc477048cca56d645ffc66ca762f62d1c3c",
"symbol": "NYCFEB192020",
"synced_at": "2021-12-06T19:02:12.378Z",
"syncing": 2,
"token_address": "0xd193a22224795c43d837a3f3d7394b4d0cc15f60",
"token_id": "1",
"token_uri": "https://nyc-feb-19-2020.s3.amazonaws.com/metadata.json"
}
]
```