@maxion-platform/ronin-market-sdk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1141 -0
- package/dist/cjs/actions/approve-token/index.js +64 -0
- package/dist/cjs/actions/approve-token/types.js +9 -0
- package/dist/cjs/actions/bulk-buy-token/index.js +116 -0
- package/dist/cjs/actions/buy-token/index.js +160 -0
- package/dist/cjs/actions/gift-token/index.js +49 -0
- package/dist/cjs/actions/offer/acceptOffer.js +40 -0
- package/dist/cjs/actions/offer/cancelOffer.js +27 -0
- package/dist/cjs/actions/offer/makeOffer.js +92 -0
- package/dist/cjs/actions/order/cancelOrder.js +58 -0
- package/dist/cjs/actions/order/createOrder.js +153 -0
- package/dist/cjs/actions/ron-wrapper/index.js +51 -0
- package/dist/cjs/common/constants.js +147 -0
- package/dist/cjs/configs/index.js +83 -0
- package/dist/cjs/contracts/BaseContract.js +23 -0
- package/dist/cjs/contracts/KatanaContract.js +25 -0
- package/dist/cjs/contracts/abis/collection-offer.json.js +2366 -0
- package/dist/cjs/contracts/abis/erc1155.json.js +823 -0
- package/dist/cjs/contracts/abis/erc20.json.js +232 -0
- package/dist/cjs/contracts/abis/erc721.json.js +825 -0
- package/dist/cjs/contracts/abis/katana.json.js +1034 -0
- package/dist/cjs/contracts/abis/market-gateway-multisend.json.js +394 -0
- package/dist/cjs/contracts/abis/market-gateway.json.js +774 -0
- package/dist/cjs/contracts/abis/multicall.json.js +349 -0
- package/dist/cjs/contracts/abis/royalty-registry.json.js +952 -0
- package/dist/cjs/contracts/abis/types/v5/factories/CollectionOffer__factory.js +2352 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Erc1155OrderExchange__factory.js +876 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Erc1155__factory.js +813 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Erc20__factory.js +240 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Erc721__factory.js +814 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Katana__factory.js +1041 -0
- package/dist/cjs/contracts/abis/types/v5/factories/MarketGatewayMultisend__factory.js +398 -0
- package/dist/cjs/contracts/abis/types/v5/factories/MarketGateway__factory.js +773 -0
- package/dist/cjs/contracts/abis/types/v5/factories/MavisExchange__factory.js +842 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Multicall__factory.js +355 -0
- package/dist/cjs/contracts/abis/types/v5/factories/RoyaltyRegistry__factory.js +949 -0
- package/dist/cjs/contracts/abis/types/v5/factories/Wron__factory.js +476 -0
- package/dist/cjs/contracts/abis/types/v5/factories/index.js +31 -0
- package/dist/cjs/contracts/abis/wron.json.js +478 -0
- package/dist/cjs/contracts/index.js +70 -0
- package/dist/cjs/contracts/market-gateway/Erc1155MarketGatewayContract.js +104 -0
- package/dist/cjs/contracts/market-gateway/MarketGatewayContract.js +102 -0
- package/dist/cjs/contracts/market-gateway/MarketGatewayMultisendContract.js +157 -0
- package/dist/cjs/contracts/market-gateway/factory.js +20 -0
- package/dist/cjs/index.js +278 -0
- package/dist/cjs/queries/collection/index.js +44 -0
- package/dist/cjs/queries/collection/types.js +8 -0
- package/dist/cjs/queries/exchange-rate/index.js +11 -0
- package/dist/cjs/queries/graphql/fragments/asset.js +24 -0
- package/dist/cjs/queries/graphql/fragments/collection.js +32 -0
- package/dist/cjs/queries/graphql/fragments/offer.js +61 -0
- package/dist/cjs/queries/graphql/fragments/order.js +77 -0
- package/dist/cjs/queries/graphql/fragments/profile.js +37 -0
- package/dist/cjs/queries/graphql/fragments/token.js +217 -0
- package/dist/cjs/queries/graphql/index.js +37 -0
- package/dist/cjs/queries/graphql/mutations/metadata.js +11 -0
- package/dist/cjs/queries/graphql/mutations/order.js +15 -0
- package/dist/cjs/queries/graphql/queries/collection.js +80 -0
- package/dist/cjs/queries/graphql/queries/exchange-rate.js +27 -0
- package/dist/cjs/queries/graphql/queries/offer.js +102 -0
- package/dist/cjs/queries/graphql/queries/order.js +105 -0
- package/dist/cjs/queries/graphql/queries/token.js +390 -0
- package/dist/cjs/queries/offer/index.js +92 -0
- package/dist/cjs/queries/offer/types.js +11 -0
- package/dist/cjs/queries/order/index.js +90 -0
- package/dist/cjs/queries/order/types.js +43 -0
- package/dist/cjs/queries/token/index.js +226 -0
- package/dist/cjs/queries/token/types.js +24 -0
- package/dist/cjs/services/balance/checkIsInsufficientBalance.js +16 -0
- package/dist/cjs/services/balance/fetchBalances.js +27 -0
- package/dist/cjs/services/order/bulkSettleOrders.js +26 -0
- package/dist/cjs/services/order/checkIsOrderValid.js +72 -0
- package/dist/cjs/services/order/generateOrderData.js +86 -0
- package/dist/cjs/services/order/getNonce.js +13 -0
- package/dist/cjs/services/order/getOrderSignature.js +18 -0
- package/dist/cjs/services/order/getOrderState.js +39 -0
- package/dist/cjs/services/order/getOrdersByCriteria.js +38 -0
- package/dist/cjs/services/order/getOrdersByQuantity.js +23 -0
- package/dist/cjs/services/order/getOrdersTotalPrice.js +46 -0
- package/dist/cjs/services/order/getSwapTokenData.js +41 -0
- package/dist/cjs/services/order/settleOrder.js +141 -0
- package/dist/cjs/services/tokens/checkIsTokenApproved.js +47 -0
- package/dist/cjs/services/tokens/configs.js +163 -0
- package/dist/cjs/services/tokens/data.js +150 -0
- package/dist/cjs/services/tokens/getPaymentTokens.js +14 -0
- package/dist/cjs/services/tokens/getTokensNeedToApprove.js +26 -0
- package/dist/cjs/services/tokens/getTokensNeedToApproveByOrders.js +31 -0
- package/dist/cjs/types/index.js +23 -0
- package/dist/cjs/types/order.js +13 -0
- package/dist/cjs/utils/convertPrice.js +13 -0
- package/dist/cjs/utils/getSpenderContractAddress.js +17 -0
- package/dist/cjs/utils/mapData.js +65 -0
- package/dist/mjs/actions/approve-token/index.js +47 -0
- package/dist/mjs/actions/approve-token/types.js +7 -0
- package/dist/mjs/actions/bulk-buy-token/index.js +86 -0
- package/dist/mjs/actions/buy-token/index.js +126 -0
- package/dist/mjs/actions/gift-token/index.js +27 -0
- package/dist/mjs/actions/offer/acceptOffer.js +15 -0
- package/dist/mjs/actions/offer/cancelOffer.js +3 -0
- package/dist/mjs/actions/offer/makeOffer.js +63 -0
- package/dist/mjs/actions/order/cancelOrder.js +32 -0
- package/dist/mjs/actions/order/createOrder.js +122 -0
- package/dist/mjs/actions/ron-wrapper/index.js +24 -0
- package/dist/mjs/common/constants.js +139 -0
- package/dist/mjs/configs/index.js +72 -0
- package/dist/mjs/contracts/BaseContract.js +15 -0
- package/dist/mjs/contracts/KatanaContract.js +19 -0
- package/dist/mjs/contracts/abis/collection-offer.json.js +2360 -0
- package/dist/mjs/contracts/abis/erc1155.json.js +817 -0
- package/dist/mjs/contracts/abis/erc20.json.js +226 -0
- package/dist/mjs/contracts/abis/erc721.json.js +819 -0
- package/dist/mjs/contracts/abis/katana.json.js +1028 -0
- package/dist/mjs/contracts/abis/market-gateway-multisend.json.js +388 -0
- package/dist/mjs/contracts/abis/market-gateway.json.js +768 -0
- package/dist/mjs/contracts/abis/multicall.json.js +343 -0
- package/dist/mjs/contracts/abis/royalty-registry.json.js +946 -0
- package/dist/mjs/contracts/abis/types/v5/factories/CollectionOffer__factory.js +2346 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Erc1155OrderExchange__factory.js +870 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Erc1155__factory.js +807 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Erc20__factory.js +234 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Erc721__factory.js +808 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Katana__factory.js +1035 -0
- package/dist/mjs/contracts/abis/types/v5/factories/MarketGatewayMultisend__factory.js +392 -0
- package/dist/mjs/contracts/abis/types/v5/factories/MarketGateway__factory.js +767 -0
- package/dist/mjs/contracts/abis/types/v5/factories/MavisExchange__factory.js +836 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Multicall__factory.js +349 -0
- package/dist/mjs/contracts/abis/types/v5/factories/RoyaltyRegistry__factory.js +943 -0
- package/dist/mjs/contracts/abis/types/v5/factories/Wron__factory.js +470 -0
- package/dist/mjs/contracts/abis/types/v5/factories/index.js +3 -0
- package/dist/mjs/contracts/abis/wron.json.js +472 -0
- package/dist/mjs/contracts/index.js +40 -0
- package/dist/mjs/contracts/market-gateway/Erc1155MarketGatewayContract.js +94 -0
- package/dist/mjs/contracts/market-gateway/MarketGatewayContract.js +91 -0
- package/dist/mjs/contracts/market-gateway/MarketGatewayMultisendContract.js +146 -0
- package/dist/mjs/contracts/market-gateway/factory.js +10 -0
- package/dist/mjs/index.js +1 -0
- package/dist/mjs/queries/collection/index.js +29 -0
- package/dist/mjs/queries/collection/types.js +6 -0
- package/dist/mjs/queries/exchange-rate/index.js +4 -0
- package/dist/mjs/queries/graphql/fragments/asset.js +17 -0
- package/dist/mjs/queries/graphql/fragments/collection.js +25 -0
- package/dist/mjs/queries/graphql/fragments/offer.js +53 -0
- package/dist/mjs/queries/graphql/fragments/order.js +68 -0
- package/dist/mjs/queries/graphql/fragments/profile.js +29 -0
- package/dist/mjs/queries/graphql/fragments/token.js +199 -0
- package/dist/mjs/queries/graphql/index.js +27 -0
- package/dist/mjs/queries/graphql/mutations/metadata.js +5 -0
- package/dist/mjs/queries/graphql/mutations/order.js +8 -0
- package/dist/mjs/queries/graphql/queries/collection.js +69 -0
- package/dist/mjs/queries/graphql/queries/exchange-rate.js +21 -0
- package/dist/mjs/queries/graphql/queries/offer.js +90 -0
- package/dist/mjs/queries/graphql/queries/order.js +94 -0
- package/dist/mjs/queries/graphql/queries/token.js +368 -0
- package/dist/mjs/queries/offer/index.js +75 -0
- package/dist/mjs/queries/offer/types.js +9 -0
- package/dist/mjs/queries/order/index.js +59 -0
- package/dist/mjs/queries/order/types.js +41 -0
- package/dist/mjs/queries/token/index.js +189 -0
- package/dist/mjs/queries/token/types.js +22 -0
- package/dist/mjs/services/balance/checkIsInsufficientBalance.js +8 -0
- package/dist/mjs/services/balance/fetchBalances.js +15 -0
- package/dist/mjs/services/order/bulkSettleOrders.js +17 -0
- package/dist/mjs/services/order/checkIsOrderValid.js +47 -0
- package/dist/mjs/services/order/generateOrderData.js +76 -0
- package/dist/mjs/services/order/getNonce.js +6 -0
- package/dist/mjs/services/order/getOrderSignature.js +10 -0
- package/dist/mjs/services/order/getOrderState.js +28 -0
- package/dist/mjs/services/order/getOrdersByCriteria.js +26 -0
- package/dist/mjs/services/order/getOrdersByQuantity.js +19 -0
- package/dist/mjs/services/order/getOrdersTotalPrice.js +36 -0
- package/dist/mjs/services/order/getSwapTokenData.js +25 -0
- package/dist/mjs/services/order/settleOrder.js +122 -0
- package/dist/mjs/services/tokens/checkIsTokenApproved.js +35 -0
- package/dist/mjs/services/tokens/configs.js +153 -0
- package/dist/mjs/services/tokens/data.js +143 -0
- package/dist/mjs/services/tokens/getPaymentTokens.js +7 -0
- package/dist/mjs/services/tokens/getTokensNeedToApprove.js +18 -0
- package/dist/mjs/services/tokens/getTokensNeedToApproveByOrders.js +22 -0
- package/dist/mjs/types/index.js +10 -0
- package/dist/mjs/types/order.js +11 -0
- package/dist/mjs/utils/convertPrice.js +7 -0
- package/dist/mjs/utils/getSpenderContractAddress.js +10 -0
- package/dist/mjs/utils/mapData.js +43 -0
- package/dist/types/actions/approve-token/index.d.ts +8 -0
- package/dist/types/actions/approve-token/index.d.ts.map +1 -0
- package/dist/types/actions/approve-token/types.d.ts +25 -0
- package/dist/types/actions/approve-token/types.d.ts.map +1 -0
- package/dist/types/actions/bulk-buy-token/index.d.ts +4 -0
- package/dist/types/actions/bulk-buy-token/index.d.ts.map +1 -0
- package/dist/types/actions/bulk-buy-token/types.d.ts +25 -0
- package/dist/types/actions/bulk-buy-token/types.d.ts.map +1 -0
- package/dist/types/actions/buy-token/index.d.ts +8 -0
- package/dist/types/actions/buy-token/index.d.ts.map +1 -0
- package/dist/types/actions/buy-token/types.d.ts +28 -0
- package/dist/types/actions/buy-token/types.d.ts.map +1 -0
- package/dist/types/actions/gift-token/index.d.ts +6 -0
- package/dist/types/actions/gift-token/index.d.ts.map +1 -0
- package/dist/types/actions/gift-token/types.d.ts +16 -0
- package/dist/types/actions/gift-token/types.d.ts.map +1 -0
- package/dist/types/actions/index.d.ts +8 -0
- package/dist/types/actions/index.d.ts.map +1 -0
- package/dist/types/actions/offer/acceptOffer.d.ts +3 -0
- package/dist/types/actions/offer/acceptOffer.d.ts.map +1 -0
- package/dist/types/actions/offer/cancelOffer.d.ts +3 -0
- package/dist/types/actions/offer/cancelOffer.d.ts.map +1 -0
- package/dist/types/actions/offer/index.d.ts +5 -0
- package/dist/types/actions/offer/index.d.ts.map +1 -0
- package/dist/types/actions/offer/makeOffer.d.ts +3 -0
- package/dist/types/actions/offer/makeOffer.d.ts.map +1 -0
- package/dist/types/actions/offer/types.d.ts +21 -0
- package/dist/types/actions/offer/types.d.ts.map +1 -0
- package/dist/types/actions/order/cancelOrder.d.ts +5 -0
- package/dist/types/actions/order/cancelOrder.d.ts.map +1 -0
- package/dist/types/actions/order/createOrder.d.ts +5 -0
- package/dist/types/actions/order/createOrder.d.ts.map +1 -0
- package/dist/types/actions/order/index.d.ts +4 -0
- package/dist/types/actions/order/index.d.ts.map +1 -0
- package/dist/types/actions/order/types.d.ts +30 -0
- package/dist/types/actions/order/types.d.ts.map +1 -0
- package/dist/types/actions/ron-wrapper/index.d.ts +5 -0
- package/dist/types/actions/ron-wrapper/index.d.ts.map +1 -0
- package/dist/types/actions/ron-wrapper/types.d.ts +9 -0
- package/dist/types/actions/ron-wrapper/types.d.ts.map +1 -0
- package/dist/types/common/constants.d.ts +24 -0
- package/dist/types/common/constants.d.ts.map +1 -0
- package/dist/types/common/index.d.ts +2 -0
- package/dist/types/common/index.d.ts.map +1 -0
- package/dist/types/configs/index.d.ts +28 -0
- package/dist/types/configs/index.d.ts.map +1 -0
- package/dist/types/contracts/BaseContract.d.ts +6 -0
- package/dist/types/contracts/BaseContract.d.ts.map +1 -0
- package/dist/types/contracts/KatanaContract.d.ts +9 -0
- package/dist/types/contracts/KatanaContract.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/CollectionOffer.d.ts +871 -0
- package/dist/types/contracts/abis/types/v5/CollectionOffer.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Erc1155.d.ts +535 -0
- package/dist/types/contracts/abis/types/v5/Erc1155.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Erc1155OrderExchange.d.ts +522 -0
- package/dist/types/contracts/abis/types/v5/Erc1155OrderExchange.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Erc20.d.ts +169 -0
- package/dist/types/contracts/abis/types/v5/Erc20.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Erc721.d.ts +547 -0
- package/dist/types/contracts/abis/types/v5/Erc721.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Katana.d.ts +548 -0
- package/dist/types/contracts/abis/types/v5/Katana.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/MarketGateway.d.ts +543 -0
- package/dist/types/contracts/abis/types/v5/MarketGateway.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/MarketGatewayMultisend.d.ts +267 -0
- package/dist/types/contracts/abis/types/v5/MarketGatewayMultisend.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/MavisExchange.d.ts +508 -0
- package/dist/types/contracts/abis/types/v5/MavisExchange.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Multicall.d.ts +219 -0
- package/dist/types/contracts/abis/types/v5/Multicall.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/RoyaltyRegistry.d.ts +497 -0
- package/dist/types/contracts/abis/types/v5/RoyaltyRegistry.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/Wron.d.ts +348 -0
- package/dist/types/contracts/abis/types/v5/Wron.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/common.d.ts +23 -0
- package/dist/types/contracts/abis/types/v5/common.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/CollectionOffer__factory.d.ts +1826 -0
- package/dist/types/contracts/abis/types/v5/factories/CollectionOffer__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc1155OrderExchange__factory.d.ts +672 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc1155OrderExchange__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc1155__factory.d.ts +626 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc1155__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc20__factory.d.ts +176 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc20__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc721__factory.d.ts +620 -0
- package/dist/types/contracts/abis/types/v5/factories/Erc721__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Katana__factory.d.ts +810 -0
- package/dist/types/contracts/abis/types/v5/factories/Katana__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/MarketGatewayMultisend__factory.d.ts +302 -0
- package/dist/types/contracts/abis/types/v5/factories/MarketGatewayMultisend__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/MarketGateway__factory.d.ts +588 -0
- package/dist/types/contracts/abis/types/v5/factories/MarketGateway__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/MavisExchange__factory.d.ts +646 -0
- package/dist/types/contracts/abis/types/v5/factories/MavisExchange__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Multicall__factory.d.ts +268 -0
- package/dist/types/contracts/abis/types/v5/factories/Multicall__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/RoyaltyRegistry__factory.d.ts +721 -0
- package/dist/types/contracts/abis/types/v5/factories/RoyaltyRegistry__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/Wron__factory.d.ts +369 -0
- package/dist/types/contracts/abis/types/v5/factories/Wron__factory.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/factories/index.d.ts +13 -0
- package/dist/types/contracts/abis/types/v5/factories/index.d.ts.map +1 -0
- package/dist/types/contracts/abis/types/v5/index.d.ts +26 -0
- package/dist/types/contracts/abis/types/v5/index.d.ts.map +1 -0
- package/dist/types/contracts/index.d.ts +19 -0
- package/dist/types/contracts/index.d.ts.map +1 -0
- package/dist/types/contracts/market-gateway/Erc1155MarketGatewayContract.d.ts +46 -0
- package/dist/types/contracts/market-gateway/Erc1155MarketGatewayContract.d.ts.map +1 -0
- package/dist/types/contracts/market-gateway/MarketGatewayContract.d.ts +43 -0
- package/dist/types/contracts/market-gateway/MarketGatewayContract.d.ts.map +1 -0
- package/dist/types/contracts/market-gateway/MarketGatewayMultisendContract.d.ts +60 -0
- package/dist/types/contracts/market-gateway/MarketGatewayMultisendContract.d.ts.map +1 -0
- package/dist/types/contracts/market-gateway/factory.d.ts +6 -0
- package/dist/types/contracts/market-gateway/factory.d.ts.map +1 -0
- package/dist/types/contracts/market-gateway/index.d.ts +5 -0
- package/dist/types/contracts/market-gateway/index.d.ts.map +1 -0
- package/dist/types/index.d.ts +9 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/queries/collection/index.d.ts +11 -0
- package/dist/types/queries/collection/index.d.ts.map +1 -0
- package/dist/types/queries/collection/queryTypes.d.ts +40 -0
- package/dist/types/queries/collection/queryTypes.d.ts.map +1 -0
- package/dist/types/queries/collection/types.d.ts +98 -0
- package/dist/types/queries/collection/types.d.ts.map +1 -0
- package/dist/types/queries/exchange-rate/index.d.ts +5 -0
- package/dist/types/queries/exchange-rate/index.d.ts.map +1 -0
- package/dist/types/queries/exchange-rate/queryTypes.d.ts +9 -0
- package/dist/types/queries/exchange-rate/queryTypes.d.ts.map +1 -0
- package/dist/types/queries/exchange-rate/types.d.ts +11 -0
- package/dist/types/queries/exchange-rate/types.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/asset.d.ts +3 -0
- package/dist/types/queries/graphql/fragments/asset.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/collection.d.ts +3 -0
- package/dist/types/queries/graphql/fragments/collection.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/offer.d.ts +3 -0
- package/dist/types/queries/graphql/fragments/offer.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/order.d.ts +3 -0
- package/dist/types/queries/graphql/fragments/order.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/profile.d.ts +4 -0
- package/dist/types/queries/graphql/fragments/profile.d.ts.map +1 -0
- package/dist/types/queries/graphql/fragments/token.d.ts +12 -0
- package/dist/types/queries/graphql/fragments/token.d.ts.map +1 -0
- package/dist/types/queries/graphql/index.d.ts +14 -0
- package/dist/types/queries/graphql/index.d.ts.map +1 -0
- package/dist/types/queries/graphql/mutations/metadata.d.ts +2 -0
- package/dist/types/queries/graphql/mutations/metadata.d.ts.map +1 -0
- package/dist/types/queries/graphql/mutations/order.d.ts +2 -0
- package/dist/types/queries/graphql/mutations/order.d.ts.map +1 -0
- package/dist/types/queries/graphql/queries/collection.d.ts +5 -0
- package/dist/types/queries/graphql/queries/collection.d.ts.map +1 -0
- package/dist/types/queries/graphql/queries/exchange-rate.d.ts +2 -0
- package/dist/types/queries/graphql/queries/exchange-rate.d.ts.map +1 -0
- package/dist/types/queries/graphql/queries/offer.d.ts +7 -0
- package/dist/types/queries/graphql/queries/offer.d.ts.map +1 -0
- package/dist/types/queries/graphql/queries/order.d.ts +6 -0
- package/dist/types/queries/graphql/queries/order.d.ts.map +1 -0
- package/dist/types/queries/graphql/queries/token.d.ts +14 -0
- package/dist/types/queries/graphql/queries/token.d.ts.map +1 -0
- package/dist/types/queries/index.d.ts +8 -0
- package/dist/types/queries/index.d.ts.map +1 -0
- package/dist/types/queries/offer/index.d.ts +19 -0
- package/dist/types/queries/offer/index.d.ts.map +1 -0
- package/dist/types/queries/offer/queryTypes.d.ts +89 -0
- package/dist/types/queries/offer/queryTypes.d.ts.map +1 -0
- package/dist/types/queries/offer/types.d.ts +33 -0
- package/dist/types/queries/offer/types.d.ts.map +1 -0
- package/dist/types/queries/order/index.d.ts +14 -0
- package/dist/types/queries/order/index.d.ts.map +1 -0
- package/dist/types/queries/order/queryTypes.d.ts +87 -0
- package/dist/types/queries/order/queryTypes.d.ts.map +1 -0
- package/dist/types/queries/order/types.d.ts +96 -0
- package/dist/types/queries/order/types.d.ts.map +1 -0
- package/dist/types/queries/profile/index.d.ts +2 -0
- package/dist/types/queries/profile/index.d.ts.map +1 -0
- package/dist/types/queries/profile/types.d.ts +11 -0
- package/dist/types/queries/profile/types.d.ts.map +1 -0
- package/dist/types/queries/token/index.d.ts +92 -0
- package/dist/types/queries/token/index.d.ts.map +1 -0
- package/dist/types/queries/token/queryTypes.d.ts +304 -0
- package/dist/types/queries/token/queryTypes.d.ts.map +1 -0
- package/dist/types/queries/token/types.d.ts +103 -0
- package/dist/types/queries/token/types.d.ts.map +1 -0
- package/dist/types/services/balance/checkIsInsufficientBalance.d.ts +4 -0
- package/dist/types/services/balance/checkIsInsufficientBalance.d.ts.map +1 -0
- package/dist/types/services/balance/fetchBalances.d.ts +4 -0
- package/dist/types/services/balance/fetchBalances.d.ts.map +1 -0
- package/dist/types/services/balance/index.d.ts +3 -0
- package/dist/types/services/balance/index.d.ts.map +1 -0
- package/dist/types/services/index.d.ts +4 -0
- package/dist/types/services/index.d.ts.map +1 -0
- package/dist/types/services/order/bulkSettleOrders.d.ts +21 -0
- package/dist/types/services/order/bulkSettleOrders.d.ts.map +1 -0
- package/dist/types/services/order/checkIsOrderValid.d.ts +5 -0
- package/dist/types/services/order/checkIsOrderValid.d.ts.map +1 -0
- package/dist/types/services/order/generateOrderData.d.ts +6 -0
- package/dist/types/services/order/generateOrderData.d.ts.map +1 -0
- package/dist/types/services/order/getNonce.d.ts +3 -0
- package/dist/types/services/order/getNonce.d.ts.map +1 -0
- package/dist/types/services/order/getOrderSignature.d.ts +4 -0
- package/dist/types/services/order/getOrderSignature.d.ts.map +1 -0
- package/dist/types/services/order/getOrderState.d.ts +4 -0
- package/dist/types/services/order/getOrderState.d.ts.map +1 -0
- package/dist/types/services/order/getOrdersByCriteria.d.ts +4 -0
- package/dist/types/services/order/getOrdersByCriteria.d.ts.map +1 -0
- package/dist/types/services/order/getOrdersByQuantity.d.ts +4 -0
- package/dist/types/services/order/getOrdersByQuantity.d.ts.map +1 -0
- package/dist/types/services/order/getOrdersTotalPrice.d.ts +15 -0
- package/dist/types/services/order/getOrdersTotalPrice.d.ts.map +1 -0
- package/dist/types/services/order/getSwapTokenData.d.ts +9 -0
- package/dist/types/services/order/getSwapTokenData.d.ts.map +1 -0
- package/dist/types/services/order/index.d.ts +11 -0
- package/dist/types/services/order/index.d.ts.map +1 -0
- package/dist/types/services/order/settleOrder.d.ts +11 -0
- package/dist/types/services/order/settleOrder.d.ts.map +1 -0
- package/dist/types/services/tokens/checkIsTokenApproved.d.ts +6 -0
- package/dist/types/services/tokens/checkIsTokenApproved.d.ts.map +1 -0
- package/dist/types/services/tokens/configs.d.ts +71 -0
- package/dist/types/services/tokens/configs.d.ts.map +1 -0
- package/dist/types/services/tokens/data.d.ts +45 -0
- package/dist/types/services/tokens/data.d.ts.map +1 -0
- package/dist/types/services/tokens/getPaymentTokens.d.ts +11 -0
- package/dist/types/services/tokens/getPaymentTokens.d.ts.map +1 -0
- package/dist/types/services/tokens/getTokensNeedToApprove.d.ts +4 -0
- package/dist/types/services/tokens/getTokensNeedToApprove.d.ts.map +1 -0
- package/dist/types/services/tokens/getTokensNeedToApproveByOrders.d.ts +4 -0
- package/dist/types/services/tokens/getTokensNeedToApproveByOrders.d.ts.map +1 -0
- package/dist/types/services/tokens/index.d.ts +7 -0
- package/dist/types/services/tokens/index.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +11 -0
- package/dist/types/types/index.d.ts.map +1 -0
- package/dist/types/types/order.d.ts +72 -0
- package/dist/types/types/order.d.ts.map +1 -0
- package/dist/types/types/wallet.d.ts +10 -0
- package/dist/types/types/wallet.d.ts.map +1 -0
- package/dist/types/utils/convertPrice.d.ts +3 -0
- package/dist/types/utils/convertPrice.d.ts.map +1 -0
- package/dist/types/utils/getSpenderContractAddress.d.ts +3 -0
- package/dist/types/utils/getSpenderContractAddress.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +4 -0
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/types/utils/mapData.d.ts +7 -0
- package/dist/types/utils/mapData.d.ts.map +1 -0
- package/package.json +72 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var order = require('./order.js');
|
|
4
|
+
|
|
5
|
+
exports.ChainId = void 0;
|
|
6
|
+
(function (ChainId) {
|
|
7
|
+
ChainId[ChainId["mainnet"] = 2020] = "mainnet";
|
|
8
|
+
ChainId[ChainId["testnet"] = 202601] = "testnet";
|
|
9
|
+
})(exports.ChainId || (exports.ChainId = {}));
|
|
10
|
+
exports.SpenderContractType = void 0;
|
|
11
|
+
(function (SpenderContractType) {
|
|
12
|
+
SpenderContractType["MarketGatewayContract"] = "MarketGatewayContract";
|
|
13
|
+
SpenderContractType["MarketGatewayMultiSendContract"] = "MarketGatewayMultiSendContract";
|
|
14
|
+
})(exports.SpenderContractType || (exports.SpenderContractType = {}));
|
|
15
|
+
|
|
16
|
+
Object.defineProperty(exports, 'ErcAssetItem', {
|
|
17
|
+
enumerable: true,
|
|
18
|
+
get: function () { return order.ErcAssetItem; }
|
|
19
|
+
});
|
|
20
|
+
Object.defineProperty(exports, 'OrderKind', {
|
|
21
|
+
enumerable: true,
|
|
22
|
+
get: function () { return order.OrderKind; }
|
|
23
|
+
});
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
exports.ErcAssetItem = void 0;
|
|
4
|
+
(function (ErcAssetItem) {
|
|
5
|
+
ErcAssetItem[ErcAssetItem["Erc20"] = 0] = "Erc20";
|
|
6
|
+
ErcAssetItem[ErcAssetItem["Erc721"] = 1] = "Erc721";
|
|
7
|
+
ErcAssetItem[ErcAssetItem["Erc1155"] = 2] = "Erc1155";
|
|
8
|
+
})(exports.ErcAssetItem || (exports.ErcAssetItem = {}));
|
|
9
|
+
exports.OrderKind = void 0;
|
|
10
|
+
(function (OrderKind) {
|
|
11
|
+
OrderKind[OrderKind["Offer"] = 0] = "Offer";
|
|
12
|
+
OrderKind[OrderKind["Sell"] = 1] = "Sell";
|
|
13
|
+
})(exports.OrderKind || (exports.OrderKind = {}));
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var mapData = require('./mapData.js');
|
|
4
|
+
|
|
5
|
+
const convertAmountToUsd = (amount, tokenSymbol, exchangeRate) => {
|
|
6
|
+
if (!exchangeRate || !amount) {
|
|
7
|
+
return 0;
|
|
8
|
+
}
|
|
9
|
+
const rate = mapData.getRate(tokenSymbol, exchangeRate);
|
|
10
|
+
return amount * rate;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
exports.convertAmountToUsd = convertAmountToUsd;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var lodash = require('lodash');
|
|
4
|
+
var index = require('../configs/index.js');
|
|
5
|
+
|
|
6
|
+
const getSpenderContractAddress = (chainId, spenderContract) => {
|
|
7
|
+
const config = index.getConfig(chainId);
|
|
8
|
+
const marketGatewayContractAddress = config.contractsAddress.marketGateway;
|
|
9
|
+
if (lodash.isEmpty(spenderContract)) {
|
|
10
|
+
return marketGatewayContractAddress;
|
|
11
|
+
}
|
|
12
|
+
const spenderAddressConfig = index.getSpenderContractConfig(chainId);
|
|
13
|
+
const spenderAddress = spenderAddressConfig[spenderContract];
|
|
14
|
+
return spenderAddress || marketGatewayContractAddress;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
exports.getSpenderContractAddress = getSpenderContractAddress;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
require('graphql-request');
|
|
4
|
+
require('../types/index.js');
|
|
5
|
+
require('../queries/graphql/queries/collection.js');
|
|
6
|
+
var types$1 = require('../queries/collection/types.js');
|
|
7
|
+
require('../queries/graphql/queries/exchange-rate.js');
|
|
8
|
+
require('../queries/graphql/queries/offer.js');
|
|
9
|
+
require('../queries/offer/types.js');
|
|
10
|
+
require('../queries/graphql/mutations/order.js');
|
|
11
|
+
require('../queries/graphql/queries/order.js');
|
|
12
|
+
require('../queries/token/types.js');
|
|
13
|
+
var types = require('../queries/order/types.js');
|
|
14
|
+
require('../queries/graphql/mutations/metadata.js');
|
|
15
|
+
require('../queries/graphql/queries/token.js');
|
|
16
|
+
var order = require('../types/order.js');
|
|
17
|
+
|
|
18
|
+
const getOrderKind = (orderType) => {
|
|
19
|
+
switch (orderType) {
|
|
20
|
+
case types.OrderType.Offer:
|
|
21
|
+
return order.OrderKind.Offer;
|
|
22
|
+
default:
|
|
23
|
+
return order.OrderKind.Sell;
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
const getErcAssetItem = (ercType) => {
|
|
27
|
+
switch (ercType) {
|
|
28
|
+
case types$1.Erc.Erc20:
|
|
29
|
+
return order.ErcAssetItem.Erc20;
|
|
30
|
+
case types$1.Erc.Erc1155:
|
|
31
|
+
return order.ErcAssetItem.Erc1155;
|
|
32
|
+
case types$1.Erc.Erc721:
|
|
33
|
+
return order.ErcAssetItem.Erc721;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
const getErcType = (ercAssetItem) => {
|
|
37
|
+
switch (ercAssetItem) {
|
|
38
|
+
case order.ErcAssetItem.Erc20:
|
|
39
|
+
return types$1.Erc.Erc20;
|
|
40
|
+
case order.ErcAssetItem.Erc1155:
|
|
41
|
+
return types$1.Erc.Erc1155;
|
|
42
|
+
case order.ErcAssetItem.Erc721:
|
|
43
|
+
return types$1.Erc.Erc721;
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const getRate = (tokenSymbol, exchangeRate) => {
|
|
47
|
+
switch (tokenSymbol.toUpperCase()) {
|
|
48
|
+
case 'WRON':
|
|
49
|
+
case 'RON':
|
|
50
|
+
return exchangeRate.ron.usd;
|
|
51
|
+
case 'AXS':
|
|
52
|
+
return exchangeRate.axs.usd;
|
|
53
|
+
case 'SLP':
|
|
54
|
+
return exchangeRate.slp.usd;
|
|
55
|
+
case 'USDC':
|
|
56
|
+
return exchangeRate.usd.usd;
|
|
57
|
+
default:
|
|
58
|
+
return exchangeRate.eth.usd;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
exports.getErcAssetItem = getErcAssetItem;
|
|
63
|
+
exports.getErcType = getErcType;
|
|
64
|
+
exports.getOrderKind = getOrderKind;
|
|
65
|
+
exports.getRate = getRate;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import {BigNumber}from'ethers';import {getConfig}from'../../configs/index.js';import {createWRonContract,createErc20Contract,createErc721Contract,createErc1155Contract}from'../../contracts/index.js';import {ApproveTokenType}from'./types.js';const approveWRonToken = async (params) => {
|
|
2
|
+
const { chainId, wallet, options } = params;
|
|
3
|
+
const { provider, account } = wallet;
|
|
4
|
+
const approvedValue = BigNumber.from('1').shl(256).sub(1).toString();
|
|
5
|
+
const config = getConfig(chainId);
|
|
6
|
+
const marketGatewayContract = config.contractsAddress.marketGateway;
|
|
7
|
+
const wRonContract = createWRonContract(chainId, provider);
|
|
8
|
+
return wRonContract.approve(marketGatewayContract, approvedValue, { ...options, from: account });
|
|
9
|
+
};
|
|
10
|
+
const approveErc20Token = async (params) => {
|
|
11
|
+
const { chainId, wallet, address, spenderAddress, options } = params;
|
|
12
|
+
const { provider, account } = wallet;
|
|
13
|
+
const approvedValue = BigNumber.from('1').shl(256).sub(1).toString();
|
|
14
|
+
const config = getConfig(chainId);
|
|
15
|
+
const spender = spenderAddress || config.contractsAddress.marketGateway;
|
|
16
|
+
const erc20Contract = createErc20Contract(address, provider);
|
|
17
|
+
return erc20Contract.approve(spender, approvedValue, { ...options, from: account });
|
|
18
|
+
};
|
|
19
|
+
const approveErc721Token = async (params) => {
|
|
20
|
+
const { chainId, wallet, address, options } = params;
|
|
21
|
+
const { provider, account } = wallet;
|
|
22
|
+
const config = getConfig(chainId);
|
|
23
|
+
const marketGatewayContract = config.contractsAddress.marketGateway;
|
|
24
|
+
const erc721Contract = createErc721Contract(address, provider);
|
|
25
|
+
return erc721Contract.setApprovalForAll(marketGatewayContract, true, { ...options, from: account });
|
|
26
|
+
};
|
|
27
|
+
const approveErc1155Token = async (params) => {
|
|
28
|
+
const { chainId, wallet, address, options } = params;
|
|
29
|
+
const { provider, account } = wallet;
|
|
30
|
+
const config = getConfig(chainId);
|
|
31
|
+
const marketGatewayContract = config.contractsAddress.marketGateway;
|
|
32
|
+
const erc1155Contract = createErc1155Contract(address, provider);
|
|
33
|
+
return erc1155Contract.setApprovalForAll(marketGatewayContract, true, { ...options, from: account });
|
|
34
|
+
};
|
|
35
|
+
const approveToken = (params) => {
|
|
36
|
+
const { tokenType, ...otherParams } = params;
|
|
37
|
+
if (tokenType === ApproveTokenType.Erc20) {
|
|
38
|
+
return approveErc20Token(otherParams);
|
|
39
|
+
}
|
|
40
|
+
if (tokenType === ApproveTokenType.Erc721) {
|
|
41
|
+
return approveErc721Token(otherParams);
|
|
42
|
+
}
|
|
43
|
+
if (tokenType === ApproveTokenType.Erc1155) {
|
|
44
|
+
return approveErc721Token(otherParams);
|
|
45
|
+
}
|
|
46
|
+
return approveWRonToken(otherParams);
|
|
47
|
+
};export{ApproveTokenType,approveErc1155Token,approveErc20Token,approveErc721Token,approveToken,approveWRonToken};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
var ApproveTokenType;
|
|
2
|
+
(function (ApproveTokenType) {
|
|
3
|
+
ApproveTokenType["Erc721"] = "Erc721";
|
|
4
|
+
ApproveTokenType["Erc1155"] = "Erc1155";
|
|
5
|
+
ApproveTokenType["Erc20"] = "Erc20";
|
|
6
|
+
ApproveTokenType["WRon"] = "WRon";
|
|
7
|
+
})(ApproveTokenType || (ApproveTokenType = {}));export{ApproveTokenType};
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import {BigNumber}from'ethers';import {SWAP_DEFAULT_SLIPPAGE,ZERO_ADDRESS}from'../../common/constants.js';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/collection.js';import {Erc}from'../../queries/collection/types.js';import'../../queries/graphql/queries/exchange-rate.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import'../../queries/graphql/mutations/order.js';import'../../queries/graphql/queries/order.js';import'../../queries/token/types.js';import'../../queries/order/types.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import {checkIsInsufficientBalance}from'../../services/balance/checkIsInsufficientBalance.js';import'../../configs/index.js';import'../../services/tokens/data.js';import {getPaymentToken}from'../../services/tokens/getPaymentTokens.js';import {getSwapConfig}from'../../services/tokens/configs.js';import'lodash';import {getOrdersTotalPrice}from'../../services/order/getOrdersTotalPrice.js';import {generateErc721Order,generateErc1155Order}from'../../services/order/generateOrderData.js';import'ethers/lib/utils';import {bulkSettleOrders}from'../../services/order/bulkSettleOrders.js';const parseOrder = (params) => {
|
|
2
|
+
const { tokenType, order, totalPrice, quantity, referralAddr = ZERO_ADDRESS } = params;
|
|
3
|
+
const { expectedState, signature } = order;
|
|
4
|
+
if (tokenType === Erc.Erc721) {
|
|
5
|
+
const orderData = generateErc721Order(order);
|
|
6
|
+
return {
|
|
7
|
+
expectedState,
|
|
8
|
+
settlePrice: totalPrice,
|
|
9
|
+
referralAddr,
|
|
10
|
+
signature,
|
|
11
|
+
order: orderData,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
const orderData = generateErc1155Order(order);
|
|
15
|
+
return {
|
|
16
|
+
expectedState,
|
|
17
|
+
settlePrice: totalPrice,
|
|
18
|
+
referralAddr,
|
|
19
|
+
signature,
|
|
20
|
+
order: orderData,
|
|
21
|
+
quantity: quantity.toString(),
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
const swapAndParseOrder = (chainId, order, totalPrice, quantity, selectedToken, deadline, tokenType) => {
|
|
25
|
+
const { paymentToken: listingToken } = order;
|
|
26
|
+
const { address } = selectedToken;
|
|
27
|
+
const swapConfig = getSwapConfig(chainId, listingToken);
|
|
28
|
+
const path = swapConfig[address].path;
|
|
29
|
+
const settlePrice = BigNumber.from(totalPrice || '0')
|
|
30
|
+
.mul(100 + SWAP_DEFAULT_SLIPPAGE)
|
|
31
|
+
.div(100)
|
|
32
|
+
.toString();
|
|
33
|
+
const parsedOrder = parseOrder({ tokenType, order, totalPrice: settlePrice, quantity });
|
|
34
|
+
return {
|
|
35
|
+
...parsedOrder,
|
|
36
|
+
deadline,
|
|
37
|
+
path,
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
const bulkBuyToken = async (params) => {
|
|
41
|
+
try {
|
|
42
|
+
const { chainId, wallet, data, selectedTokenAddress, deadline, tokenType, requiredAllSuccess = false, options, } = params;
|
|
43
|
+
const selectedToken = getPaymentToken(chainId, selectedTokenAddress);
|
|
44
|
+
const { address: paymentToken } = selectedToken;
|
|
45
|
+
const { account } = wallet;
|
|
46
|
+
const { totalPriceOfEachOrder } = await getOrdersTotalPrice({
|
|
47
|
+
data,
|
|
48
|
+
chainId,
|
|
49
|
+
token: selectedToken,
|
|
50
|
+
wallet,
|
|
51
|
+
});
|
|
52
|
+
let totalSettlePrice = BigNumber.from('0');
|
|
53
|
+
const bulkBuyData = data.map(({ quantity, order }) => {
|
|
54
|
+
const { paymentToken: listingToken, hash } = order;
|
|
55
|
+
const totalPrice = totalPriceOfEachOrder[hash];
|
|
56
|
+
const isListingWithPaymentToken = listingToken.toLowerCase() === paymentToken.toLowerCase();
|
|
57
|
+
if (isListingWithPaymentToken) {
|
|
58
|
+
totalSettlePrice = totalSettlePrice.add(totalPrice);
|
|
59
|
+
return parseOrder({ tokenType, order, totalPrice, quantity: quantity.toString() });
|
|
60
|
+
}
|
|
61
|
+
const settlePrice = BigNumber.from(totalPrice || '0')
|
|
62
|
+
.mul(100 + SWAP_DEFAULT_SLIPPAGE)
|
|
63
|
+
.div(100)
|
|
64
|
+
.toString();
|
|
65
|
+
totalSettlePrice = totalSettlePrice.add(settlePrice);
|
|
66
|
+
return swapAndParseOrder(chainId, order, totalPrice, quantity.toString(), selectedToken, deadline, tokenType);
|
|
67
|
+
});
|
|
68
|
+
const isInsufficient = await checkIsInsufficientBalance(chainId, selectedTokenAddress, account, totalSettlePrice.toString());
|
|
69
|
+
if (isInsufficient) {
|
|
70
|
+
throw new Error('Insufficient balance for transaction.');
|
|
71
|
+
}
|
|
72
|
+
return bulkSettleOrders({
|
|
73
|
+
chainId,
|
|
74
|
+
wallet,
|
|
75
|
+
bulkBuyData: bulkBuyData,
|
|
76
|
+
paymentToken,
|
|
77
|
+
totalSettlePrice: totalSettlePrice.toString(),
|
|
78
|
+
tokenType,
|
|
79
|
+
requiredAllSuccess,
|
|
80
|
+
options,
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
catch (error) {
|
|
84
|
+
throw new Error(error.message || error);
|
|
85
|
+
}
|
|
86
|
+
};export{bulkBuyToken};
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import {BigNumber}from'ethers';import {formatUnits}from'ethers/lib/utils';import {SWAP_DEFAULT_SLIPPAGE,ZERO_ADDRESS}from'../../common/constants.js';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/collection.js';import {Erc}from'../../queries/collection/types.js';import {getExchangeRate}from'../../queries/exchange-rate/index.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import {getOrderByHash}from'../../queries/order/index.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import'../../queries/order/types.js';import'../../queries/token/types.js';import {checkIsInsufficientBalance}from'../../services/balance/checkIsInsufficientBalance.js';import'../../configs/index.js';import {Token}from'../../services/tokens/data.js';import {getPaymentTokens,getPaymentToken}from'../../services/tokens/getPaymentTokens.js';import {getSwapConfig}from'../../services/tokens/configs.js';import {getTokensNeedToApprove}from'../../services/tokens/getTokensNeedToApprove.js';import'lodash';import {checkIsErc721OrderValid,checkIsErc1155OrderValid}from'../../services/order/checkIsOrderValid.js';import {convertAmountToUsd}from'../../utils/convertPrice.js';import {getSwappedAmount,getLiquidityProviderFee,getLiquidityProviderFeePercent,getPriceImpactPercent}from'../../services/order/getSwapTokenData.js';import {getSettlePrice,settleErc721Order,swapRONAndSettleErc721Order,swapTokensAndSettleErc721Order,settleErc1155Order,swapRONAndSettleErc1155Order,swapTokensAndSettleErc1155Order}from'../../services/order/settleOrder.js';const buyErc721Token = async (params) => {
|
|
2
|
+
const { order, selectedTokenAddress, chainId, wallet, deadline, refAddress = ZERO_ADDRESS, recipient, options } = params;
|
|
3
|
+
if (!order) {
|
|
4
|
+
throw new Error('Order not found');
|
|
5
|
+
}
|
|
6
|
+
const { paymentToken: listingToken, currentPrice } = order;
|
|
7
|
+
const { account } = wallet;
|
|
8
|
+
const tokens = getPaymentTokens(chainId);
|
|
9
|
+
const isBuyingWithListingToken = selectedTokenAddress.toLowerCase() === listingToken.toLowerCase();
|
|
10
|
+
const isBuyingWithRonToken = selectedTokenAddress.toLowerCase() === tokens[Token.RON].address.toLowerCase();
|
|
11
|
+
const settlePrice = await getSettlePrice(chainId, selectedTokenAddress, listingToken, currentPrice);
|
|
12
|
+
if (!settlePrice) {
|
|
13
|
+
throw new Error('Can not get settle price');
|
|
14
|
+
}
|
|
15
|
+
// Check order is valid
|
|
16
|
+
const isOrderValid = await checkIsErc721OrderValid(chainId, order);
|
|
17
|
+
if (!isOrderValid) {
|
|
18
|
+
throw new Error('Invalid order');
|
|
19
|
+
}
|
|
20
|
+
// Check all tokens is approved
|
|
21
|
+
const tokensNeedToApprove = await getTokensNeedToApprove(chainId, account, selectedTokenAddress, listingToken, settlePrice);
|
|
22
|
+
const isApprovedAllToken = tokensNeedToApprove.length === 0;
|
|
23
|
+
if (!isApprovedAllToken) {
|
|
24
|
+
const tokensNameNeedToApprove = tokensNeedToApprove.map(token => token.name);
|
|
25
|
+
throw new Error(`Tokens need to approve: ${JSON.stringify(tokensNameNeedToApprove)}`);
|
|
26
|
+
}
|
|
27
|
+
// Check insufficient balance
|
|
28
|
+
const isInsufficient = await checkIsInsufficientBalance(chainId, selectedTokenAddress, account, settlePrice);
|
|
29
|
+
if (isInsufficient) {
|
|
30
|
+
throw new Error('Insufficient balance');
|
|
31
|
+
}
|
|
32
|
+
// Settle order
|
|
33
|
+
if (isBuyingWithListingToken) {
|
|
34
|
+
return settleErc721Order(chainId, wallet, order, settlePrice, refAddress, recipient, options);
|
|
35
|
+
}
|
|
36
|
+
const swapConfig = getSwapConfig(chainId, listingToken);
|
|
37
|
+
const tokenPaths = swapConfig[selectedTokenAddress]?.path;
|
|
38
|
+
if (isBuyingWithRonToken) {
|
|
39
|
+
return swapRONAndSettleErc721Order(chainId, wallet, order, settlePrice, tokenPaths, deadline, refAddress, recipient, options);
|
|
40
|
+
}
|
|
41
|
+
return swapTokensAndSettleErc721Order(chainId, wallet, order, settlePrice, tokenPaths, deadline, refAddress, recipient, options);
|
|
42
|
+
};
|
|
43
|
+
const buyErc1155Token = async (params) => {
|
|
44
|
+
const { order, selectedTokenAddress, chainId, wallet, quantity, deadline, refAddress = ZERO_ADDRESS, recipient, options, } = params;
|
|
45
|
+
if (!order) {
|
|
46
|
+
throw new Error('Order not found');
|
|
47
|
+
}
|
|
48
|
+
const { paymentToken: listingToken, currentPrice } = order;
|
|
49
|
+
const { account } = wallet;
|
|
50
|
+
const totalPrice = BigNumber.from(currentPrice)
|
|
51
|
+
.mul(Number(quantity || 0))
|
|
52
|
+
.toString();
|
|
53
|
+
const tokens = getPaymentTokens(chainId);
|
|
54
|
+
const isBuyingWithListingToken = selectedTokenAddress.toLowerCase() === listingToken.toLowerCase();
|
|
55
|
+
const isBuyingWithRonToken = selectedTokenAddress.toLowerCase() === tokens[Token.RON].address.toLowerCase();
|
|
56
|
+
const settlePrice = await getSettlePrice(chainId, selectedTokenAddress, listingToken, totalPrice);
|
|
57
|
+
if (!settlePrice) {
|
|
58
|
+
throw new Error('Can not get settle price');
|
|
59
|
+
}
|
|
60
|
+
// Check order is valid
|
|
61
|
+
const isOrderValid = await checkIsErc1155OrderValid(chainId, order);
|
|
62
|
+
if (!isOrderValid) {
|
|
63
|
+
throw new Error('Invalid order');
|
|
64
|
+
}
|
|
65
|
+
// Check all tokens is approved
|
|
66
|
+
const tokensNeedToApprove = await getTokensNeedToApprove(chainId, account, selectedTokenAddress, listingToken, settlePrice);
|
|
67
|
+
const isApprovedAllToken = tokensNeedToApprove.length === 0;
|
|
68
|
+
if (!isApprovedAllToken) {
|
|
69
|
+
const tokensNameNeedToApprove = tokensNeedToApprove.map(token => token.name);
|
|
70
|
+
throw new Error(`Tokens need to approve: ${JSON.stringify(tokensNameNeedToApprove)}`);
|
|
71
|
+
}
|
|
72
|
+
// Check insufficient balance
|
|
73
|
+
const isInsufficient = await checkIsInsufficientBalance(chainId, selectedTokenAddress, account, settlePrice);
|
|
74
|
+
if (isInsufficient) {
|
|
75
|
+
throw new Error('Insufficient balance');
|
|
76
|
+
}
|
|
77
|
+
// Settle order
|
|
78
|
+
if (isBuyingWithListingToken) {
|
|
79
|
+
return settleErc1155Order(chainId, wallet, order, settlePrice, quantity, refAddress, recipient, options);
|
|
80
|
+
}
|
|
81
|
+
const swapConfig = getSwapConfig(chainId, listingToken);
|
|
82
|
+
const tokenPaths = swapConfig[selectedTokenAddress]?.path;
|
|
83
|
+
if (isBuyingWithRonToken) {
|
|
84
|
+
return swapRONAndSettleErc1155Order(chainId, wallet, order, settlePrice, tokenPaths, quantity, deadline, refAddress, recipient, options);
|
|
85
|
+
}
|
|
86
|
+
return swapTokensAndSettleErc1155Order(chainId, wallet, order, currentPrice, tokenPaths, quantity, deadline, refAddress, recipient, options);
|
|
87
|
+
};
|
|
88
|
+
const buyToken = async (params) => {
|
|
89
|
+
const { hash, ...otherParams } = params;
|
|
90
|
+
const order = await getOrderByHash({ hash, chainId: params.chainId });
|
|
91
|
+
if (!order) {
|
|
92
|
+
throw new Error('Order not found');
|
|
93
|
+
}
|
|
94
|
+
const ercType = order.assets?.[0]?.erc;
|
|
95
|
+
if (ercType === Erc.Erc721) {
|
|
96
|
+
return buyErc721Token({ ...otherParams, order });
|
|
97
|
+
}
|
|
98
|
+
return buyErc1155Token({ quantity: 1, ...otherParams, order });
|
|
99
|
+
};
|
|
100
|
+
const getSwapTokenData = async (params) => {
|
|
101
|
+
const { chainId, inputTokenAddress, outputTokenAddress, amount } = params;
|
|
102
|
+
const exchangeRate = await getExchangeRate({ chainId });
|
|
103
|
+
const inputTokenData = getPaymentToken(chainId, inputTokenAddress);
|
|
104
|
+
const outputTokenData = getPaymentToken(chainId, outputTokenAddress);
|
|
105
|
+
if (!inputTokenData) {
|
|
106
|
+
throw new Error('Input token address is invalid');
|
|
107
|
+
}
|
|
108
|
+
if (!outputTokenData) {
|
|
109
|
+
throw new Error('Output token address is invalid');
|
|
110
|
+
}
|
|
111
|
+
const swappedAmount = await getSwappedAmount(chainId, inputTokenAddress, outputTokenAddress, amount);
|
|
112
|
+
const fiatValueIn = convertAmountToUsd(Number(formatUnits(BigNumber.from(amount), inputTokenData.decimals)), inputTokenData.symbol, exchangeRate);
|
|
113
|
+
const fiatValueOut = convertAmountToUsd(Number(formatUnits(BigNumber.from(swappedAmount), outputTokenData.decimals)), inputTokenData?.symbol, exchangeRate);
|
|
114
|
+
const liquidityProviderFee = getLiquidityProviderFee(chainId, inputTokenAddress, outputTokenAddress, amount);
|
|
115
|
+
const liquidityProviderFeePercent = getLiquidityProviderFeePercent(chainId, inputTokenAddress, outputTokenAddress);
|
|
116
|
+
const priceImpactPercent = await getPriceImpactPercent(chainId, inputTokenAddress, outputTokenAddress, fiatValueIn, fiatValueOut);
|
|
117
|
+
const maximumSent = await getSettlePrice(chainId, inputTokenAddress, outputTokenAddress, amount);
|
|
118
|
+
return {
|
|
119
|
+
swappedAmount: swappedAmount?.toString(),
|
|
120
|
+
maximumSent,
|
|
121
|
+
liquidityProviderFee,
|
|
122
|
+
liquidityProviderFeePercent,
|
|
123
|
+
priceImpactPercent,
|
|
124
|
+
slippageTolerance: SWAP_DEFAULT_SLIPPAGE,
|
|
125
|
+
};
|
|
126
|
+
};export{buyErc1155Token,buyErc721Token,buyToken,getSwapTokenData};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import {BigNumber}from'ethers';import {createErc721Contract,createErc1155Contract}from'../../contracts/index.js';import {getTokenMetadata}from'../../queries/collection/index.js';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/exchange-rate.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import'../../queries/graphql/mutations/order.js';import'../../queries/graphql/queries/order.js';import'../../queries/token/types.js';import'../../queries/order/types.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import {Erc}from'../../queries/collection/types.js';const giftErc721Token = async (params) => {
|
|
2
|
+
const { tokenId, tokenAddress, receiverAddress, wallet, options } = params;
|
|
3
|
+
const { account, provider } = wallet;
|
|
4
|
+
const erc721Contract = createErc721Contract(tokenAddress, provider);
|
|
5
|
+
return erc721Contract?.['safeTransferFrom(address,address,uint256)'](account, receiverAddress, BigNumber.from(tokenId), { ...options });
|
|
6
|
+
};
|
|
7
|
+
const giftErc1155Token = async (params) => {
|
|
8
|
+
const { tokenId, tokenAddress, receiverAddress, quantity, wallet, options } = params;
|
|
9
|
+
const { account, provider } = wallet;
|
|
10
|
+
const erc1155Contract = createErc1155Contract(tokenAddress, provider);
|
|
11
|
+
return erc1155Contract?.safeTransferFrom(account, receiverAddress, BigNumber.from(tokenId), quantity, [], {
|
|
12
|
+
...options,
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
const giftToken = async (params) => {
|
|
16
|
+
const { chainId, ...otherParams } = params;
|
|
17
|
+
const tokenMetadata = await getTokenMetadata({
|
|
18
|
+
showAttributes: false,
|
|
19
|
+
chainId,
|
|
20
|
+
tokenAddress: otherParams.tokenAddress,
|
|
21
|
+
});
|
|
22
|
+
const { erc } = tokenMetadata;
|
|
23
|
+
if (erc === Erc.Erc721) {
|
|
24
|
+
return giftErc721Token(otherParams);
|
|
25
|
+
}
|
|
26
|
+
return giftErc1155Token({ quantity: 1, ...otherParams });
|
|
27
|
+
};export{giftErc1155Token,giftErc721Token,giftToken};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import {ZERO_ADDRESS}from'../../common/constants.js';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/collection.js';import'../../queries/collection/types.js';import'../../queries/graphql/queries/exchange-rate.js';import {getOffer}from'../../queries/offer/index.js';import'../../queries/graphql/mutations/order.js';import'../../queries/graphql/queries/order.js';import'../../queries/token/types.js';import'../../queries/order/types.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import'ethers';import'../../configs/index.js';import'../../services/tokens/data.js';import {checkIsErc721Approved}from'../../services/tokens/checkIsTokenApproved.js';import'lodash';import'ethers/lib/utils';import {settleErc721Order}from'../../services/order/settleOrder.js';const acceptOffer = async (params) => {
|
|
2
|
+
const { hash, wallet, chainId, refAddress = ZERO_ADDRESS, recipient, options } = params;
|
|
3
|
+
const { account } = wallet;
|
|
4
|
+
const offer = await getOffer({ hash, chainId });
|
|
5
|
+
if (!offer) {
|
|
6
|
+
throw new Error('Offer not found');
|
|
7
|
+
}
|
|
8
|
+
const { assets } = offer;
|
|
9
|
+
const tokenAddress = assets?.[0]?.token?.tokenAddress;
|
|
10
|
+
const isApproved = await checkIsErc721Approved(chainId, account, tokenAddress);
|
|
11
|
+
if (!isApproved) {
|
|
12
|
+
throw new Error('Token need to be approved');
|
|
13
|
+
}
|
|
14
|
+
return settleErc721Order(chainId, wallet, offer, '0', refAddress, recipient, options);
|
|
15
|
+
};export{acceptOffer};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import {cancelOrder}from'../order/cancelOrder.js';import'ethers';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/collection.js';import'../../queries/collection/types.js';import'../../queries/graphql/queries/exchange-rate.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import'../../queries/graphql/mutations/order.js';import'../../queries/graphql/queries/order.js';import'../../queries/token/types.js';import'../../queries/order/types.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import'../../configs/index.js';import'../../services/tokens/data.js';import'lodash';import'ethers/lib/utils';const cancelOffer = (params) => {
|
|
2
|
+
return cancelOrder(params);
|
|
3
|
+
};export{cancelOffer};
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import {BigNumber}from'ethers';import {MARKET_FEE_PERCENTAGE}from'../../common/constants.js';import'graphql-request';import'../../types/index.js';import'../../queries/graphql/queries/collection.js';import'../../queries/collection/types.js';import'../../queries/graphql/queries/exchange-rate.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import {requestCreateOrder}from'../../queries/order/index.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import {OrderType}from'../../queries/order/types.js';import'../../queries/token/types.js';import {checkIsInsufficientOfferBalance}from'../../services/balance/checkIsInsufficientBalance.js';import'../../configs/index.js';import {wRonToken}from'../../services/tokens/data.js';import {checkIsWRonTokenApproved}from'../../services/tokens/checkIsTokenApproved.js';import'lodash';import {generateInputOrder}from'../../services/order/generateOrderData.js';import {getNonce}from'../../services/order/getNonce.js';import {getErc721OrderSignature}from'../../services/order/getOrderSignature.js';import'ethers/lib/utils';import {ErcAssetItem,OrderKind}from'../../types/order.js';const getInputOrder = async (chainId, account, price, duration, expectedState, assets) => {
|
|
2
|
+
const wRonAddress = wRonToken[chainId].address;
|
|
3
|
+
const nonce = await getNonce(chainId, account);
|
|
4
|
+
return generateInputOrder({
|
|
5
|
+
price: BigNumber.from(price),
|
|
6
|
+
duration,
|
|
7
|
+
paymentToken: wRonAddress,
|
|
8
|
+
orderType: OrderType.Offer,
|
|
9
|
+
expectedState,
|
|
10
|
+
nonce,
|
|
11
|
+
maker: account,
|
|
12
|
+
assets,
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
const getOrderSignature = (chainId, wallet, price, duration, expectedState, assets) => {
|
|
16
|
+
const { account, signer } = wallet;
|
|
17
|
+
const wRonAddress = wRonToken[chainId].address;
|
|
18
|
+
const now = new Date().getTime();
|
|
19
|
+
const startedAt = Math.ceil(now / 1000);
|
|
20
|
+
const expiredAt = startedAt + duration;
|
|
21
|
+
const dataForSigning = {
|
|
22
|
+
maker: account,
|
|
23
|
+
kind: OrderKind.Offer,
|
|
24
|
+
assets,
|
|
25
|
+
expiredAt,
|
|
26
|
+
paymentToken: wRonAddress,
|
|
27
|
+
startedAt,
|
|
28
|
+
basePrice: price,
|
|
29
|
+
endedAt: 0,
|
|
30
|
+
endedPrice: '0',
|
|
31
|
+
expectedState,
|
|
32
|
+
nonce: 0,
|
|
33
|
+
marketFeePercentage: MARKET_FEE_PERCENTAGE,
|
|
34
|
+
};
|
|
35
|
+
return getErc721OrderSignature(chainId, signer, dataForSigning);
|
|
36
|
+
};
|
|
37
|
+
const makeOffer = async (params) => {
|
|
38
|
+
const { tokenId, tokenAddress, price, duration, chainId, wallet } = params;
|
|
39
|
+
const { account } = wallet;
|
|
40
|
+
const assets = [
|
|
41
|
+
{
|
|
42
|
+
id: tokenId,
|
|
43
|
+
addr: tokenAddress,
|
|
44
|
+
erc: ErcAssetItem.Erc721,
|
|
45
|
+
quantity: 0,
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
const isWRonApproved = checkIsWRonTokenApproved(chainId, account, price);
|
|
49
|
+
if (!isWRonApproved) {
|
|
50
|
+
throw new Error('WRon need to be approved');
|
|
51
|
+
}
|
|
52
|
+
const isInsufficient = await checkIsInsufficientOfferBalance(chainId, account, price);
|
|
53
|
+
if (isInsufficient) {
|
|
54
|
+
throw new Error('Insufficient balance');
|
|
55
|
+
}
|
|
56
|
+
const expectedState = '0';
|
|
57
|
+
const inputOrder = await getInputOrder(chainId, account, price, duration, expectedState, assets);
|
|
58
|
+
const signature = await getOrderSignature(chainId, wallet, price, duration, expectedState, assets);
|
|
59
|
+
if (!signature) {
|
|
60
|
+
throw new Error('Invalid signature');
|
|
61
|
+
}
|
|
62
|
+
return requestCreateOrder({ order: inputOrder, account, signature, chainId });
|
|
63
|
+
};export{makeOffer};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import'ethers';import'../../configs/index.js';import'../../services/tokens/data.js';import {createMarketGatewayContract,createErc1155MarketGatewayContract}from'../../contracts/market-gateway/factory.js';import'../../types/index.js';import'graphql-request';import'../../queries/graphql/queries/collection.js';import {Erc}from'../../queries/collection/types.js';import'../../queries/graphql/queries/exchange-rate.js';import'../../queries/graphql/queries/offer.js';import'../../queries/offer/types.js';import {getOrderByHash}from'../../queries/order/index.js';import'../../queries/graphql/mutations/metadata.js';import'../../queries/graphql/queries/token.js';import'../../queries/order/types.js';import'../../queries/token/types.js';import'lodash';import {generateErc721Order,generateErc1155Order}from'../../services/order/generateOrderData.js';import'ethers/lib/utils';const cancelErc721Order = async (params) => {
|
|
2
|
+
const { chainId, wallet, order, options } = params;
|
|
3
|
+
const { provider } = wallet;
|
|
4
|
+
if (!order) {
|
|
5
|
+
throw new Error('Order not found');
|
|
6
|
+
}
|
|
7
|
+
const marketGatewayContract = createMarketGatewayContract(chainId, provider);
|
|
8
|
+
const erc721Order = generateErc721Order(order);
|
|
9
|
+
return marketGatewayContract.cancelOrder(erc721Order, options);
|
|
10
|
+
};
|
|
11
|
+
const cancelErc1155Order = async (params) => {
|
|
12
|
+
const { chainId, wallet, order, options } = params;
|
|
13
|
+
const { provider } = wallet;
|
|
14
|
+
if (!order) {
|
|
15
|
+
throw new Error('Order not found');
|
|
16
|
+
}
|
|
17
|
+
const erc1155MarketGatewayContract = createErc1155MarketGatewayContract(chainId, provider);
|
|
18
|
+
const erc1155Order = generateErc1155Order(order);
|
|
19
|
+
return erc1155MarketGatewayContract.cancelErc1155Order(erc1155Order, options);
|
|
20
|
+
};
|
|
21
|
+
const cancelOrder = async (params) => {
|
|
22
|
+
const { hash, ...otherParams } = params;
|
|
23
|
+
const order = await getOrderByHash({ hash, chainId: params.chainId });
|
|
24
|
+
if (!order) {
|
|
25
|
+
throw new Error('Order not found');
|
|
26
|
+
}
|
|
27
|
+
const ercType = order.assets?.[0]?.erc;
|
|
28
|
+
if (ercType === Erc.Erc721) {
|
|
29
|
+
return cancelErc721Order({ ...otherParams, order });
|
|
30
|
+
}
|
|
31
|
+
return cancelErc1155Order({ ...otherParams, order });
|
|
32
|
+
};export{cancelErc1155Order,cancelErc721Order,cancelOrder};
|