diff --git a/packages/client/src/mud/createSystemCalls.ts b/packages/client/src/mud/createSystemCalls.ts index d448cb0d..c2489b66 100644 --- a/packages/client/src/mud/createSystemCalls.ts +++ b/packages/client/src/mud/createSystemCalls.ts @@ -3,6 +3,7 @@ import { ClientComponents } from "./createClientComponents"; import { SetupNetworkResult } from "./setupNetwork"; import { singletonEntity, encodeEntity } from "@latticexyz/store-sync/recs"; import { message } from 'antd'; +import { get } from "http"; export type SystemCalls = ReturnType; @@ -10,7 +11,7 @@ export function createSystemCalls( { worldContract, waitForTransaction }: SetupNetworkResult, ClientComponents ) { - const { Counter, Player, LootList1, LootList2 } = ClientComponents; + const { Counter, Player, LootList1, LootList2, BoxList } = ClientComponents; const increment = async () => { const tx = await worldContract.write.increment(); await waitForTransaction(tx); @@ -133,6 +134,7 @@ export function createSystemCalls( try { const tx = await worldContract.write.revealBox([boxId]); await waitForTransaction(tx); + return getComponentValue(BoxList, encodeEntity({ boxId: "uint256" }, { boxId: boxId})); } catch (error) { message.error(error.cause.reason); } @@ -143,6 +145,7 @@ export function createSystemCalls( const tx = await worldContract.write.getCollections([boxId, oreAmount, treasureAmount]); await waitForTransaction(tx); } catch (error) { + console.log('getCollections', error); message.error(error.cause.reason); } } diff --git a/packages/client/src/pages/game/index.tsx b/packages/client/src/pages/game/index.tsx index 2799b864..3b380dd0 100644 --- a/packages/client/src/pages/game/index.tsx +++ b/packages/client/src/pages/game/index.tsx @@ -24,8 +24,7 @@ import { triggerVertexUpdate } from '@/utils/map'; import { bfs, simplifyMapData } from '@/utils/map'; import useMerkel from '@/hooks/useMerkel'; import { ethers } from 'ethers'; - -let boxId = '' +import { get } from "http"; const toObject = (obj) => { return JSON.parse(JSON.stringify(obj, (key, value) => @@ -150,7 +149,7 @@ const Game = () => { } const getCollectionsFun = (box: any) => { - boxId = '' + console.log(box); setContent(
@@ -163,7 +162,6 @@ const Game = () => {
@@ -177,7 +175,7 @@ const Game = () => { const box:any = getComponentValue(BoxList, entity) box.id = id.boxId.toString() return box; - }).filter(e => e.opened == false || (e.opened && (e.oreBalance || e.treasureBalance)));; + }).filter(e => e.opened == false || (e.opened && (e.oreBalance || e.treasureBalance))); const getBalance = async () => { const balance = await network.publicClient.getBalance({ @@ -196,13 +194,6 @@ const Game = () => { getBalance() }, []); - useEffect(() => { - if (boxId) { - const box = boxs.find((item) => item.id === boxId); - getCollectionsFun(box); - } - }, [boxs]); - const finishBattle = (e: any) => { console.log(e); @@ -311,8 +302,9 @@ const Game = () => { console.log(currentBlockNumber, blockNumber, 'currentBlockNumber') if (currentBlockNumber - blockNumber >= 2) { clearInterval(interval) - await revealBox(id) - boxId = id + let boxData = await revealBox(id) + boxData.id = id + getCollectionsFun(boxData); } }, 1000) }