diff --git a/packages/client/src/ui/features/shop/HeroCard.tsx b/packages/client/src/ui/features/shop/HeroCard.tsx index 40c9b7c..4241c4a 100644 --- a/packages/client/src/ui/features/shop/HeroCard.tsx +++ b/packages/client/src/ui/features/shop/HeroCard.tsx @@ -24,9 +24,10 @@ const rarityBgColor: Record = { interface IHeroCard { creatureKey: CreatureKey; altarSlot: number; + setLoading: React.Dispatch>; } -export const HeroCard = ({ creatureKey, altarSlot }: IHeroCard) => { +export const HeroCard = ({ creatureKey, altarSlot, setLoading }: IHeroCard) => { const { clientComponents: { GameStatus, Player }, systemCalls: { buyHero, buyAndMerge }, @@ -50,6 +51,7 @@ export const HeroCard = ({ creatureKey, altarSlot }: IHeroCard) => { alert("can only buy piece during prepare"); return; } + setLoading(true); playClick(); if (mergeAble.canMerge) { @@ -64,11 +66,17 @@ export const HeroCard = ({ creatureKey, altarSlot }: IHeroCard) => { y: mergeAble.onBoardCoord.y, invSlot: mergeAble.invSlot, onBoardIdx: mergeAble.boardIdx, - }).then(() => { - playUpgrade(); - }); + }) + .then(() => { + playUpgrade(); + }) + .finally(() => { + setLoading(false); + }); } else { - buyHero(account, altarSlot, firstEmptyInv); + buyHero(account, altarSlot, firstEmptyInv).finally(() => { + setLoading(false); + }); } }, [ account, diff --git a/packages/client/src/ui/features/shop/Shop.tsx b/packages/client/src/ui/features/shop/Shop.tsx index 71e401d..2091951 100644 --- a/packages/client/src/ui/features/shop/Shop.tsx +++ b/packages/client/src/ui/features/shop/Shop.tsx @@ -85,6 +85,7 @@ const Shop = () => { level: 1, }} altarSlot={1} + setLoading={setLoading} /> { level: 1, }} altarSlot={2} + setLoading={setLoading} /> { level: 1, }} altarSlot={3} + setLoading={setLoading} /> { level: 1, }} altarSlot={4} + setLoading={setLoading} /> { level: 1, }} altarSlot={5} + setLoading={setLoading} />