Introduction

Starknet-Scaffold is a comprehensive, open-source toolkit designed for developing decentralized applications (dApps) on Starknet. This toolkit includes the most popular and functional tools, ensuring an up-to-date development environment.

Starknet-Scaffold was built using a robust technology stack, which includes:

  1. NextJS: A powerful React framework that enables server-side rendering and static site generation, improving performance and SEO for web applications. It provides a seamless development experience with features like file-based routing and API routes.

  2. Starknet.js: A JavaScript library that allows developers to interact with Starknet, the layer-2 scalability solution for Ethereum. It facilitates the integration of Starknet smart contracts with dApps, enabling functionalities like contract calls and transactions.

  3. Starknet-React: A set of React hooks and components designed to work with Starknet.js, making it easier to integrate Starknet functionalities into React applications. It simplifies state management and interaction with Starknet smart contracts within the React ecosystem.

  4. Starknetkit: A development toolkit that includes a suite of tools and libraries for building, testing, and deploying Starknet smart contracts. It enhances developer productivity by providing standardized workflows and utilities.

  5. Typescript: A typed superset of JavaScript that compiles to plain JavaScript, offering static type definitions and advanced type-checking. It improves code quality and developer productivity by catching errors at compile-time rather than runtime.

  6. Scarb: A toolchain manager and build system specifically designed for Starknet projects. It simplifies dependency management, project configuration, and the compilation process for Starknet smart contracts.

  7. Starknet-Foundry: A suite of tools for Starknet smart contract development, including testing frameworks, debugging tools, and deployment utilities. It provides a comprehensive environment for building robust and reliable smart contracts on Starknet.

In the subsequent chapters of this documentation, readers will be taken through an in-depth exploration of how Starknet-Scaffold works. Each chapter will guide you step-by-step through its various components and functionalities, providing practical insights and detailed explanations to help you effectively utilize this powerful toolkit.

Quickstart

This section covers installation and setting up of the development environment.

  1. Installation
  2. Environment
  3. Tool version

Installation

This documentation provides detailed instructions on how to install and set up Starknet-Scaffold.

Requirements

Before you begin, ensure you have the following tools installed on your system:

Installation Methods

  1. Using the create-starknet-app executable (recommended).
  2. Cloning the repository from GitHub.

Method One: Using create-starknet-app executable.

The recommended way to get started with Starknet-Scaffold is by using the create-starknet-app executable. This method allows you to choose between different boilerplate types based on your project needs.

  1. Run the executable

    Open your terminal and run:

    npx create-starknet-app
    

    You'll be prompted for a project name, and a package type, enter both to proceed.

    Available package types include:

    • contract-only: For a project that require just contract-related tools (no frontend).

    • fullstack: For full stack projects. Provides customizable out-of-the-box UI components.

    • dojo: For gaming projects which needs access to the dojo stack.

    • debugger: For projects with need to utilize the full debugging suite.

    Once installation is completed, navigate to the project directory:

    cd my-project
    

Method Two: Cloning the repository from GitHub.

To get started with Starknet-Scaffold via GitHub, follow these steps:

  1. Clone the repository:

    Clone the Starknet-Scaffold repository from GitHub to your local machine. Open your terminal or command prompt and run the following command:

    git@github.com:horuslabsio/Starknet-Scaffold.git
    
  2. Navigate to the Project Directory

    After cloning, navigate into the project directory by running:

    cd Starknet-Scaffold
    

PS: The executable automatically installs Scarb and Starknet Foundry, if you do not have them installed locally.

Environment

Getting Started

After setting up your project, follow these steps to get your development environment running smoothly:

  1. Install the required dependencies

    Navigate to your project directory and install the required dependencies:

    cd my-app
    
    npm run install
    

    This will download and install all the important packages specified in the package.json file, including Scarb, Starknet Foundry and dojo if not initially present.

    PS: This is only necessary if you installed by cloning. All these are done automatically when you use the create-starknet-app executable.

  2. To build your Cairo contracts:

    npm run build-contracts
    
  3. To start your development server, run:

    npm run start
    

    This command kickstarts a local development server for your new project.

