/autonomous-lottery-dapp

Autonomous lottery with a new round starting every 10th block.

Primary LanguageTypeScript

Autonomous Lottery Dapp

Autonomous lottery with a new round starting every 10th block. Winners are determined by hashing player addresses and need not be stored in contract state. This can be manipulated by miners so the project is not ready for mainnet yet.

Rinkeby testnet deploy: https://autonomous-lottery-dapp.vercel.app

Hardhat

Hardhat Network is used to run and debug Solidity locally, along with Typechain to provide TypeScript bindings for Ethereum smart contracts.

Solidity

Patterns applied:

Ethers.js

Ethers library is used to interact with the blockchain.

Waffle

External & public contract functions are covered by Waffle tests.

Next.js

Next.js hits Infura on SSR to render the latest lottery info (rounds, players, payouts, winners) for browsers with no Ethereum provider like Metamask installed. Metamask is only required to interact with the lottery.

React

Frontend uses context provider with React Hooks pattern for global store, initialized (hydrated) from SSR, and then updated on contract events.

Styling

Tailwind is used for layout, and Ant Design for UI components.

TypeScript

All code across Next.js, React, Hardhat scripts and tests is statically typed with TypeScript.

Local dev

  1. npm i
  2. npm run node starts Hardhat Network
  3. npm run deploy deploys the Lottery contract & makes some transactions for testing
  4. npm run dev starts Next.js
  5. Install Metamask