1.2.1 • Published 12 months ago

@mytonswap/widget v1.2.1

Weekly downloads
-
License
MIT
Repository
github
Last release
12 months ago

MyTonSwap Widget

@mytonswap/widget is a customizable Swap component that enables developers to integrate swap functionality on the TON blockchain directly into their React applications. With this widget, users can seamlessly swap assets and connect to the TON blockchain via TonConnect.

Preview

Features

  • Swap Functionality: Easily swap assets on the TON blockchain.
  • TonConnect Integration: Connect to the TON blockchain through TonConnect for secure and convenient user authentication.
  • Easy Integration: Add and configure the widget in your React project effortlessly.
  • Responsive Design: The widget is optimized for different devices and screen sizes.
  • Customizable: Adapt the widget’s appearance to match your application’s style.

Installation

Install the widget using npm or yarn:

# Using npm
npm install @mytonswap/widget

# Using yarn
yarn add @mytonswap/widget

Usage

After installation, you can integrate the @mytonswap/widget components in your React app as follows:

Swap Component

import "./App.css";
import { useEffect } from "react";
import { createSwap } from "@mytonswap/widget";
import { useTonConnectUI } from "@tonconnect/ui-react";

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if (tc) {
            createSwap("swap-component", { tonConnectInstance: tc });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="swap-component"></div>
        </div>
    );
}

export default App;

Wallet Button

import "./App.css";
import { useEffect } from "react";
import { createWalletProfile } from "@mytonswap/widget";
import { useTonConnectUI } from "@tonconnect/ui-react";

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if (tc) {
            createWalletProfile("wallet-button", {
                tonConnectInstance: tc,
                position: "bottom-right",
            });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="wallet-button"></div>
        </div>
    );
}

export default App;

Theme & Customization

You can fully customize the appearance of the @mytonswap/widget by passing a theme object as a property to the createSwap function. This allows you to match the widget's styling with the design of your application.

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if (tc) {
          createSwap("swap-component", {
              tonConnectInstance: tc,
              theme: {
                  border: "#3A3A3C", // Border color
                  primary: "#16A34A", // Primary button and highlight color
                  background: "#18181B", // Widget background color
                  input_card: "#27272A", // Input card background
                  input_token: "#3A3A3C", // Token input background color
                  light_shade: "#3A3A3C", // Lighter shade for elements
                  slippage_box: "#D1D1E0", // Slippage box background
                  text_black: "#FFFFFF", // Text color on dark backgrounds
                  text_white: "#000000", // Text color on light backgrounds
                  text_fade: "#6B7280", // Faded text color for descriptions
                  skeleton_shine: "#585959", // Skeleton loader shine effect
              },
          });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="swap-component"></div>
        </div>
    );
}

Default Tokens

You can specify default tokens to be displayed in the swap interface by passing a defaultTokens property to the createSwap function. This property should be an array of token objects, each containing the necessary details such as the token's address.

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if (tc) { 
          createSwap("swap-component", {
              tonConnectInstance: tc,
              options: {
                  default_pay_token:
                      "EQD4P32U10snNoIavoq6cYPTQR82ewAjO20epigrWRAup54_",
                  default_receive_token:
                      "EQD-cvR0Nz6XAyRBvbhz-abTrRC6sI5tvHvvpeQraV9UAAD7",
              },
          });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="swap-component"></div>
        </div>
    );
}

Pinned tokens

You can pin specific tokens to the top of the token selection list by using the pin_tokens property to the createSwap function. This ensures that these tokens are always easily accessible to users.

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if(tc){
          createSwap("swap-component", {
              tonConnectInstance: tc,
              options: {
                  pin_tokens: [
                      "EQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAM9c",
                      "EQD-cvR0Nz6XAyRBvbhz-abTrRC6sI5tvHvvpeQraV9UAAD7",
                  ],
              },
          });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="swap-component"></div>
        </div>
    );
}

AppId

This feature allows partners to be uniquely identified when using the widget, enabling better tracking and analytics for partner-related swaps.

function App() {
    const [tc] = useTonConnectUI();
    useEffect(() => {
        if (tc) {
          createSwap("swap-component", {
              tonConnectInstance: tc,
              options: {
                  app_id: "your_app_id",
              },
          });
        }
    }, [tc]);
    return (
        <div className="App">
            <div id="swap-component"></div>
        </div>
    );
}

Contributing

We welcome contributions to improve @mytonswap/widget. To contribute, follow these steps:

  1. Fork the repository.
  2. Create a new branch: git checkout -b feature-name.
  3. Make your changes and commit them: git commit -m 'Add feature'.
  4. Push to the branch: git push origin feature-name.
  5. Submit a pull request.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Support For issues or questions, feel free to open an issue on our GitHub repository.

1.2.0

12 months ago

1.2.1

12 months ago

1.1.1

12 months ago

1.0.2

12 months ago

1.1.0

12 months ago

1.0.1

12 months ago

1.0.0

12 months ago

1.0.6

12 months ago

1.0.5

12 months ago

1.0.4

12 months ago

1.0.3

12 months ago

0.3.9

1 year ago

0.3.14

1 year ago

0.3.13

1 year ago

0.3.12

1 year ago

0.3.11

1 year ago

0.3.10

1 year ago

0.3.8

1 year ago

0.3.6

1 year ago

0.3.5

1 year ago

0.3.7

1 year ago

0.3.4

1 year ago

0.3.3

1 year ago

0.3.2

1 year ago

0.3.1

1 year ago

0.3.0

1 year ago

0.2.0

1 year ago

0.1.1

1 year ago