Starknet-Scaffold provides other scripts to facilitate development. We will cover more of these available scripts in the coming chapters.

starknet scaffold

You now have a fully set up and running installation of Starknet-Scaffold at https://localhost:3000. For further customization and detailed instructions, please refer to the documentation.

Tool version

Starknet Scaffold v0.5.0

  • Cairo: v2.7.0
  • Scarb: v2.7.0
  • Starknet Foundry: v0.27.0
  • starknet-react/chains: v0.1.7
  • starknet-react/core: v2.9.0
  • Starknet.js: v6.11.0

UI Components

An overview of the different UI components available on Starknet Scaffold. Starknet Scaffold provides a set of pre-built components for common web3 use cases. You can make use of them to accelerate and simplify your dapp development.

  1. Connect Button & Connect Wallet Modal
  2. Address Bar & User Modal
  3. Transaction History
  4. Add Token
  5. Account Balance
  6. Network Switcher

Connect Button

The custom connect button is located in the header of the page and facilitates the connection of a user's Starknet wallet to the dapp. When clicked, it triggers a custom wallet modal that appears at the center of the screen.

Connect Wallet Modal

The connect wallet modal is a UI component that appears when the connect button is clicked. Its primary function is to allow users to select the wallet they wish to use to connect to the dapp.

The modal is divided into two sections:

  • Left side: Lists popular Starknet wallets available for connection, including:

    1. Argent X
    2. Braavos
    3. Argent Web Wallet
    4. Argent (mobile)
    5. Bitget
    6. OKX

When an option is clicked, the corresponding wallet's modal (if installed) opens, allowing the user to unlock their wallet and connect. Once connected, the user is redirected to the dapp.

  • Right side: Provides information to educate users on how wallet connections work.

Import

import ConnectButton from "~/app/components/lib/Connect";

Usage

<ConnectButton />

Props

PropTypeDescription
text?stringName of the button (optional)
className?stringCSS class for button (optional)

Address Bar & User Modal

Address Bar

The Address Bar displays the address of the connected account. If the connected wallet has a Starknet.id, the Address Bar will display the Starknet.id pfp and name. If not, a Blockies-generated image representation of the connected address is displayed alongside a shortened version of the address.

User Modal

The User Modal is a component that is triggered from the Address Bar. It provides the following details about the connected account:

  • Profile Picture & Address: Displays either the user's Starknet.id profile picture or a Blockies-generated image representing the connected address.
  • Wallet Address: Shows the wallet address, which can be copied by the user.
  • Account Balance: Displays the current ETH and STRK balance of the connected wallet.
  • Disconnect Button: Provides an option for the user to disconnect their wallet from the dapp.

Import

import AddressBar from "~/app/components/lib/AddressBar";

Usage

<AddressBar />

Transactions History

This component displays the list of transactions performed by the connected wallet.

Each transaction item shows the following:

  • Transaction status: represented by icons. The status of a transaction can be one of the following: completed, pending, or failed.
  • User address
  • Transaction time and date
  • "See transaction": redirects the user to view the transaction on a block explorer.

Import

import TransactionsButton from "~/app/components/lib/Transactions";

Usage

 <TransactionsButton />

Props

PropTypeDescription
text?stringName of the button (optional)
className?stringCSS class for button (optional)

Add Token

The Add Token component enables users to add a custom token to their wallet. To successfully add a token, users need to provide the following information:

  • Contract Address: The contract address of the token.
  • Token Name: The name of the token.
  • Token Symbol: The token's symbol.
  • Decimals: The decimal for the token.

Once all fields are filled out, users can click the Add Token button to add the custom token to their wallet.

Import

import AddTokenButton from "~/app/components/lib/AddToken";

Usage

<AddTokenButton />

Props

PropTypeDescription
text?stringName of the button (optional)
className?stringCSS class for button (optional)

Account Balance

This component shows the STRK and ETH balance of the connected wallet address.

Import

import AccountBalance from "~/app/component/AccountBalance";

Usage

<AccountBalance address="0x34aA3F359A9D614239015126635CE7732c18fDF3"/>

