From ca94be839c119add37218ab022fbb924d13a773f Mon Sep 17 00:00:00 2001 From: TITI <162849030+0xtiti@users.noreply.github.com> Date: Wed, 8 May 2024 11:56:49 -0300 Subject: [PATCH 1/2] feat: track logs (#21) --- src/components/Voting.tsx | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/src/components/Voting.tsx b/src/components/Voting.tsx index 33772f7..571d9c9 100644 --- a/src/components/Voting.tsx +++ b/src/components/Voting.tsx @@ -60,6 +60,15 @@ export const Voting = () => { try { // Get the proof data const { merkle_root, nullifier_hash, proof } = result; + if (address && merkle_root && nullifier_hash && proof) { + track('Voting proof', { + address, + merkle_root, + nullifier_hash, + proof, + }); + } + console.log('Voting proof:', result); const [decodedMerfleRoot] = decodeAbiParameters(parseAbiParameters('uint256 merkle_root'), merkle_root as Hex); const [decodedNullifierHash] = decodeAbiParameters( @@ -78,17 +87,23 @@ export const Voting = () => { if (isValid) { setModalOpen(ModalType.WALLETCONFIRM); + const hash = await castVote(BigInt(PROPOSAL_ID), vote, thoughts, proofData); if (!hash) throw new Error('No hash returned'); + track('Tx hash', { hash }); setModalOpen(ModalType.LOADING); + if (!publicClient) return; const receipt = await publicClient.waitForTransactionReceipt({ hash: hash as Hex, }); + console.log('Tx receipt:', receipt); + if (receipt) { setTxDone(true); setModalOpen(ModalType.SUCCESS); track('Voting success', { vote }); + if (vote === 1) { const jsConfetti = new JSConfetti(); jsConfetti?.addConfetti({ @@ -103,10 +118,13 @@ export const Voting = () => { } } catch (error) { console.error('Cast failed:', error); + if (error instanceof Error && address) { + track('Error', { message: error.message || 'Unknown error', address }); + } setModalOpen(ModalType.ERROR); } }, - [simulateCheckValidity, vote, castVote, setModalOpen, publicClient, setTxDone], + [address, simulateCheckValidity, vote, setModalOpen, castVote, publicClient, setTxDone], ); return ( From 061f4e71677a1a4b2381b1e7a85d46bc63f9f4c8 Mon Sep 17 00:00:00 2001 From: TITI <162849030+0xtiti@users.noreply.github.com> Date: Wed, 8 May 2024 12:25:12 -0300 Subject: [PATCH 2/2] fix: logs event per vercel plan (#23) --- src/components/Voting.tsx | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/components/Voting.tsx b/src/components/Voting.tsx index 571d9c9..0dfb80e 100644 --- a/src/components/Voting.tsx +++ b/src/components/Voting.tsx @@ -61,11 +61,10 @@ export const Voting = () => { // Get the proof data const { merkle_root, nullifier_hash, proof } = result; if (address && merkle_root && nullifier_hash && proof) { + const proofStr = `merkleRoot: ${merkle_root} nullifierHash: ${nullifier_hash} proof: ${proof}`; track('Voting proof', { address, - merkle_root, - nullifier_hash, - proof, + proofStr, }); } console.log('Voting proof:', result);