> ## Documentation Index
> Fetch the complete documentation index at: https://docs.getpara.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Send Tokens with Stellar Libraries

> Transfer XLM using the Stellar SDK with Para wallets in React Native

export const Card = ({imgUrl, title, description, href, horizontal = false, newTab = false}) => {
  const [isHovered, setIsHovered] = useState(false);
  const handleClick = e => {
    e.preventDefault();
    if (newTab) {
      window.open(href, '_blank', 'noopener,noreferrer');
    } else {
      window.location.href = href;
    }
  };
  return <div className={`not-prose relative my-2 p-[1px] rounded-xl transition-all duration-300 ${isHovered ? 'bg-gradient-to-r from-[#FF4E00] to-[#874AE3]' : 'bg-gray-200'}`} onMouseEnter={() => setIsHovered(true)} onMouseLeave={() => setIsHovered(false)}>
      <a href={href} onClick={handleClick} className={`not-prose flex ${horizontal ? 'flex-row' : 'flex-col'} font-normal h-full bg-white overflow-hidden w-full cursor-pointer rounded-[11px] no-underline`}>
        {imgUrl && <div className={`relative overflow-hidden flex-shrink-0 ${horizontal ? 'w-[30%] rounded-l-[11px]' : 'w-full'}`} onClick={e => e.stopPropagation()}>
            <img src={imgUrl} alt={title} className="w-full h-full object-cover pointer-events-none select-none" draggable="false" />
            <div className="absolute inset-0 pointer-events-none" />
          </div>}
        <div className={`flex-grow px-6 py-5 ${horizontal ? 'w-[70%]' : 'w-full'} flex flex-col ${horizontal && imgUrl ? 'justify-center' : 'justify-start'}`}>
          {title && <h2 className="font-semibold text-base text-gray-800 m-0">{title}</h2>}
          {description && <div className={`font-normal text-gray-500 re leading-6 ${horizontal || !imgUrl ? 'mt-0' : 'mt-1'}`}>
              <p className="m-0 text-xs">{description}</p>
            </div>}
        </div>
      </a>
    </div>;
};

Transfer XLM tokens between wallets using Para's Stellar signer with the Stellar SDK.

<Card title="Setup Stellar Libraries First" description="You must complete the Stellar library setup before sending tokens" href="/v2/react-native/guides/web3-operations/stellar/setup-libraries" horizontal />

## Send XLM

```typescript theme={null}
import { useParaStellarSigner } from "@getpara/react-native-wallet/stellar";
import { TransactionBuilder, Operation, Asset, BASE_FEE, Horizon, Networks } from "@stellar/stellar-sdk";
import { View, Text, Button } from "react-native";

const server = new Horizon.Server("https://horizon.stellar.org");

function SendXLM() {
  const { stellarSigner, isLoading } = useParaStellarSigner({
    networkPassphrase: Networks.PUBLIC,
  });

  const sendPayment = async (recipient: string, amount: string) => {
    if (!stellarSigner) {
      console.error("No signer available. Connect wallet first.");
      return;
    }

    // Load the sender's account from the network
    const sourceAccount = await server.loadAccount(stellarSigner.address);

    // Build the payment transaction
    const transaction = new TransactionBuilder(sourceAccount, {
      fee: BASE_FEE,
      networkPassphrase: Networks.PUBLIC,
    })
      .addOperation(
        Operation.payment({
          destination: recipient,
          asset: Asset.native(),
          amount, // e.g. "10" for 10 XLM
        })
      )
      .setTimeout(180)
      .build();

    // Sign the transaction with Para
    const { signedTxXdr } = await stellarSigner.signTransaction(transaction.toXDR());

    // Submit to the network
    const tx = TransactionBuilder.fromXDR(signedTxXdr, Networks.PUBLIC);
    const result = await server.submitTransaction(tx);
    console.log("Transaction hash:", result.hash);

    return result;
  };

  if (isLoading) return <Text>Loading...</Text>;

  return (
    <View>
      <Text>Address: {stellarSigner?.address}</Text>
      <Button title="Send 10 XLM" onPress={() => sendPayment("GRECIPI...", "10")} />
    </View>
  );
}
```

## Send Custom Assets

To send a custom asset (like USDC on Stellar), replace `Asset.native()` with the specific asset:

```typescript theme={null}
import { Asset } from "@stellar/stellar-sdk";

// Example: USDC on Stellar
const usdc = new Asset(
  "USDC",
  "GA5ZSEJYB37JRC5AVCIA5MOP4RHTM335X2KGX3IHOJAPP5RE34K4KZVN"
);

// Use in your payment operation
Operation.payment({
  destination: recipient,
  asset: usdc,
  amount: "100", // 100 USDC
});
```

<Note>
  The recipient must have a trustline for the custom asset before they can receive it. See [Execute Transactions](/v2/react-native/guides/web3-operations/stellar/execute-transactions) for how to create trustlines.
</Note>

## Next Steps

<CardGroup cols={3}>
  <Card title="Execute Transactions" description="Build complex multi-operation transactions" href="/v2/react-native/guides/web3-operations/stellar/execute-transactions" icon="bolt" />

  <Card title="Sign Messages" description="Sign arbitrary bytes for verification" href="/v2/react-native/guides/web3-operations/stellar/sign-messages" icon="signature" />

  <Card title="Verify Signatures" description="Verify Ed25519 signatures" href="/v2/react-native/guides/web3-operations/stellar/verify-signatures" icon="shield-check" />
</CardGroup>