Props

PropTypeDescription
addressstringAddress in 0x___ format.

Network Switcher

This component allows users to switch between Starknet networks (mainnet/sepolia).

Import

import NetworkSwitcher from "~/app/components/lib/NetworkSwitcher";

Usage

<NetworkSwitcher />

Tour Guide

Starknet Scaffold provides a suite of tools and features aimed at simplifying your development experience. This section provides insight on how to make use of the various features available.

  1. Deployer
  2. Burner
  3. Faucet
  4. Wikipedia
  5. Converter
  6. Address Book

Deployer

The scaffold deployer is a simple tool for seamlessly declaring and deploying smart contracts to Starknet testnet and mainnet.

This tools interface consists of two sections; the declare and deploy section.

Declare section

This section takes in the Contract Class JSON file (Sierra) and the Compiled Contract Class JSON file (CASM), then declares the contract. Once declared, a class hash is returned which can be used to deploy the contract.

starknet scaffold declare section

Deploy section

This section takes in the declared class hash and its constructor arguments, then deploys the contract.

starknet scaffold  deploy section

Burner Wallet

The Burner wallet tool enables users to generate temporary wallets for use during the course of development. Burner wallets are only supported on the Sepolia network and a user can only generate a maximum of five wallets at a time.

A generated wallet UI gives us information such as ETH and STRK balance and address. The burner wallet can be funded using the Faucet tool.

In order for the generated burner wallet to be used, it has to be connected. After connection, the user can use it for the following;

  1. Transfer of tokens(ETH/STRK): Transfer tokens by inputting the recipient address and amount.

  2. Execute smart contract calls: Execute functions from other smart contracts by inputting the contract address, function name and arguments.

Users have the ability to also clear the generated wallets.

starknet scaffold burner

Faucet

This is a sepETH/sepSTRK faucet tool built by the Starknet Foundation. You can claim ETH/STRK sepolia testnet tokens for development. This tool can be used to fund generated burner wallets.

starknet faucet

Wikipedia

The Wikipedia is a collection of Starknet/Cairo learning resources within the ecosystem.

The columns of the table are:

  • Name: The name of the resource.
  • Description: A short description of the mentioned tool.
  • Status: Indicates whether the tool/resource is up-to-date or not.
  • URL: A link to the tool/resource.

This tool also includes a search functionality to easily find resources.

starknet scaffold wikipedia

Converter

A collection of utility functions for Starknet related conversions. Convert between hex, felts, strings, selectors and uint256s.

starknet converter

Address Book

The address book contains a list of all relevant contract addresses within the starknet ecosystem.

starknet scaffold address book page

Scripts Overview

Contract Scripts

Below are npx scripts provided by Starknet-Scaffold for your smart contract development.

Build Contract

To build your contracts:

npm run build-contracts

Format contracts

Leverage Scarb’s native formatting capabilities by running:

npm run format-contracts

Verify contracts

To verify your smart contracts, from the base repository run:

npm run verify-contracts --contract-address=<CONTRACT_ADDRESS> --contract-name=<CONTRACT_NAME> --network=<NETWORK>

Test contracts

To run your Starknet Foundry tests:

npm run test-contracts

Run custom starknet-foundry scripts

To run a custom starknet foundry deploy/declare/invoke script:

npm run contract-scripts <SCRIPT_NAME> --url=<RPC_URL>

Generate an SRC-5 interface ID for your contracts

To generate an SRC-5 interface ID, run:

npm run generate-interface <PATH_TO_INTERFACE>

Prepare Account for deployment

To prepare your account for deployment, run:

npm run prepare-account --url=<RPC_URL> --name=<ACCOUNT_NAME> <PROFILE_NAME>

generates a profile which is added to scarb.toml and can be passed to other commands.

Deploy Account

To deploy an account:

npm run deploy-account --profile=<MY_PROFILE> --name=<ACCOUNT_NAME> --fee-token=<FEE_TOKEN> --max-fee=<MAX_FEE>

where the profile is gotten from snfoundry.toml, name is the prepared account and maxfee is the specified max fee.

Delete Account

