@lyncworld/fuel-marketplace
Version:
Marketplace NPM SDK on Fuel blockchain. Powered by LYNC, it allows anyone to create their own decentralized marketplace which includes listing and buying of Non-fungible tokens (NFTs) and Semi-fungible tokens (SFTs) in a few lines of code.
41 lines (34 loc) • 1.1 kB
text/typescript
import { useCallback, useEffect, useState } from 'react';
import { HooksReturn, MarketplaceListings, HooksArgs } from '@/interfaces';
import { getListings } from '@/ssr';
export const useListings = ({ network, limit }: HooksArgs): Readonly<HooksReturn<MarketplaceListings[]>> => {
const [fetching, setFetching] = useState<boolean>(true);
const [data, setData] = useState<MarketplaceListings[]>([]);
const [error, setError] = useState<unknown>(null);
const fetchData = useCallback(async () => {
setFetching(true);
setError(null);
try {
const listings = await getListings({
network,
limit,
});
if (listings.success) {
setError(null);
setData(listings.data);
} else {
setError(listings.error);
setData([]);
}
} catch (error: unknown) {
setError(error);
setData([]);
} finally {
setFetching(false);
}
}, [network, limit]);
useEffect(() => {
fetchData();
}, [fetchData]);
return { fetching, data, error } as const satisfies HooksReturn<MarketplaceListings[]>;
};