import { View, Text, Button } from 'react-native';
import { useParaCosmos } from './hooks/useParaCosmos';
import { SigningStargateClient, coins } from '@cosmjs/stargate';
import { MsgTransfer } from 'cosmjs-types/ibc/applications/transfer/v1/tx';
import { Height } from 'cosmjs-types/ibc/core/client/v1/client';
const RPC_URL = 'https://rpc.cosmos.directory/cosmoshub';
function IBCTransfer() {
const { protoSigner, address, isLoading } = useParaCosmos();
const sendIBCTransfer = async () => {
if (!protoSigner || !address) return;
const client = await SigningStargateClient.connectWithSigner(RPC_URL, protoSigner);
const currentHeight = await client.getHeight();
const timeoutHeight = Height.fromPartial({
revisionNumber: 1n,
revisionHeight: BigInt(currentHeight + 1000),
});
const msgTransfer = {
typeUrl: '/ibc.applications.transfer.v1.MsgTransfer',
value: MsgTransfer.fromPartial({
sourcePort: 'transfer',
sourceChannel: 'channel-141',
token: {
denom: 'uatom',
amount: '1000000',
},
sender: address,
receiver: 'osmo1...',
timeoutHeight: timeoutHeight,
timeoutTimestamp: 0n,
}),
};
const fee = {
amount: coins(5000, 'uatom'),
gas: '250000',
};
try {
const result = await client.signAndBroadcast(
address,
[msgTransfer],
fee,
'IBC transfer via Para'
);
console.log('IBC transfer initiated:', result.transactionHash);
} catch (error) {
console.error('IBC transfer failed:', error);
}
};
if (isLoading) return <Text>Loading...</Text>;
return (
<View>
<Text>From: {address}</Text>
<Button title="Send 1 ATOM to Osmosis" onPress={sendIBCTransfer} />
</View>
);
}