To delete an account:

npm run delete-account --profile=<MY_PROFILE> --account-file=<PATH_TO_ACCOUNT_FILE> --name=<ACCOUNT_NAME> --network=<alpha-mainnet | alpha-goerli>

Declare Contract

To declare a Starknet contract:

npm run declare-contract --profile=<MY_PROFILE> --contract-name=<CONTRACT_NAME> --url=<RPC_URL> --fee-token=<FEE_TOKEN>

Deploy Contract

To deploy a contract:

npm run deploy-contract --profile=<MY_PROFILE> --feetoken=<FEE_TOKEN> --class=<CONTRACT_CLASSHASH> --url=<RPC_URL>

Starknet-Devnet

Confirm that Docker is installed and running to use starknet-devnet. To run devnet:

npm run devnet

Dojo Scripts

The contracts folder contains all the tools needed to write, build, test and deploy dojo projects. It is built with sozo and katana. Here are common operations you can perform on your dojo contracts.

Initialize Dojo Project

To initialize a dojo project, from the base repository:

npm run initialize-dojo --name=<PROJECT_NAME>

Build Dojo Project

To build your dojo project, from the base repository run:

npm run build-dojo --name=<PROJECT_NAME>

Deploy Katana

To build deploy katana, from the base repository run:

npm run deploy-dojo-katana --name=<PROJECT_NAME>

Migrate Dojo Project

To migrate your dojo project, from the base repository run:

npm run migrate-dojo --name=<PROJECT_NAME>

User Interface Scripts

The following are scripts from Starknet-Scaffold for handling the user interface.

Run Frontend

To run UI, from the base repository:

npm run start

Run Frontend

To build your frontend, from the base repository run:

npm run build-ui

Spinning up and using Devnet

Introduction

Starknet Devnet is a development network (devnet) implemented in Rust. With Devnet, you can simulate Starknet in the comfort of your local network. Fork mainnet/testnet to interact with real-world smart contracts, while maintaining isolation.

Prerequisites:

Docker has to be installed for the script to work.

Run Starknet-Devnet

To run starknet-devnet:

npm run devnet

Check out the official starknet devnet documentation here.

Address Book

This provides a detailed list of relevant contract addresses on Starknet, including core contracts, various token contracts, and OpenZeppelin contracts. These addresses are essential for developers and users interacting with the Starknet ecosystem, as they allow you to access, interact with, and integrate various functionalities within the starknet network.

Starknet Contracts

NameL1 Contract Address
Core Contract0xc662c410C0ECf747543f5bA90660f6ABeBD9C8c4
GpsStatementVerifier0x47312450B3Ac8b5b8e247a6bB6d523e7605bDb60
STRK0x04718f5a0fc34cc1af16a1cdee98ffb20c31f5cd61d6ab07201858f4287c938d

Tokens

