Skip to content

Latest commit

 

History

History
96 lines (71 loc) · 4.01 KB

File metadata and controls

96 lines (71 loc) · 4.01 KB

Storage and increment app on Fuel Blockchain

This is a simple dapp which implements the Storage Counter contract

This is a simple dapp that allows users to increment the current value of the storage variable and assign a new value to the storage variable.

There is no CSS implemented in this app since this app mostly explains how the functions and methods are implemented in javascript

Hosted app link: https://storage-and-increment-app-fuel.netlify.app/

Smart contract writing and deploying process

  • First, I wrote the smart contract in solidity and then used the transpiler provided in the Sway playground to convert it into its corresponding sway code and then deployed it on the testnet using my Fuel Wallet.

  • The reason I merged the Storage and Counter contracts and created one single contract which does both is so that we can understand how to call a parameterized and non-parameterized function

  • I deployed the contract using Hardhat

    hardhat.config.js

    require("@nomicfoundation/hardhat-toolbox");
    
    const KIICHAIN_RPC_URL = "https://a.sentry.testnet.kiivalidator.com:8645/"
    
    const KIICHAIN_PRIV_KEY = "YOUR_PRIVATE_KEY"
    
    module.exports = {
     solidity: "0.8.0",
     networks: {
       kiichainTestnet: {
         url: KIICHAIN_RPC_URL,
         accounts: [KIICHAIN_PRIV_KEY],
       },
     },
    };
    

Getting started

  1. Clone the repository

    git clone https://github.com/Shoydon/Storage-increment-app-on-Fuel-Blockchain.git
  2. cd into the project

    cd storage-and-increment-dapp
  3. Install the required libraries

    npm i
  4. Run the app

    npm start

    Note: The app throws some error on the latest versions of the node modules: @fuels/connectors and @fuels/react.

    To overcome this, we strictly need to install @fuels/connectors@0.5.0 and @fuels/react@0.20.0

  • Required npm modules
    fuels@0.93.0
    @fuels/connectors@0.5.0 
    @fuels/react@0.20.0 
    @tanstack/react-query@5.51.23

Working of the App:

The app is pretty straightforward.

App.js contains the entire logic of the application.

contract folder contains the solidity contract and its sway equivalent code

contract.json contains the abi and address of the contract deployed on the Fuel Testnet

There is 1 input field and 3 buttons:

1. Input field: Input the value that you want to store

2. Store Value button: Calls the set_value function to store the new value

3. Increment Value button: Calls the increment_value function to increment the current value

4. Retrieve Value button: Calls the get_value function to get the current value

Built with

  • ReactJs - JavaScript library for building user interfaces.
  • Solidity - Solidity is a programming language used to build smart contracts on EVM based blockchains.
  • Hardhat - Development environment for building and deploying smart contracts on testnets.
  • Fuel docs - Documentation for developers to start building on Fuel.
  • Sway playground - Sway Playground is an online environment for experimenting with and learning the Sway programming language.
  • Fuel Wallet - With the Fuel Wallet, you can explore DApps on Fuel and manage your crypto assets, all in one place.
  • Typescript SDK - The Fuel TypeScript SDK provides methods and utilities in TypeScript, for developing on or interacting with the Fuel network and its ecosystem.
  • Wallet SDK - The Fuel Wallet SDK provides methods and utilities to connect with the wallets compatible with the Fuel network and its ecosystem.
  • Fuel faucet - Gives some testnet tokens to start working on the testnet.