Integrar Freighter con una dapp de React
Las billeteras son una parte esencial de cualquier dapp. Permiten a los usuarios interactuar con la blockchain y firmar transacciones. En esta sección, aprenderás cómo integrar la billetera Freighter en tus dapps de React.
Componente WalletData
En la dapp de crowdfund de ejemplo, el componente WalletData
juega un papel clave en la integración de la billetera. Desglosaremos el código y entenderemos su funcionalidad:
import React from "react";
import { useAccount, useIsMounted } from "../../../hooks";
import { ConnectButton } from "../../atoms";
import styles from "./style.module.css";
export function WalletData() {
const mounted = useIsMounted();
const account = useAccount();
return (
<>
{mounted && account ? (
<div className={styles.displayData}>
<div className={styles.card}>{account.displayName}</div>
</div>
) : (
<ConnectButton label="Connect Wallet" />
)}
</>
);
}
Aquí tienes un desglose del código:
- La variable
mounted
se obtiene usando eluseIsMounted
hook, indicando si el componente está actualmente montado o no. - El
useAccount
hook se utiliza para obtener los datos de la cuenta del usuario, y la propiedaddata
se desestructura del resultado. - Se utiliza renderización condicional para mostrar contenido diferente según el estado de montaje del componente y la disponibilidad de datos de cuenta.
- Si el componente está montado y los datos de la cuenta están disponibles, se muestra la información de la billetera del usuario. Esto incluye el nombre de usuario de la cuenta.
- Si el componente no está montado o los datos de la cuenta no están disponibles, se renderiza un componente
ConnectButton
, permitiendo al usuario conectarse con Freighter.
Guías en esta categoría:
📄️ Conectar a la Testnet
Crear una cuenta Stellar en Testnet con Freighter
📄️ Habilitar tokens Soroban
Añadir tokens de contrato inteligente a tu billetera Freighter
📄️ Integrar Freighter con una dapp de React
Integrar la billetera Freighter en tus dapps de React
📄️ Indicar a Freighter que firme transacciones como desarrollador de dapp JS
Firmar transacciones de contratos inteligentes utilizando la extensión del navegador Freighter
📄️ Enviar pagos de tokens Soroban
Enviar un pago de token de contrato inteligente directamente desde Freighter
📄️ Firmar entradas de autorización
Usa la API de Freighter para firmar una entrada de autorización
📄️ Firmar Soroban XDRs
Firmar XDRs de contratos inteligentes utilizando dapps integradas con Freighter