How to get token balances?
In this sample project tutorial, we will see how we can use SHYFT APIs to list all fungible tokens from our wallet and also get the details of one particular token
In this tutorial, we will build a simple app, which will list all the fungible tokens in your wallet using our very own SHYFT APIs. Once done, you will be able to show a list of Fungible Tokens from your wallet.
You can read SHYFT Documentation here.
Pre-requisites
To get started, we will need a few things.
Authentication: Get your Shyft API key
x-api-key
is an authentication parameter, which gives you access to SHYFT APIs. You can get your own API Key from the SHYFT website. Just signup with your email id here and you can get it for free.
Phantom Wallet
We will need the Phantom wallet browser extension, you can download it from the link below.
Once done, set up your Phantom wallet account. On-screen tips are available, which will guide you through setting up and getting started. You can also find a detailed guide related to this here.
We will use React to develop this project but you can choose any language of your choice. As we are using react we will need Node.js installed on our computer. You can download node.js from here.
Initial Setup
Now, we are all set to create our first token-listing app. Let's create a new React application for building our app. To create a react app, fire up your terminal and use the following command.
This will create a boilerplate template for you new react project. We have used vscode as our code editor for this project, but you can use any code editor of your choice. Once the above command has completed its execution, we will open up that project folder using vscode and it should look like this.
Building the application
We have divided the project into two parts.
So, let's start building.
Displaying a list of all tokens in your wallet
Connecting to Phantom wallet.
This is the first step to required for this part. We will use the Wallet Address from your Phantom Wallet and use it to fetch all tokens currently in your wallet and then we will display them.
To connect to your phantom wallet, we need a few dependencies added to our project. To add these dependencies, we will have to install the packages manually in our project folder or we can add this to the dependencies list inside the package.json
file and run the npm install
command to automatically add these to our project.
Inside the package.json
file dependency section, we add the following and the save and hit npm ci
The first to packages mentioned in this list is used for connecting to the phantom wallet, and we will use the axios
package to make http requests to our SHYFT APIs.
Note: Every time we add a package or a dependency to our project, we have to restart the local server.
Once done, let's run the following command
This will start a local development server and your application will be up and running at the following link: http://localhost:3000
Now, let's create a new file under the /src
directory, we have used the name ListAll.js
but you can name it anything you want.
Now, let's create a simple button which will connect to the phantom wallet adapter and retrieve our wallet address.
(We have used bootstrap to add very minimal styling to our project but this is not necessary, you can write your own stylesheets or use any other methods for styling your application)
Once created, we have to create a function which will connect to the phantom wallet when invoked. For this we have to import a few things in our ListAll.js
file.
and the function for connecting to phantom
and we will invoke this function once we have clicked on the Connect Wallet
button as shown above in the image before.
If executed successfully, we will receive the wallet address from phantom. Let's create two variables, one for strong the wallet address and one for storing the data we will receive from our APIs.
Once we receive the wallet address, we assign it to the the walletaddress
state variable created using the React's useState
hook.
Making the API call.
API url we will use here to retrieve the token data:
We will also need to pass X-API-KEY
in the header, this key is used for authentication purposes.
You can find more about our APIs here.
Getting Your Own X-API-KEY
x-api-key
is an important parameter we pass on to the header while making the API call for authentication purposes. You can get your own x-api-key
from our own SHYFT website. Just signup with your email id here and you can get it for free.
Now, once we have the wallet address, we are ready to make the API call to fetch our required data which in this case is the token list.
To fetch the data, we have used the axios
package, but you can use JavaScript's very own fetch or any other package you want. We have made this call inside React's useEffect
hook. Here is the code.
If successful, the response which we get back from the server looks somewhat like this with the result
containing an array of all the tokens. We store the array of tokens in the data state variable.
The following details are returned from the API for each token present in our wallet: name
, address
, balance
, symbol
and image.
Now, let's display this array of tokens in our app. We use JavaScript's map method to display the array inside a table.
Congratulations, you have just accomplished out first goal, fetching all tokens from your wallet using SHYFT APIs. Now we move on the next part of our project that is getting the details of one particular token.
Get the details of one particular token
Now, we will attempt to fetch the details of one particular token using our very own SHYFT APIs. We will design this project as an extension of the previous part of the project using React, but you can also design this as a separate project as well.
We will attempt to link the tokens in the previous part with a new page which will display all the details of that particular token.
To achieve this, we have to setup a few routes, the home (/
) route will display the details of all tokens and the view-details (/view-details
) route will display the details of one particular token.
To setup the routes, we will use the react-router-dom
package. To install this package, we run the following command in our terminal inside our project folder.
Once installed, we have to restart our local server. Now, it's time to setup our routes. Let's create a new component, we will name it the Details
component, but you can name it anything you want. We will place this inside Details.js
, inside the \src
directory. It looks somewhat like this.
Setting Up Routes
Now, inside our App Component (App.js
), we set up the Routes. For setting up the Routes, we need the following:
We will setup two routes, one for listing all the tokens and another one for displaying the details of one particular token.
Once setup, we should be able to access the /view-details
route within our application.
Linking via URL Parameters
We can link each of the token listed in the ListAll
component to redirect to the /view-details
route along with token_address
and network
as route parameters. This will help us to get the details of one particular token by updating the token_address
in the url even if our wallet is not connected. One of the ways we can achieve this is this:
The <Link></Link>
component of the react-router-dom
package will help us to navigate to the desired path.
Building the details component
Now, let's create a layout for our Details
component. Inside the Details.js
file(Details Component), we will create a few state variables using React's useState
hook for storing the data and a simple layout for displaying the data. Inside the Details
Component, we use the following:
Getting the details of one particular token
Now the token_address
and network
parameters should be available in the Details
component, as we have passed them via route parameters. This is one way of passing the token address. but you can have your own method if you want. If this was a separate application, we could have used a form to collect the token address and the other required parameters. Now, let's see how we can get the details of one particular token.
SHYFT API to fetch the details of one particular token
Before making this API call, we need to have our X-API-KEY. x-api-key
is an important parameter we pass on to the header for authentication purposes. You can get your own x-api-key
from our own SHYFT website. Just signup with your email id here and you can get it for free.
Once we have our X-API-KEY, we are all set. We will use the axios package to make the API call, but you can use any other package or Javascript's very own fetch to make this call.
Once successful, it should return a response which will contain all the information related to the token. Here is a sample response:
Now, for the final step, we will assign the data received in the response to the state variables, to display the details in the component. Here is the part of the snippet we will use to update the details.
And that's all you have to do get the details of the token.
Congratulations, you have just completed creating a DAPP in which you can get all the tokens in your wallet and their details.
That's pretty much for this tutorial, if you enjoyed this then also try out our other tutorials on Building your First NFT Dapp and Read all NFTs from a wallet. More tutorials are coming soon.
Feel free to clone our code and contribute to our community.
If you liked this, you can learn more about SHYFT APIs in our API Documentation.
You can view a more refined version of this project here. A sample snapshot from the community project has been illustrated above.
Resources
Join our Discord
Hope you have a good time reading our tutorials and happy hacking!! 😇
Last updated