Skip to content

Latest commit

 

History

History
152 lines (106 loc) · 3.25 KB

README.md

File metadata and controls

152 lines (106 loc) · 3.25 KB

@kredeum/wagmi-svelte5

A Svelte 5 Web3 library based on Wagmi, providing seamless integration of Web3 functionality into your Svelte applications.

✨ Features

  • 🔌 Built for Svelte 5 with full TypeScript support
  • 🌐 Web3 Integration using Wagmi core functionality
  • 🔒 Secure Wallet Connection Management
  • ⛓️ Multi-chain Support with Auto-detection
  • 🎣 Reactive Web3 Hooks for Real-time Updates
  • 🔄 Auto-refresh on Network Changes
  • 📦 Simple and Intuitive API
  • 🛠️ Type-safe Contract Interactions

📁 Repository Structure

This repository contains two main parts:

  • 📦 The Svelte5 package code in src/lib/wagmi
  • 🎮 A SvelteKit demo app with usage examples in src/routes

📦 Svelte5 Package

💻 Installation

Add this package to your Svelte5 project:

npm install @kredeum/wagmi-svelte5
# or
pnpm install @kredeum/wagmi-svelte5
# or
yarn add @kredeum/wagmi-svelte5

🚀 Quick Start

Simple Example

<script lang="ts">
  import { newWagmi } from "@kredeum/wagmi-svelte5";
  import { Counter } from "$lib/examples/Counter.svelte";

  newWagmi();
  const counter = new Counter();
</script>

{counter.number}² = {counter.square(counter.number)}

Using this Counter class Helper

import { SmartContract } from "$lib/wagmi";

export class Counter extends SmartContract {
  get number() {
    return this.call("number") as bigint;
  }
  square(num: number | bigint) {
    return this.call("square", [num]) as bigint;
  }
  constructor() {
    super("Counter");
  }
}

Same example without Helper

<script lang="ts">
  import { newWagmi, SmartContract } from "@kredeum/wagmi-svelte5";

  newWagmi();
  const contract = new SmartContract("Counter");
  const num = $derived(contract.call("number"));
  const square = $derived(contract.call("square", [num]));
</script>

{num}² = {square}

📄 Smart Contract Source

// Counter.sol
contract Counter is ICounter {
    uint256 public number;

    function square(uint256 num) public pure override(ICounter) returns (uint256) {
        return num ** 2;
    }
    ...
}

Full Counter.sol code deployed on Base Sepolia testnet can be Viewed here: 🔍 on BaseScan

🎮 SvelteKit Demo and Examples

The demo app in src/routes showcases various package features and usage patterns.

🛠️ Requirements

Your local machine needs:

Optional but recommended:

⚡ Quick Setup

Get started with the examples:

# Clone the repository
git clone https://github.com/kredeum/wagmi-svelte5.git
cd wagmi-svelte5

# Install dependencies
pnpm install

# Run the demo app
turbo start
# or without Turborepo
pnpx turbo start

🌐 Your browser will open to http://localhost:5173 showing the Tests page

🤝 Contributing

We welcome contributions! Feel free to:

  • 🐛 Report issues
  • 💡 Suggest features
  • 🔧 Submit pull requests

📄 License

MIT License - see the LICENSE file for details.

👨‍💻 Author

zapaz.eth zapaz@kredeum.com (http://labs.kredeum.com/)