-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #121 from bnb-chain/widget/classname
feat: Add class name into components
- Loading branch information
Showing
69 changed files
with
1,179 additions
and
195 deletions.
There are no files selected for viewing
67 changes: 67 additions & 0 deletions
67
packages/canonical-bridge-widget/docs/Bridge Configuration (basic).md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# Bridge configuration (basic) | ||
|
||
Bridge configuration allows user to config title, theme color, multi-language and server API. | ||
|
||
```javascript | ||
const bridgeConfig: ICanonicalBridgeConfig = { | ||
appName: 'Your-App-Name', | ||
assetPrefix: '', | ||
appearance: { | ||
bridgeTitle: 'Bridge Title', | ||
mode: 'dark', | ||
theme: { | ||
dark: { | ||
input: { | ||
background: '#1E2026', | ||
title: '#8C8F9B', | ||
}, | ||
}, | ||
light: {}, | ||
}, | ||
locale: 'en', | ||
messages, | ||
}, | ||
wallet: { | ||
walletConnectProjectId: env.WALLET_CONNECT_PROJECT_ID, | ||
}, | ||
http: { | ||
refetchingInterval: 30 * 1000, // 30s | ||
apiTimeOut: 60 * 1000, // 60s | ||
deBridgeAccessToken: '', | ||
serverEndpoint: env.WIDGET_SERVER_ENDPOINT, | ||
}, | ||
}; | ||
``` | ||
|
||
## appName | ||
|
||
This is the prefix of images url. The default token and chain images can be found in | ||
canonical-bridge-ui. Please copy these images to your /images folder. | ||
|
||
## appearance | ||
|
||
1. theme: Light and dark color configuration. For full list of available color settings | ||
|
||
2. mode: Dark/light mode. Default mode is dark | ||
|
||
3. locale: Language of your website. For example: 'fr' or 'zh-CN'. | ||
|
||
4. message: Multilingual message. You need to create individual language files, for example fr.ts . | ||
Message format should look like this. Replace the message value with the language you want. <b>Do | ||
not change the value within curly bracket!</b>. | ||
|
||
## wallet | ||
|
||
walletConnectProjectId: WalletConnect Cloud project identifier. You can find your projectId on your | ||
WalletConnect dashboard. | ||
|
||
## http | ||
|
||
1. refetchingInterval: Optional. Time interval for fetching bridge fees. Default value is 30 | ||
seconds. Please do not set this value to more than 30 seconds to avoid sending outdated orders, | ||
which may result in transaction failure. | ||
|
||
2. apiTimeOut: Optional. Bridge API request timeout. Default value is 1 min. | ||
|
||
3. serverEndpoint: Server endpoint to fetch token price and token list. You need to deploy your | ||
server API. Please check the docs. |
133 changes: 133 additions & 0 deletions
133
packages/canonical-bridge-widget/docs/Custom Route (advanced).md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,133 @@ | ||
This widget provides several bridges or routes; deBridge, cBridge, Stargate, LayerZero and Meson. To | ||
enable routes you need to add route settings into transferConfig, which is prop | ||
of<CanonicalBridgeProvider> component. The config structure for individual route is like | ||
|
||
```javascript | ||
// ROUTE_NAME should be one of following name | ||
// cBridge | deBridge | meson | stargate | layerZero | ||
ROUTE_NAME: { | ||
config: ROUTE_CONFIG, | ||
exclude: { | ||
chains: [], | ||
tokens: {} | ||
}, | ||
bridgedTokenGroups: [] | ||
} | ||
``` | ||
|
||
ROUTE_CONFIG contains the list of token address and bridge address. The token list structure of | ||
different bridge may vary, and you can check demo for more details. To enable deBridge or cBridge | ||
routes, there are a few ways to configure token settings. | ||
|
||
1. Deploying Your Own API Server: Fetch the cBridge and deBridge token lists by following the | ||
deployment instructions | ||
(https://github.com/bnb-chain/canonical-bridge/tree/main/apps/canonical-bridge-server). This is | ||
our recommended approach for flexibility and control over updates. | ||
2. Using cBridge or deBridge APIs Directly: Obtain token and chain configurations directly from the | ||
cBridge API or deBridge API and inject them into transferConfig. | ||
3. Downloading JSON-formatted Settings: Download token settings in JSON format from the cBridge API | ||
or deBridge API and save them within your application. Be aware that you may need to update these | ||
files regularly to avoid missing newly supported tokens. | ||
|
||
The first option is ideal, but due to the cost of deploying your own API server, the second or third | ||
options may be more feasible. | ||
|
||
## API server | ||
|
||
The instructions of API server deployment can be found | ||
(https://github.com/bnb-chain/canonical-bridge/tree/main/apps/canonical-bridge-server). The server | ||
provides endpoints /api/bridge/cbridge and /api/bridge/deBridge to retrieve token config, and it | ||
also supported token prices. Deploy API your own API server is highly recommended to access full | ||
widget functionality. | ||
|
||
After setting up the token configurations, you may wonder where this token list originates and how | ||
to add more tokens. For this, please check the documentation of each bridge provider. Links to these | ||
documentation are listed below. | ||
|
||
[deBridge](https://deswap.debridge.finance/v1.0/#/utils/AppControllerV10_getSupportedChainInfoResponse) | ||
|
||
[cBridge](https://cbridge-docs.celer.network/developer/api-reference/gateway-gettransferconfigsforall) | ||
|
||
[Stargate](https://stargateprotocol.gitbook.io/stargate/v2-developer-docs/technical-reference/mainnet-contracts) | ||
|
||
[Meson](https://meson.dev/api/endpoints/list-chains) | ||
|
||
[LayerZero V1 endpoints](https://docs.layerzero.network/v1/developers/evm/technical-reference/mainnet/mainnet-addresses) | ||
|
||
## Token Config format | ||
|
||
By adding tokens to each route please follow the below token list and network list format. | ||
|
||
Stargate: | ||
|
||
```javascript | ||
{ | ||
"tokens": { | ||
// chain id. 1 represents Ethereum | ||
"1": [ | ||
{ | ||
"address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", // token address | ||
"bridgeAddress": "0xc026395860Db2d07ee33e05fE50ed7bD583189C7", // bridge contract address | ||
"decimals": 6, | ||
"symbol": "USDC", | ||
"endpointID": 30101, // can be found in stargate link under api server section. | ||
"name": "USD Coin" | ||
}, | ||
] | ||
}, | ||
"chains": [ | ||
{ | ||
"chainId": 1, | ||
"chainName": "Ethereum" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
LayerZero: | ||
|
||
```javascript | ||
{ | ||
"tokens": { | ||
// chain id of networks. | ||
"1": [ // 1 => Ethereum | ||
{ | ||
"address": "0x152649eA73beAb28c5b49B26eb48f7EAD6d4c898", // token address | ||
"bridgeAddress": "0x152649eA73beAb28c5b49B26eb48f7EAD6d4c898", // bridge contract address | ||
"decimals": 18, | ||
"symbol": "CAKE", | ||
"name": "Cake", | ||
"endpointID": 101, // This id can be found in layerzero V1 endpoint link above | ||
"version": 1 // layerzero version | ||
} | ||
], | ||
"56": [ // 56 => BNB smart chain | ||
{ | ||
"address": "0x0e09fabb73bd3ade0a17ecc321fd13a19e81ce82", | ||
"bridgeAddress": "0xb274202daBA6AE180c665B4fbE59857b7c3a8091", | ||
"decimals": 18, | ||
"symbol": "CAKE", | ||
"name": "Cake", | ||
"endpointID": 102, | ||
"version": 1 | ||
} | ||
], | ||
}, | ||
"chains": [ | ||
{ | ||
"chainId": 1, | ||
"chainName": "Ethereum" | ||
}, | ||
{ | ||
"chainId": 56, | ||
"chainName": "BSC" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
cBridge and deBridge config format is as same as | ||
[cBridge](https://cbridge-docs.celer.network/developer/api-reference/gateway-gettransferconfigsforall) | ||
and | ||
[deBridge](https://deswap.debridge.finance/v1.0/#/utils/AppControllerV10_getSupportedChainInfoResponse) | ||
respectively. |
Oops, something went wrong.