Skip to main content

TON Connect Integration

This document provides information on how to integrate the TON Connect for UXUY Wallet.

Ton Connect SDk

TonConnect is an open protocol that connects wallets and DApps (Web3 applications). It uses a bridge (JS Bridge or Http Bridge) to establish a connection between two applications and/or devices and starts communication. Uxuy Wallet fully supports TonConnect.

TonConnect SDK Packages and UXUY Wallet Integration Demo

ton docs:

sdk packages:

UXUY Wallet integration demo:

UXUY Wallet Integration

To integrate the TonConnect SDK into the Uxuy Wallet, follow the steps below:

Step 1: Install the TonConnect SDK package and initialize :

use @tonconnect/ui

npm install @tonconnect/ui 

use @tonconnect/ui-react

npm install @tonconnect/ui-react 

Step 2: Initialize the TonClient and TonConnect objects:

manifestUrl is the URL of the manifest file that contains information about the DApp. manifest

walletsListConfiguration.includeWallets can be used to add custom wallets to the list of supported wallets.

restoreConnection is a boolean value that determines whether the TonConnect SDK should attempt to restore an existing connection with the DApp.

UXUY Wallet walletsListConfiguration.includeWallets configuration:

Add the following configuration to the walletsListConfiguration.includeWallets array in the TonConnectUI constructor:

 
{
"name": "UXUY Wallet",
"appName": "uxuyTonWallet",

"universalLink": "https://t.me/UXUYbot/app",
"bridgeUrl": "https://bridge.tonapi.io/bridge",
"imageUrl": "https://raw.githubusercontent.com/uxuycom/uxuy-docsite/main/static/assets/UXUYWallet-logo/UXUYWallet_logo_circle.svg",
"platforms": ["android", "ios", "linux", "windows", "macos"],
},

use @tonconnect/ui

    import { TonConnectUI  } from '@tonconnect/ui'

const tonConnectUI = new TonConnectUI({

restoreConnection: true,
walletsListConfiguration: {
//custom wallets list configuration here
includeWallets: [
{

name: "UXUY Wallet",
appName: "uxuyTonWallet",

// we will support tonconnect-v2 in the future
// jsBridgeKey: "uxuyTonWallet",
aboutUrl: "https://uxuy.com",
universalLink: "https://t.me/UXUYbot/app",
bridgeUrl: "https://bridge.tonapi.io/bridge",
imageUrl: "https://raw.githubusercontent.com/uxuycom/uxuy-docsite/main/static/assets/UXUYWallet-logo/UXUYWallet_logo_circle.svg",
platforms: ["android", "ios", "linux", "windows", "macos"],
}

]
},

manifestUrl: "<Your manifest url>",
// manifestUrl: "https://raw.githubusercontent.com/uxuySafe/examples/bb930d695232f2a9d900dfe69f429604dc00bbea/examples/tonconnect-v2/public/tonconnect-manifest.json",
})

use @tonconnect/ui-react

import { TonConnectUIProvider } from '@tonconnect/ui-react';

<TonConnectUIProvider
// manifestUrl={`https://raw.githubusercontent.com/uxuySafe/examples/bb930d695232f2a9d900dfe69f429604dc00bbea/examples/tonconnect-v2/public/tonconnect-manifest.json`}
manifestUrl={`<Your manifest url>`}
walletsListConfiguration={{
includeWallets: [
{
name: "UXUY Wallet",
appName: "uxuyTonWallet",

// we will support tonconnect-v2 in the future
// jsBridgeKey: "uxuyTonWallet",
aboutUrl: "https://uxuy.com",
universalLink: "https://t.me/UXUYbot/app",
bridgeUrl: "https://bridge.tonapi.io/bridge",
imageUrl: "https://raw.githubusercontent.com/uxuycom/uxuy-docsite/main/static/assets/UXUYWallet-logo/UXUYWallet_logo_circle.svg",
platforms: ["android", "ios", "linux", "windows", "macos"],
}
]
}}>
<App/>
</TonConnectUIProvider>

Step 3: Add the TonConnect UI button to the UI of the DApp:

use @tonconnect/ui


// open Single Wallet Modal:
<button onClick={() => tonConnectUI.openSingleWalletModal("uxuyTonWallet")}
>Connect to UXUY Wallet</button>

// open Multi Wallet Modal:
<button onClick={async () => { tonConnectUI.openModal() }}>openModal</button>


// get current wallet info:
const unsubscribe = tonConnectUI.onStatusChange(
walletInfo => {
console.log("onStatusChange", { walletInfo });

});
// remove listener
// unsubscribe()

use @tonconnect/ui-react

    import { TonConnectButton, useTonAddress, useTonWallet, Locales, useTonConnectUI, useTonConnectModal,  } from "@tonconnect/ui-react"


function App() {
const [tonConnectUI] = useTonConnectUI();

return <>

{/* open Single Wallet Modal: */}
<button onClick={() => tonConnectUI.openSingleWalletModal("uxuyTonWallet")}>Connect to UXUY Wallet<button>

{/* open Multi Wallet Modal: */}
<TonConnectButton> Connect to TON UI </TonConnectButton>


</>
}


{/* // get account address : */}
const AddressInfo = () => {
const userFriendlyAddress = useTonAddress();
const rawAddress = useTonAddress(false);

return (
rawAddress && (
<div>
<span>User-friendly address: {userFriendlyAddress}</span>
<span>Raw address: {rawAddress}</span>
</div>
)
);
};

Step 4: sign and send transactions using TonConnect SDK:

use @tonconnect/ui


<button onClick={
async () => {
const transaction = {
validUntil: Math.floor(Date.now() / 1000) + 60, // 60 sec
messages: [
{
address: "UQA_ofPvh6hDWmGGIC9ZTaULpC18HxSEDSyuRxZSH4z3mDJk",
amount: "100000",
},
{
address: "UQA_ofPvh6hDWmGGIC9ZTaULpC18HxSEDSyuRxZSH4z3mDJk",
amount: "600000",

}
]
}
const result = await tonConnectUI.sendTransaction(transaction);
}
}>
sendTransaction
</button>

use @tonconnect/ui-react


const [tonConnectUI] = useTonConnectUI();

async function sendTon() {
const myTransaction = {
validUntil: Math.floor(Date.now() / 1000) + 60, // 60 sec
messages: [
{
address: "UQCiLpPEi53uFdA4r3fNSZc_XMBJrtG24B4nzL7dPhQ3nytp",
amount: "1",
// stateInit: "base64bocblahblahblah==" // just for instance. Replace with your transaction initState or remove
},
{
address: "UQAvIWV8KxUsqWk5k639PLID_9NlaiVSqGbVcc-IdKPZOrjc",
amount: "600000",
// payload: "base64bocblahblahblah==" // just for instance. Replace with your transaction payload or remove
}
]
}
const result = await tonConnectUI.sendTransaction(myTransaction)
return result
}