ConnectProvider

Description

The ConnectProvider component in TypeScript React sets up a context provider for managing the ConnectSmartAccount related state and functionality.

Parameters

  • apiKey : Cometh Connect public api key. This can be retrieved from the Cometh dashboard

  • bundlerUrl: The URL of the Cometh bundler. This can be retrieved from the Cometh 4337 docs and dashboard

  • paymasterUrl - optional: The paymaster API key. This can be retrieved from the Cometh dashboard

  • chain -Your required chain.

  • rpcUrl - optional

Example

"use client";

import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
import { Inter } from "next/font/google";
import "./lib/ui/globals.css";

import { ConnectProvider } from "@cometh/connect-react-hooks";
import { arbitrumSepolia } from "viem/chains";

const queryClient = new QueryClient();

const inter = Inter({
    subsets: ["latin"],
});

const apiKey = process.env.NEXT_PUBLIC_COMETH_API_KEY;
const bundlerUrl = process.env.NEXT_PUBLIC_4337_BUNDLER_URL;
const paymasterUrl = process.env.NEXT_PUBLIC_4337_PAYMASTER_URL;
const rpcUrl = "https://arbitrum-sepolia.blockpi.network/v1/rpc/public";

export default function RootLayout({
    children,
}: {
    children: React.ReactNode;
}) {
    return (
        <html lang="en">
            <QueryClientProvider client={queryClient}>
                <ConnectProvider
                    config={{
                        paymasterUrl,
                        bundlerUrl,
                        apiKey,
                        rpcUrl,
                        chain: arbitrumSepolia
                    }}
                    queryClient={queryClient}
                >
                    <body className={inter.className}>{children}</body>
                </ConnectProvider>
            </QueryClientProvider>
        </html>
    );
}

Last updated