A comprehensive tutorial demonstrating cross-chain token swaps with NEAR Intents using 1-Click API. This project provides step-by-step examples for performing seamless token swaps between different blockchains.
- Cross-Chain Token Swaps: Swap tokens between NEAR, Ethereum, Arbitrum, and other supported chains
- Step-by-Step Tutorial: Each example focuses on a specific part of the swap process
- Complete Integration: Full end-to-end swap implementation
- Real-Time Monitoring: Track swap progress with status polling
- pnpm >= 8
- Node.js >=16
- TypeScript
- NEAR account with sufficient balance (~0.05 $NEAR)
- 1-Click SDK JWT token -> Request here (Optional)
- (Although a JWT is not required, not using one will incur 0.1% fee on all swaps)
 
- 
Clone and Install git clone https://github.com/near-examples/near-intents-examples cd near-intents-examples pnpm install
- 
Environment Setup Create a .envfile with your private credentials (see .env.example):SENDER_NEAR_ACCOUNT=your-account.near SENDER_PRIVATE_KEY=your_near_private_key ONE_CLICK_JWT=your_json_web_token 
- 
Configure Swap Swap quotes can be configured and executed independently in both 2-get-quote.ts & 5-full-swap.ts: // Example Swap Configuration const isTest = true; // set to true for quote estimation / testing, false for actual execution const senderAddress = process.env.SENDER_NEAR_ACCOUNT as string; // Configure in .env const recipientAddress = '0x553e771500f2d7529079918F93d86C0a845B540b'; // Token swap recipient address on Arbitrum const originAsset = "nep141:wrap.near"; // Native $NEAR const destinationAsset = "nep141:arb-0x912ce59144191c1204e64559fe8253a0e49e6548.omft.near"; // Native $ARB const amount = "100000000000000000000000"; // 0.1 $NEAR 
- Quote Generation: Get token swap pricing quote with a depositAddress
- Token Deposit: If you approve the quote, send agreed upon token amount to the depositAddress
- Intent Execution: 1Click executes swap on specified chain(s) w/ NEAR Intents
Open each file before executing it using the guide below. Each file has detailed comments that further educates you about each step. Some files also have configuration options for you to alter and experiment with.
pnpm getTokensRuns logic found in 1-get-tokens.ts:
- Fetches all supported tokens across different blockchains
- No authentication required
- Displays tokens organized by blockchain
- Use assetIdfor swap quote configuration
pnpm getQuoteRuns logic found in 2-get-quote.ts:
- Retrieves swap quotes with pricing and fees
- Generates unique deposit addresses
- Calculates expected output amounts
pnpm sendDepositRuns logic found in 3-send-deposit.ts:
- Sends $NEAR tokens to the generated deposit address
- Initiates the cross-chain swap process
- Returns transaction hash for tracking
pnpm checkStatusRuns logic found in 4-check-status.ts:
- Monitors swap execution status
- Tracks progress through different stages
- Shows completion confirmation
pnpm fullSwapRuns logic found in 5-full-swap.ts:
- Combines steps 2-4 into one seamless process
- Automatic status monitoring until completion
- (NOTE: Configure swap options in 5-full-swap.tsindependently of other files)
1click-example/
├── 1-get-tokens.ts      # Fetch supported networks and tokens
├── 2-get-quote.ts       # Get swap quotes
├── 3-send-deposit.ts    # Send deposit transaction
├── 4-check.status.ts    # Monitor swap status
├── 5-full-swap.ts       # Execute complete swap flow
├── near.ts              # NEAR account utilities
└── utils.ts             # Helper functions for formatting `getTokens` response
- @defuse-protocol/one-click-sdk-typescript: Official 1-Click SDK
- @near-js/*: NEAR blockchain interaction
- dotenv: Environment variable management
- TypeScript: Type-safe development
The system tracks swaps through these stages:
- PENDING_DEPOSIT: Waiting for deposit confirmation
- KNOWN_DEPOSIT_TX: Deposit transaction detected
- PROCESSING: Swap being executed
- SUCCESS: Swap completed successfully
- REFUNDED: Swap failed, tokens refunded
Contributions are welcome! Please feel free to submit issues and enhancement requests.
This project is provided as educational examples for the 1-Click SDK and NEAR Intents ecosystem.