@nfid/identitykit
v1.0.1
Published
A React library for adding wallet connections to dApps.
Downloads
986
Readme
NFID IdentityKit
NFID IdentityKit is a React library designed to simplify adding a wallet connection to your decentralized application (dApp). With intuitive, responsive, and customizable components, developers can easily select which ICP-compatible wallets to support in their apps for authentication, signatures, and transfers.
✨ Features
- Easy Integration: Quickly add wallet connection functionality to your dApp.
- Customizable: Tailor the look and feel to match your application's design.
- Responsive: Optimized for different screen sizes and devices.
🛠 Prerequisites
Before using NFID IdentityKit, ensure that you have:
- An ICP project with a frontend canister.
📦 Installation
A library to integrate compatible ICP wallets into your application, which contains React-specific components for integrating compatible ICP wallets into your application.
Install library with the following command:
npm install @nfid/identitykit
🔗 Peer Dependencies
IdentityKit requires certain peer dependencies to function correctly. Ensure the following packages are installed in your project:
npm install @dfinity/ledger-icp @dfinity/identity @dfinity/agent @dfinity/candid @dfinity/principal @dfinity/utils @dfinity/auth-client
Note: IdentityKit is a React library and exports styles that need to be imported into your project.
🚀 Usage
🎨 Import Styles
Begin by importing the necessary styles in your project:
import "@nfid/identitykit/react/styles.css"
🧩 Wrap Your Application with IdentityKitProvider
Next, wrap your entire application with the IdentityKitProvider
to enable wallet connections:
import { IdentityKitProvider } from "@nfid/identitykit/react"
const App = () => {
return (
<IdentityKitProvider>
<YourApp />
</IdentityKitProvider>
)
}
🔗 Add the Connect Button
Finally, import and render the ConnectWallet
component in your application to allow users to
connect their wallets:
import { ConnectWallet } from "@nfid/identitykit/react"
export const YourApp = () => {
return <ConnectWallet />
}
Once integrated, IdentityKit will handle your user's wallet selection, display wallet information, and manage wallet switching.
📄 License
This project is licensed under the MIT License.
🤝 Contributing
Contributions are welcome! To get started, please submit a pull request or open an issue on GitHub.
💬 Support
If you encounter any issues or have questions, feel free to reach out to the team directly on Discord.
📘 Documentation
For full documentation, visit docs.identitykit.xyz.
🎉 Try it out
Here is a short list of live IdentityKit implementations:
- Demo App
- ICRC Standards Implementation (view low-level ICRC standards implementations)