From d8dfe88e2a49ef5bab85acfb33b815c91bfec495 Mon Sep 17 00:00:00 2001 From: mihaisc Date: Thu, 29 Oct 2020 16:53:27 +0200 Subject: [PATCH] refresh price and pool info (#164) * refresh price and pool info Signed-off-by: mihaisc * lib update Signed-off-by: mihaisc * remove unused dependencies Signed-off-by: mihaisc * remove console.log Signed-off-by: mihaisc --- package-lock.json | 19 +++++++++++++++++++ .../organisms/AssetActions/Pool/Add/index.tsx | 3 +++ .../organisms/AssetActions/Pool/Remove.tsx | 3 +++ .../organisms/AssetActions/Pool/index.tsx | 12 ++++++++++-- 4 files changed, 35 insertions(+), 2 deletions(-) diff --git a/package-lock.json b/package-lock.json index d871e0cd1..696cb4de3 100644 --- a/package-lock.json +++ b/package-lock.json @@ -3876,6 +3876,25 @@ "decimal.js": "^10.2.1", "web3": "^1.3.0", "web3modal": "^1.9.1" + }, + "dependencies": { + "@oceanprotocol/lib": { + "version": "0.9.8", + "resolved": "https://registry.npmjs.org/@oceanprotocol/lib/-/lib-0.9.8.tgz", + "integrity": "sha512-jV7lobTXskqqmv23Vl3iQ4SZk+0FVFxLSVkXniOKOOFP0pJ0vllSNnM+wHkG4inF3HWHHyeh8AyFNTSxOUuirA==", + "requires": { + "@ethereum-navigator/navigator": "^0.5.0", + "@oceanprotocol/contracts": "^0.5.7", + "decimal.js": "^10.2.0", + "fs": "0.0.1-security", + "lzma": "^2.3.2", + "node-fetch": "^2.6.1", + "save-file": "^2.3.1", + "uuid": "^8.3.0", + "web3": "^1.3.0", + "web3-eth-contract": "^1.3.0" + } + } } }, "@oceanprotocol/typographies": { diff --git a/src/components/organisms/AssetActions/Pool/Add/index.tsx b/src/components/organisms/AssetActions/Pool/Add/index.tsx index a9c2eaafc..bd252e3fd 100644 --- a/src/components/organisms/AssetActions/Pool/Add/index.tsx +++ b/src/components/organisms/AssetActions/Pool/Add/index.tsx @@ -43,6 +43,7 @@ const initialValues: FormAddLiquidity = { export default function Add({ setShowAdd, + refreshInfo, poolAddress, totalPoolTokens, totalBalance, @@ -51,6 +52,7 @@ export default function Add({ dtAddress }: { setShowAdd: (show: boolean) => void + refreshInfo: () => void poolAddress: string totalPoolTokens: string totalBalance: Balance @@ -127,6 +129,7 @@ export default function Add({ setTxId(result?.transactionHash) resetForm() + refreshInfo() } catch (error) { console.error(error.message) toast.error(error.message) diff --git a/src/components/organisms/AssetActions/Pool/Remove.tsx b/src/components/organisms/AssetActions/Pool/Remove.tsx index eeab15b43..0b21c1310 100644 --- a/src/components/organisms/AssetActions/Pool/Remove.tsx +++ b/src/components/organisms/AssetActions/Pool/Remove.tsx @@ -46,11 +46,13 @@ const contentQuery = graphql` export default function Remove({ setShowRemove, + refreshInfo, poolAddress, poolTokens, dtSymbol }: { setShowRemove: (show: boolean) => void + refreshInfo: () => void poolAddress: string poolTokens: string dtSymbol: string @@ -87,6 +89,7 @@ export default function Remove({ ) setTxId(result?.transactionHash) + refreshInfo() } catch (error) { Logger.error(error.message) toast.error(error.message) diff --git a/src/components/organisms/AssetActions/Pool/index.tsx b/src/components/organisms/AssetActions/Pool/index.tsx index 1c175e811..e86c89b2c 100644 --- a/src/components/organisms/AssetActions/Pool/index.tsx +++ b/src/components/organisms/AssetActions/Pool/index.tsx @@ -43,7 +43,7 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement { const content = data.content.edges[0].node.childContentJson.pool const { ocean, accountId, networkId } = useOcean() - const { price } = useMetadata(ddo) + const { price, refreshPrice } = useMetadata(ddo) const { dtSymbol } = usePricing(ddo) const [poolTokens, setPoolTokens] = useState() @@ -54,6 +54,8 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement { const [showAdd, setShowAdd] = useState(false) const [showRemove, setShowRemove] = useState(false) + // the purpose of the value is just to trigger the effect + const [refreshPool, setRefreshPool] = useState(false) // TODO: put all these variables behind some useEffect // to prevent unneccessary updating on every render const hasAddedLiquidity = @@ -115,13 +117,18 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement { } } init() - }, [ocean, accountId, price, ddo.dataToken]) + }, [ocean, accountId, price, ddo.dataToken, refreshPool]) + const refreshInfo = async () => { + setRefreshPool(!refreshPool) + await refreshPrice() + } return ( <> {showAdd ? (