Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/suiet/wallet-adapter
Integration of Suiet Wallet into the Wallet Adapter
https://github.com/suiet/wallet-adapter
Last synced: 3 months ago
JSON representation
Integration of Suiet Wallet into the Wallet Adapter
- Host: GitHub
- URL: https://github.com/suiet/wallet-adapter
- Owner: suiet
- License: mit
- Created: 2022-09-10T14:59:28.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-12-28T23:21:51.000Z (about 2 years ago)
- Last Synced: 2024-10-02T00:19:52.870Z (4 months ago)
- Language: TypeScript
- Homepage: https://wallet-adapter-example.suiet.app
- Size: 871 KB
- Stars: 76
- Watchers: 8
- Forks: 19
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-sui - Suiet Wallet - Suiet Wallet Adapter. (Wallets / Wallet Adapters)
- awesome-move - Suiet Wallet - Suiet Wallet Adapter. (Wallets / Wallet Adapters)
README
# Suiet Wallet Adapter
**⚠️ Deprecation Announcement: This package will not be maintained, please switch to our [wallet-kit](https://github.com/suiet/wallet-kit) instead. Because Sui team has come up with a [wallet-standard](https://github.com/MystenLabs/sui/tree/main/sdk/wallet-adapter/wallet-standard) which introduces a standard way to integrate with wallets on Sui.**
> 👋 If you want to know how to **install/use** suiet, please visit our offical website [suiet.app](https://suiet.app)
> or [docs](https://suiet.app/docs)Integrate your DApp with Suiet Wallet from now on 🥳
We've presented an adapter that implemented the interface
of [SUI Wallet Adapter](https://github.com/MystenLabs/sui/tree/main/wallet-adapter) for you✨ With this adapter, your
DApp can easily connect with the Suiet Wallet Extension, which enables DApp to retrieve basic info of user's wallet and
launch manipulation requests such as transaction signing.1️⃣ First-choice integration guide
Try our [@suiet/wallet-kit](https://www.npmjs.com/package/@suiet/wallet-kit) for easy integration with this
adapter🥳`@suiet/wallet-kit` is an all-in-one wallet connection kit with nice UI components for dapps , which connects your dapp
with wallets on SUI and
empowers your dapp with awesome wallet abilities🪄2️⃣ Manual integration guide
For React DApps, the Sui team has provided **React context provider** and **React hook** in the
npm
package [@mysten/wallet-adapter-react](https://github.com/MystenLabs/sui/tree/main/wallet-adapter/packages/react-providers)
. Therefore we can simply register the Suiet Adapter into the official provider and then make use of them.> ⚠️ Usage with React ONLY: We only support React DApp right now.
## 🚀 Get Started
### Easy Integration with Suiet wallet kit
🔗 Quick start in minutes: [https://kit.suiet.app/docs/QuickStart](https://kit.suiet.app/docs/QuickStart)
### Maunal Integration with SUI official kit
### ⚙️ Prerequisites
1. A React project
2. Install required npm packages```bash
npm install @mysten/wallet-adapter-react @suiet/wallet-adapter
```### 🚢 Use Sui wallet provider & Register Suiet adapter
```jsx
// main.js
import {WalletProvider} from "@mysten/wallet-adapter-react";
import {SuietWalletAdapter} from "@suiet/wallet-adapter";const supportedWallets = [
{adapter: new SuietWalletAdapter()},
];ReactDOM.createRoot(document.getElementById("root")).render(
);
```### ✅ Retrieve data and launch manipulations
```jsx
// App.jsx
import {useEffect} from "react";
import {useWallet} from "@mysten/wallet-adapter-react";function App() {
const {
select,
wallet,
connected,
connecting,
disconnect,
getAccounts,
executeMoveCall,
} = useWallet();useEffect(() => {
if (!connected || !wallet) return;
(async function () {
console.log(wallet.adapter.name);
const accounts = await getAccounts();
console.log(accounts);
})();
}, [connected, wallet]);async function handleExecuteMoveCall() {
await executeMoveCall({
packageObjectId: "0x2",
module: "devnet_nft",
function: "mint",
typeArguments: [],
arguments: [
"name",
"capy",
"https://cdn.britannica.com/94/194294-138-B2CF7780/overview-capybara.jpg?w=800&h=450&c=crop",
],
gasBudget: 10000,
});
}return (
Current wallet: {wallet ? wallet.adapter.name : 'null'}
{
if (!connected) {
select('Suiet');
} else {
disconnect();
}
}}
>
{connecting ? "connecting" : connected ? "Disconnect" : "connect"}
)
}
```There you go ✅ Go connect with our wallet with custom UI selector!
## ✨ Features
### Sign Message
> ⚠️ Sui official react kit doesn't support this feature right now.
> You can try our [@suiet/wallet-kit](https://www.npmjs.com/package/@suiet/wallet-kit) which fully support it and also
> many handful features```ts
signMessage: (input: { message: Uint8Array }) => Promise<{
signature: Uint8Array;
signedMessage: Uint8Array;
}>
```If you are using `@suiet/wallet-kit`, you can use `signMessage` function from hooks.
If you are using SUI official kit which has not supported this feature, you can try the below hack (when connected to
Suiet Wallet):> Suiet Wallet version should >= 0.1.25
```js
import {SuietWalletAdapter} from "@suiet/wallet-adapter";
import * as tweetnacl from 'tweetnacl' // crypto lib for verify signatureconst suietAdapter = new SuietWalletAdapter();
async function signMessage() {
const result = await suietAdapter.signMessage({
message: new TextEncoder().encode('Hello world')
})const textDecoder = new TextDecoder()
console.log('signMessage success', result)
console.log('signMessage signature', result.signature) // output -> Uint8Array
console.log('signMessage signedMessage', textDecoder.decode(result.signedMessage).toString()) // Uint8Array of your raw message// verify signMessage with
const publicKey = await suietAdapter.getPublicKey()
console.log('publicKey', publicKey) // output -> Uint8Array(32)
const isValidSignature = tweetnacl.sign.detached.verify(
result.signedMessage,
result.signature,
publicKey,
)
console.log('verify signature with publicKey: ', isValidSignature)
}
```## 💡 Demo playground
We also prepared a demo for developers, feel free to check it out:
🔗 Website: https://wallet-adapter-example.suiet.app/
🔗 Github Repo: https://github.com/suiet/wallet-adapter/tree/main/examples/sui-kit-integration