Won the 1st place in the Randomness category of the Sui Overflow 2024 hackathon
Most of the Sui starters I found were either very basic or one-sided (frontend or backend). Thanks to my experience with various full-stack starters and templates, I knew how to do better, so I started this template with the goal of providing all basic tools and components for you to focus on your business logic from day one and not spend weeks on creating your app skeleton. // @kkomelin
- Suibase: Painless work with the networks and system dependencies
- Local Sui Explorer: Browse your transactions and objects locally
- pnpm: More efficient package management for monorepos
- TypeScript: Less error-prone JavaScript
- React or Next.js: Choose a template with a framework of your choice
- Tailwind CSS: Utility-first CSS for more efficient styling
- Vite + SWC: Faster app bundling and optimizing
- Radix UI: Accessible React components to prototype quicker
- Sui dApp Kit: All you need to work with Sui network on frontend
- @suiware/kit: Useful react primitives, such as useTransact, useNetworkType, NetworkType, useBalance, Balance, useFaucet, Faucet and more
- Frontend Deployment: Firebase, Walrus Sites, Arweave
- One-liner Install: Just
pnpm create sui-dapp@latest
- Demo app: Default Greeting (React) template
Before you begin, install the following:
-
Clone the resulting repo locally.
-
Choose a template by running the corresponding init command:
Template | Init command |
---|---|
Greeting (React) | pnpm init:template:greeting-react |
Greeting (Next.js) | pnpm init:template:greeting-next |
Counter (React) | pnpm init:template:counter-react |
pnpm create sui-dapp@latest
This way you'll be able to configure the project step-by-step.
pnpm localnet:start
Local Sui Explorer will be available on localhost:9001
pnpm localnet:deploy
This command skips dependency verifications to prevent dependency version mismatch issues, which are caused by local and remote Sui version mismatch. The deploy commands for devnet, testnet and mainnet do perform such verifications.
You have a few options here:
a) Use the Faucet button integrated into your wallet (e.g. Sui Wallet).
b) Copy the localnet address from your wallet and run the following in your console:
pnpm localnet:faucet 0xYOURADDRESS
c) Run the app and use the Faucet button in the footer.
pnpm start
Find all commands in the documentation.
pnpm test
- Useful VSCode Extensions
- Suibase Docs
- Move Book
- Sui Move: Code Conventions
- @mysten/create-dapp - official starter
- Awesome Sui
Copyright (c) 2024 Konstantin Komelin and other contributors
Code is licensed under MIT
SVG Graphics used for NFTs is licensed under CC-BY 4.0