Create a React app and display data using the subgraph
We can’t wait for you to complete this and claim, your PFP’s 🖼️ and $GRT
-
#graphathon
-
#graphIndia
-
Create a folder/directory and open it in your code editor.
-
We will create a React app. Open your terminal pointing towards the directory and run the following command
npm create vite@latest
- Enter the Project Name as
frontend
orclient
. - Select
React
as the framework and then selectJavaScript
(without SWC ❌). - Run the following commands to start. (You can refer to your terminal)
cd client
npm install
npm run dev
- We will also need to install
graphql
to query the data andurql
which is a highly customizable and versatile GraphQL client for React.
npm install graphql urql@3.0.3
- Inside the directory, go to the
src/App.jsx
and replace the existing code with
import { useState, useEffect } from 'react';
import './App.css';
function App() {
return (
<>
<div>
</div>
</>
)
}
export default App;
-
We are going to make use of the Uniswap subgraph for this challenge. See it here.
-
Click on
Query
button on the right and copy the Query URL to access the subgraph. -
Go back to our
App.jsx
and store the URL in a variable inside the App function.
const QueryURL = "https://gateway.thegraph.com/api/[api-key]/subgraphs/id/ELUcwgpm14LKPLrBRuVvPvNKHQ9HvwmtKgKSH6123cr7"
-
You need an API Key to query the data. Under the Query URL you can see the option to
Manage API Keys
. Click on that and it will take you to create it. You can also create it using this link. -
Click on
Create API Key
and enter a name eg. graphathon-uniswap. -
You get 1,000 free queries for the API key. Enter your email address and claim your queries.
-
Copy the generated API key and paste it into our query URL.
-
Add the data you want to query below the
QueryURL
variable. Here we will get the data about the first 5 token details of Uniswap.
const query = `{
tokens(first: 5) {
id
name
symbol
decimals
}
}`
- Create a client to access Uniswap. We will make of
urql
for this. Add the following import statement at the top
import { createClient } from 'urql';
- To create the client add the following code after the
query
variable
const client = createClient({
url: QueryURL
})
- We will make use of useEffect and useState to track the state. Add the following code in the App function
const [tokens, setTokens] = useState([]);
useEffect(() => {
const getTokens = async () => {
const { data } = await client.query(query).toPromise();
console.log(data);
setTokens(data.tokens);
}
getTokens();
}, [])
- To display the data on the frontend, we will return the following.
return (
<>
<div>
<h1>Tokens Information</h1>
{tokens !== null && tokens.length > 0 && tokens.map((token) => {
return (
<div key={token.id}>
<div>{token.id}</div>
<div>{token.name}</div>
</div>
);
})}
</div>
</>
);
- Your final
App.jsx
should look like this 👇🏻 -:
import { useEffect, useState } from 'react';
import { createClient } from 'urql';
import './App.css';
function App() {
const [tokens, setTokens] = useState([]);
const QueryURL = "https://gateway.thegraph.com/api/[api-key]/subgraphs/id/ELUcwgpm14LKPLrBRuVvPvNKHQ9HvwmtKgKSH6123cr7";
const client = createClient({
url: QueryURL
});
const query = `{
tokens(first: 5) {
id
name
symbol
decimals
}
}`
useEffect(() => {
const getTokens = async () => {
const { data } = await client.query(query).toPromise();
setTokens(data.tokens);
};
getTokens();
}, []);
return (
<>
<div>
<h1>Tokens Information</h1>
{tokens !== null && tokens.length > 0 && tokens.map((token) => {
return (
<div key={token.id}>
<div>{token.id}</div>
<div>{token.name}</div>
</div>
);
})}
</div>
</>
);
}
export default App;
-
Run
npm run dev
to view the frontend. -
Wohooo! You did it. 🥳 Congratulationssss! Share it with the world.
-
Make use of The Graph Playground in the dashboard to use different queries and display that data. (SKY IS THE LIMIT 🌌)
-
Create a new file with the title
solution-3.md
and add the frontend screenshot in the file. -
[🚨VERY IMPORTANT STEP🚨] Submit the link of this
solution-3.md
file to this Graph-A-Thon challenge submission form.
-
Create a new branch
username_graphathon
, e.g.yash251_graphathon
-
Create a file named
solution-3.md
for this challenge. -
Add the frontend screenshot in the file.
-
Submit details on the Airtable form.
This is an important step, please don't skip it.