NameL2 Contract AddressL2 Bridge ContractL1 Contract AddressL1 Bridge Contract
Ether0x049d36570d4e46f48e99674bd3fcc84644ddd6b96f7c741b1562b82f9e004dc70x073314940630fd6dcda0d772d4c972c4e0a9946bef9dabf4ef84eda8ef542b820x00000000000000000000000000000000000000000xae0Ee0A63A2cE6BaeEFFE56e7714FB4EFE48D419
DAI0x00da114221cb83fa859dbdb4c44beeaa0bb37c7537ad5ae66fe5e0efd20e6eb30x075ac198e734e289a6892baa8dd14b21095f13bf8401900f5349d5569c3f6e600x6B175474E89094C44Da98b954EedeAC495271d0F0x9f96fe0633ee838d0298e8b8980e6716be81388d
USD Coin0x053c91253bc9682c04929ca02ed00b3e423f6710d2ee7e0d5ebb06f3ecf368a80x05cd48fccbfd8aa2773fe22c217e808319ffcc1c5a6a463f7d8fa2da482181960xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB480xF6080D9fbEEbcd44D89aFfBFd42F098cbFf92816
Tether USD0x068f5c6a61780768455de69077e07e89787839bf8166decfbf92b645209c0fb80x074761a8d48ce002963002becc6d9c3dd8a2a05b1075d55e5967f42296f16bd00xdAC17F958D2ee523a2206206994597C13D831ec70xbb3400F107804DFB482565FF1Ec8D8aE66747605
Wrapped BTC0x03fe2b97c1fd336e750087d68b9b867997fd64a2661ff3ca5a7c771641e8e7ac0x07aeec4870975311a7396069033796b61cd66ed49d22a786cba12a8d767173020x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C5990x283751A21eafBFcD52297820D27C1f1963D9b5b4
Lords0x124aeb495b947201f5fac96fd1138e326ad86195b98df6dec9009158a533b490x7c76a71952ce3acd1f953fd2a3fda8564408b821ff367041c89f445260766330x686f2404e77ab0d9070a46cdfb0b7fecdd2318b00x023A2aAc5d0fa69E3243994672822BA43E34E5C9
Starknet Wrapped Staked Ether0x042b8f0484674ca266ac5d08e4ac6a3fe65bd3129795def2dca5c34ecc5f96d20x0088eedbe2fe3918b69ccb411713b7fa72079d4eddf291103ccbe41e78a9615c0x7f39c581f595b53c5cb19bd0b3f8da6c935e2ca00xbf67f59d2988a46fbff7ed79a621778a3cd3985b

OpenZeppelin

NameContract Address
OpenZeppelin Universal Deployer0x041a78e741e5af2fec34b695679bc6891742439f7afb8484ecd7766661ad02bf

Contributing Guide

Welcome to the Starknet Scaffold contributing guide! Thank you for investing your time in contributing to our project. This guide aims to provide a comprehensive overview of the contribution workflow, ensuring an effective and efficient process for everyone involved.

About the Project

Starknet-Scaffold, an open-source, up-to-date toolkit for building decentralized applications (dapps) on Starknet. It's designed to make it easier for developers to create and deploy smart contracts and build user interfaces that interact with those contracts. It makes forking the Starknet development stack easy through a frontend that adapts to smart contracts, and scripts optimized to make contract building, declaring and deploying a breeze. README to get an overview of the project.

Our Vision

Our goal is to provide the primary building blocks for creating dApps. While the repository can be forked to include additional integrations and features, we aim to keep the main branch simple and minimalistic.

Project Status

The project is under active development. You can view open issues, follow the development process, and contribute to the project.

Getting Started

You can contribute to this repository in several ways:

  • Solve open issues
  • Report bugs or request new features
  • Improve the documentation

General Contribution Guidelines

1. Understand Our Project: Starknet-Scaffold, an open-source, up-to-date toolkit for building decentralized applications (dapps) on Starknet.

2. Search Existing Issues and Pull-Requests (PRs): Before creating a new issue or Pull-Request (PR), check if a similar one already exists.

3. Communication: For more developer resources and questions - @0xdarlington

4. Focused Contributions: Contributions should either fix/add functionality or address style issues, but not both.

5. Provide Context: When reporting an error, explain what you were trying to do and how to reproduce the error.

6. Consistent Formatting: Use the same formatting as in the repository. Configure your IDE using the included prettier/linting config files.

7. Update Documentation: If applicable, edit the README.md file to reflect any changes you make.

8. Respond to Feedback: Engage with maintainers and reviewers, making necessary changes and improvements based on their feedback.

9. Be Patient: Understand that maintainers are often busy and it may take time for your PR to be reviewed and merged.

10. Monitor Your Contribution: Keep an eye on your PR and address any further comments or requested changes. Stay Engaged: Continue to contribute, help others, and be an active member of the community. By following these guidelines, you can make meaningful contributions to Our open-source project and become a valuable member of Our open-source community

Issues

Issues are used to report problems, request new features, or discuss potential changes before creating a Pull-Request PR.

Solving an Issue

  1. Find an Issue: Browse existing issues to find one that interests you. existing issues

  2. Assign the Issue: If you find an issue to work on, assign it to yourself.

  3. Open a PR: Once you've addressed the issue, open a PR with your fix.

Creating a New Issue

