Skip to content

Framework for rapid Dapp development. Simple. Robust. Extendable. Testable

License

Notifications You must be signed in to change notification settings

gsteenkamp89/useDApp

This branch is 315 commits behind TrueFiEng/useDApp:master.

Folders and files

NameName
Last commit message
Last commit date
Apr 21, 2022
Apr 20, 2022
Mar 16, 2022
Apr 21, 2022
Apr 20, 2022
Mar 25, 2022
Mar 17, 2022
Feb 14, 2021
Feb 22, 2021
Feb 22, 2021
Feb 22, 2021
Feb 10, 2021
Apr 20, 2022
Apr 20, 2022
Mar 10, 2022
Feb 10, 2021

Repository files navigation

useDapp

CI Npm package version Discord

Ethereum 🀝 React

Framework for rapid Dapp development.
Simple. Robust. Extendable. Testable.

About

Introduces great features:

  • πŸ—οΈ React hooks - Uses React hooks as your primary building ingredient
  • πŸš… Auto refresh - Refreshes on a new block, wallet change or network change
  • πŸ›’ Multicall - Combines multiple blockchain calls into a single multicall

Combines the best practices:

  • πŸ”§ Modern stack - Employs ethers.js, multicall & waffle
  • πŸ“š Extendability - Extends easily with custom hooks
  • πŸ’‘ Testability - Simple integration tests for UI and blockchain

Example

import { Mainnet } from '@usedapp/core/modal/chain/ethereum'
import { useEthers, useEtherBalance } from '@usedapp/core'

const config = {
  readOnlyChainId: Mainnet.chainId,
  readOnlyUrls: {
    [Mainnet.chainId]: 'https://mainnet.infura.io/v3/62687d1a985d4508b2b7a24827551934',
  },
}

ReactDOM.render(
  <DAppProvider config={config}>
    <App />
  </DAppProvider>,
  document.getElementById('root')
)

const STAKING_CONTRACT = '0x00000000219ab540356cBB839Cbe05303d7705Fa'

export function App() {
  const { activateBrowserWallet, deactivate, account } = useEthers()
  const userBalance = useEtherBalance(account)
  const stakingBalance = useEtherBalance(STAKING_CONTRACT)

  return (
    <div>
      {!account && <button onClick={activateBrowserWallet}> Connect </button>}
      {account && <button onClick={deactivate}> Disconnect </button>}
      {stakingBalance && <p>ETH2 staking balance: {formatEther(stakingBalance)} ETH </p>}
      {account && <p>Account: {account}</p>}
      {userBalance && <p>Ether balance: {formatEther(userBalance)} ETH </p>}
    </div>
  )
}

See application here.

Documentation

For detailed feature walkthrough checkout documentation.

Contributing

Contributions are always welcome, no matter how large or small. Before contributing, please read the code of conduct and contribution policy.

Before you issue pull request:

  • Make sure all tests pass.
  • Make sure linter passes.
  • Make sure you have test coverage for any new features.

To install dependencies type:

npm i -g pnpm
pnpm install

To build project:

yarn build

To run tests type:

yarn test

To run linter type:

yarn lint

License

useDapp is released under the MIT License.

About

Framework for rapid Dapp development. Simple. Robust. Extendable. Testable

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 65.2%
  • JavaScript 21.8%
  • CSS 6.3%
  • HTML 3.5%
  • Sass 3.2%