Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

Awesome Lists containing this project

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 signature

const 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