If a related issue doesn't exist, you can open a new one. Here are some tips for creating a new issue:

  1. Provide as much context as possible.

  2. Include steps to reproduce the issue or the reason for the feature request.

  3. Add screenshots, videos, etc., to clarify your points.

Pull Requests

We follow the "fork-and-pull" Git workflow: We follow the "fork-and-pull" Git workflow

  1. Fork the Repo: Create a fork of the repository.

Example: User A visits our main-repo repository on GitHub, https://github.com/argentlabs/Starknet-Scaffold and clicks the Fork button, creating a personal copy of the repository under their own GitHub account (e.g., userA/Starknet-Scaffold).

  1. Clone the Project: Clone your fork locally.
git clone https://github.com/userA/Starknet-Scaffold

cd Starknet-Scaffold
  1. Create a Branch: Create a new branch with a descriptive name. User A creates a new branch for their feature or bug fix. This ensures the main branch (typically main or master) remains clean and unaffected by ongoing work:
git checkout -b new-feature
  1. Commit Changes: Commit your changes to the new branch. User A makes the necessary changes to the code, adds the modified files, and commits the changes:
git add .

git commit -m "Add new feature to improve performance"
  1. Push Changes: Push your changes to your fork. User A pushes the changes in the new-feature branch to their forked repository on GitHub.
git push origin new-feature

  1. Open a PR: Open a PR in the main repository and tag a maintainer for review.

Tips for a High-Quality Pull Request

Creating a high-quality pull request (PR) in open-source projects increases the likelihood of your contributions being accepted and appreciated. Here are some tips for crafting a high-quality pull request:

1. Understand the our Contribution Guidelines:

  • Read CONTRIBUTING.md: Follow the project-specific instructions for contributing.

  • Adhere to Coding Standards: Ensure your code complies with the project's coding style and standards.

2. Clear and Descriptive Title:

  • Concise Summary: Use a clear, concise title that summarizes the purpose of the PR.

3. Detailed Description:

  • What and Why: Explain what changes you made and why they are necessary.

  • Issue References: Reference relevant issues by number (e.g., "Fixes #123").

  • Impact: Describe the impact of your changes on the project.

4. Small and Focused Changes:

  • Single Purpose: Each PR should address a single issue or feature. Avoid bundling multiple changes in one PR.

  • Incremental Changes: If you have multiple related changes, consider submitting them in smaller, incremental PRs.

5. Documentation:

  • Update Documentation: Ensure any relevant documentation is updated to reflect your changes.

  • Code Comments: Add comments in your code where necessary to explain complex logic.

6. Testing:

  • Include Tests: Add or update tests to cover your changes.

  • Pass All Tests: Ensure all existing and new tests pass. Run the test suite locally before submitting the PR.

7. Commit Quality:

  • Atomic Commits: Make small, logical commits. Each commit should be a single, self-contained change.

  • Meaningful Commit Messages: Write clear, descriptive commit messages that explain the intent of each change.

8. Code Review Readiness:

  • Clean Up: Remove any unnecessary code, comments, or debug statements.

  • Consistent Formatting: Follow the project's formatting guidelines and use linting tools if available.

9. Engage with the Community:

  • Seek Feedback Early: If unsure about your approach, seek feedback early by discussing your plan in an issue or community forum before submitting the PR.

  • Respond Promptly: Be responsive to feedback and make requested changes promptly.

10. Polish Your PR:

  • Proofread: Check for typos and grammatical errors in your description and comments.

  • Visual Enhancements: If your PR affects the UI, you can include before and after screenshots or a short video.

By following these tips, you can create a high-quality pull request that is more likely to be accepted and appreciated by the maintainers and the community.

After Submitting Your PR

  1. Review Process: We may ask questions, request additional information, or suggest changes. These requests aim to clarify the PR for everyone and ensure a smooth interaction process.

  2. Resolve Conversations: As you update your PR and apply changes, mark each conversation as resolved.

  3. Merging: Once the PR is approved, we will "squash-and-merge" to keep the git commit history clean.

Thank you for your contributions to Starknet-Scaffold! We appreciate your efforts in helping us build and improve this project.