Learn everything about Solana
Review VI - Frontend
In this video, we are going to see how we can interact with our project from the client side.
To run this program:
First, install required libraries:
npm install
Then, run the development server:
npm run dev
Open http://localhost:3000 with your browser to see the result.
You can click here for the frontend template.
Here is the changes we have made to index.tsx in this video:
const connection = new web3.Connection(web3.clusterApiUrl("devnet"));
const { publicKey, sendTransaction } = useWallet();
const [txid, setTxid] = useState("");
const [reviews, setReviews] = useState<Review[]>([]);
const [title, setTitle] = useState("");
const [rating, setRating] = useState(0);
const [description, setDescription] = useState("");
useEffect(() => {
const fetchAccounts = async () => {
await fetchReviews(REVIEW_PROGRAM_ID, connection).then(setReviews);
};
fetchAccounts();
}, []);
const handleSubmit = () => {
const review = new Review(title, rating, description);
handleTransactionSubmit(review);
};
const handleTransactionSubmit = async (review: Review) => {
if (!publicKey) {
alert("Please connect your wallet!");
return;
}
const buffer = review.serialize();
const transaction = new web3.Transaction();
const [pda] = await web3.PublicKey.findProgramAddressSync(
[publicKey.toBuffer(), Buffer.from(review.title)],
new web3.PublicKey(REVIEW_PROGRAM_ID)
);
const instruction = new web3.TransactionInstruction({
keys: [
{
pubkey: publicKey,
isSigner: true,
isWritable: false,
},
{
pubkey: pda,
isSigner: false,
isWritable: true,
},
{
pubkey: web3.SystemProgram.programId,
isSigner: false,
isWritable: false,
},
],
data: buffer,
programId: new web3.PublicKey(REVIEW_PROGRAM_ID),
});
transaction.add(instruction);
try {
let txid = await sendTransaction(transaction, connection);
setTxid(
`Transaction submitted: https://explorer.solana.com/tx/${txid}?cluster=devnet`
);
} catch (e) {
console.log(JSON.stringify(e));
alert(JSON.stringify(e));
}
};
Comments
You need to enroll in the course to be able to comment!