mirror of
https://github.com/neynarxyz/create-farcaster-mini-app.git
synced 2025-11-15 23:58:56 -05:00
This reverts commit b1fdfc19a92241638692d58494f48ce1bb25df74, reversing changes made to b9e2087bd8cd9e8ed7a5862936609b5bf29aa911.
87 lines
2.2 KiB
TypeScript
87 lines
2.2 KiB
TypeScript
import React, { createContext, useEffect, useState } from "react";
|
|
import dynamic from "next/dynamic";
|
|
import { sdk } from '@farcaster/miniapp-sdk';
|
|
|
|
const FarcasterSolanaProvider = dynamic(
|
|
() => import('@farcaster/mini-app-solana').then(mod => mod.FarcasterSolanaProvider),
|
|
{ ssr: false }
|
|
);
|
|
|
|
type SafeFarcasterSolanaProviderProps = {
|
|
endpoint: string;
|
|
children: React.ReactNode;
|
|
};
|
|
|
|
const SolanaProviderContext = createContext<{ hasSolanaProvider: boolean }>({ hasSolanaProvider: false });
|
|
|
|
export function SafeFarcasterSolanaProvider({ endpoint, children }: SafeFarcasterSolanaProviderProps) {
|
|
const isClient = typeof window !== "undefined";
|
|
const [hasSolanaProvider, setHasSolanaProvider] = useState<boolean>(false);
|
|
const [checked, setChecked] = useState<boolean>(false);
|
|
|
|
useEffect(() => {
|
|
if (!isClient) return;
|
|
let cancelled = false;
|
|
(async () => {
|
|
try {
|
|
const provider = await sdk.wallet.getSolanaProvider();
|
|
if (!cancelled) {
|
|
setHasSolanaProvider(!!provider);
|
|
}
|
|
} catch {
|
|
if (!cancelled) {
|
|
setHasSolanaProvider(false);
|
|
}
|
|
} finally {
|
|
if (!cancelled) {
|
|
setChecked(true);
|
|
}
|
|
}
|
|
})();
|
|
return () => {
|
|
cancelled = true;
|
|
};
|
|
}, [isClient]);
|
|
|
|
useEffect(() => {
|
|
let errorShown = false;
|
|
const origError = console.error;
|
|
console.error = (...args) => {
|
|
if (
|
|
typeof args[0] === "string" &&
|
|
args[0].includes("WalletConnectionError: could not get Solana provider")
|
|
) {
|
|
if (!errorShown) {
|
|
origError(...args);
|
|
errorShown = true;
|
|
}
|
|
return;
|
|
}
|
|
origError(...args);
|
|
};
|
|
return () => {
|
|
console.error = origError;
|
|
};
|
|
}, []);
|
|
|
|
if (!isClient || !checked) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<SolanaProviderContext.Provider value={{ hasSolanaProvider }}>
|
|
{hasSolanaProvider ? (
|
|
<FarcasterSolanaProvider endpoint={endpoint}>
|
|
{children}
|
|
</FarcasterSolanaProvider>
|
|
) : (
|
|
<>{children}</>
|
|
)}
|
|
</SolanaProviderContext.Provider>
|
|
);
|
|
}
|
|
|
|
export function useHasSolanaProvider() {
|
|
return React.useContext(SolanaProviderContext).hasSolanaProvider;
|
|
}
|