yarn add @pngfi/react-hooks
// or
npm i @pngfi/react-hooks --save
import { PngfiProvider } from '@pngfi/react-hooks';
const App = ({ children }) => {
const wallet = useWallet();
return (
<PngfiProvider
cluster="mainnet-beta"
userPublicKey={wallet.publicKey}
>
{/* You can use useBonding in children now */}
{children}
</PngfiProvider>
)
}
import { usePngfiConfig } from '@pngfi/react-hooks';
const {
fallback: {
cluster,
pngfiApi,
userPublicKey
//...
}
//...
} = usePngfiConfig()
import { useAnchorProvider } from '@pngfi/react-hooks';
const provider = useAnchorProvider({
connection,
wallet,
connected
});
import { useDistributors } from '@pngfi/react-hooks';
const { data, error, loading } = useDistributors(user: string);
import { useMerkleRewards } from '@pngfi/react-hooks';
const { data, error, loading } = useMerkleRewards(user: string);
import { useDistributorEpochs } from '@pngfi/react-hooks';
const { data, error, loading } = useDistributorEpochs(distributor: string);
import { useMerkleRewardsDistributor } from '@pngfi/react-hooks';
const { data, error, loading } = useMerkleRewardsDistributor(distributor: string);
import { useDistributorRewardsEpoch } from '@pngfi/react-hooks';
const { data, error, loading } = useDistributorRewardsEpoch(distributor: string, epoch: string);
import { useTokens } from '@pngfi/react-hooks';
const { data, error, loading } = useTokens();
import { usePools } from '@pngfi/react-hooks';
const { data, error, loading } = usePools();
import { useMarkets } from '@pngfi/react-hooks';
const { data, error, loading } = useMarkets();
import { usePrices } from '@pngfi/react-hooks';
const { data, error, loading } = usePrices(['SOL', 'UST']);
import { useBonding } from '@pngfi/react-hooks';
const { data, error, loading } = useBonding();
import { useStaking } from '@pngfi/react-hooks';
const { data, error, loading } = useStaking();
import { useBalances } from '@pngfi/react-hooks';
const { data, error, loading } = useBalances(user);
import { useUserVesting } from '@pngfi/react-hooks';
const { data, error, loading } = useUserVesting(owner, vestConfig);
useMerkleRewards
to get rewardsimport {
useMerkleRewards
} from "@pngfi/react-hooks";
const { publicKey: userPublicKey } = useWallet();
const { data = [] } = useMerkleRewards(userPublicKey.toString());
claimRewards
to claim rewardsimport {
useConnection, useWallet
} from '@solana/wallet-adapter-react';
import {
useAnchorProvider,
useRewards
} from "@pngfi/react-hooks";
const { connection } = useConnection();
const { wallet, connected } = useWallet();
const { claimRewards } = useRewards();
const provider = useAnchorProvider({
connection,
wallet,
connected
});
const { publicKey: userPublicKey } = useWallet();
const onClaim = async (data) => {
try {
const claimTx = await claimRewards(provider, userPublicKey, {
distributor: data.distributor,
amount: data.amount.toString(),
claimAddress: data.claimAddress || '',
proof: data.proof,
mint: data.mint,
index: data.index,
});
console.log('claimTx', claimTx);
const { signature } = await claimTx.confirm();
console.log('claimTx result', signature);
} catch (e) {
console.log('e', e);
}
}
// ...
onClaim(item) // item of useMerkleRewards data
insertDistributor
to insert distributorimport { useConnection, useWallet } from '@solana/wallet-adapter-react';
import { useAnchorProvider, useRewards, useTokenByMint, signAuth, ISignMessage } from '@pngfi/react-hooks';
import { Keypair } from '@solana/web3.js';
const { publicKey, wallet, connected, signMessage } = useWallet();
const { connection } = useConnection();
const provider = useAnchorProvider({ connection, wallet, connected });
const { insertDistributor, confirmInsertDistributor } = useRewards();
const token = useTokenByMint(tokenMint);
const { txe, distributor } = await insertDistributor({
provider,
base: Keypair.generate().publicKey.toString(),
adminAuth: publicKey.toString(),
data: {
"title": title,
token,
"rewards": distributors.map(v => {
return {
dest: v.distributor,
amount: v.amount
}
})
}
});
txe.confirm
to confirm sendTransactionconst { signature, response } = await txe.confirm();
confirmInsertDistributor
to update distributor status.await confirmInsertDistributor({
distributor: distributor.distributor,
status: 'SUCCESS', // 'CANCEL', 'ERROR'
}, {
'X-PNG-SIGNATURE': await signAuth(signMessage, ISignMessage.confirmDistributor),
'X-PNG-ADDRESS': publicKey.toString()
});
useDistributors
to get distributorsimport { useWallet } from '@solana/wallet-adapter-react';
import { useDistributors } from '@pngfi/react-hooks';
const { publicKey } = useWallet();
const { data, loading, error } = await useDistributors(publicKey.toString());
useDistributor
to get distributorimport { useDistributor } from '@pngfi/react-hooks';
const { data, loading, error } = await useDistributor(distributorAddress);
updateDistributor
to update distributorimport { useConnection, useWallet } from '@solana/wallet-adapter-react';
import { useAnchorProvider, useRewards, useTokenByMint, signAuth } from '@pngfi/react-hooks';
const { publicKey, wallet, connected, signMessage, ISignMessage } = useWallet();
const { connection } = useConnection();
const provider = useAnchorProvider({ connection, wallet, connected });
const { updateDistributor, confirmUpdateDistributor } = useRewards();
const distributor = useDistributor(address);
const token = useTokenByMint(distributor.tokenMint);
const { txe, distributor } = await updateDistributor({
provider,
distributor: distributor.address,
adminAuth: String(publicKey),
data: {
"title": title,
token,
"rewards": distributors.map(v => {
return {
dest: v.distributor,
amount: v.amount
}
})
}
});
txe.confirm
to confirm sendTransactionconst { signature, response } = await txe.confirm();
confirmUpdateDistributor
to update distributor status.await confirmUpdateDistributor({
distributor: distributor.distributor,
previousEpochID: distributor.epochID,
status: 'SUCCESS', // 'CANCEL', 'ERROR'
}, {
'X-PNG-SIGNATURE': await signAuth(signMessage, ISignMessage.confirmDistributor),
'X-PNG-ADDRESS': String(publicKey)
});
deleteDistributor
to delete distributorimport { useWallet } from '@solana/wallet-adapter-react';
import { useRewards, signAuth, ISignMessage } from '@pngfi/react-hooks';
const { publicKey, signMessage } = useWallet();
const { deleteDistributor } = useRewards();
const result = await deleteDistributor((distributor.address, {
'X-PNG-SIGNATURE': await signAuth(signMessage, ISignMessage.confirmDistributor),
'X-PNG-ADDRESS': String(publicKey)
}));
useBond
to get bond infoimport {
useConnection, useWallet
} from '@solana/wallet-adapter-react';
import {
useAnchorProvider,
useBond
} from "@pngfi/react-hooks";
const [bondingItemData, setBondingItemData] = useState({} as any);
const { connection } = useConnection();
const { wallet, connected } = useWallet();
const provider = useAnchorProvider({
connection,
wallet,
connected
});
const {
bondingTotalValue,
getBondingItemData,
onBond
} = await useBond(provider);
useEffect(() => {
async function fetchData() {
const data = await getBondingItemData(pubkey);
setBondingItemData(data);
}
fetchData();
}, [getBondingItemData, pubkey]);
const {
bondingModel,
stakingModel,
bondingInfo // IBondingInfoWithTokens,
payoutHolderBalance,
assetTokens,
} = bondingItemData;
const { publicKey: ownerAccount } = useWallet();
const res = onBond({
ownerAccount,
bondingInfo,
bondingModel,
stakingModel,
depositToken,
amount,
execute: (opTx, amount, token, isSwap) => {
// const { signature } = await opTx.confirm();
},
swap: () => {
// const { execute } = await jupAg.exchange({
// routeInfo: routes[0]
// });
// const swapResult = await execute({
// wallet: {
// sendTransaction,
// publicKey,
// signAllTransactions,
// signTransaction
// }
// });
},
userVestingInfo,
});
useStake
to get stake infoimport {
useConnection, useWallet
} from '@solana/wallet-adapter-react';
import {
useAnchorProvider,
useStake
} from "@pngfi/react-hooks";
const { connection } = useConnection();
const { publicKey, wallet, connected } = useWallet();
const provider = useAnchorProvider({
connection,
wallet,
connected
});
const {
stakingTotalValue,
getStakingItemData,
onStake,
onUnStake
} = useStake(provider);
const {
stakingInfo,
stakingModel,
// ...
} = getStakingItemData();
// stake
const [toVTokenTx, stakeAllTx, rebaseTx] = await onStake({
stakingInfo,
stakingModel,
amount,
});
const { signature } = await toVTokenTx
.combine(stakeAllTx)
.combine(rebaseTx)
.confirm();
// unstake
const [unstakeTx, vestAllTx, rebaseTx] = await onUnStake({
stakingInfo,
stakingModel,
amount,
});
const { signature } = await unstakeTx
.combine(vestAllTx)
.combine(rebaseTx)
.confirm();
Generated using TypeDoc