1
0
mirror of https://github.com/kremalicious/blog.git synced 2024-11-22 09:56:51 +01:00

load web3 stuff client-side only

This commit is contained in:
Matthias Kretschmann 2023-08-17 16:13:44 +01:00
parent cc6549b0d3
commit bed3752c24
Signed by: m
GPG Key ID: 606EEEF3C479A91F
3 changed files with 16 additions and 8 deletions

View File

@ -172,8 +172,7 @@ export const onCreateWebpackConfig: GatsbyNode['onCreateWebpackConfig'] =
util: false,
crypto: false,
path: false,
url: false,
process: false
url: false
}
}
})

View File

@ -1,8 +1,9 @@
import React, { ReactElement, useState } from 'react'
import { parseEther } from 'viem'
import { ConnectButton } from '@rainbow-me/rainbowkit'
import { useDebounce } from 'use-debounce'
import { parseEther } from 'viem'
import { usePrepareSendTransaction, useSendTransaction } from 'wagmi'
import { ConnectButton } from '@rainbow-me/rainbowkit'
import Alert, { getTransactionMessage } from './Alert'
import InputGroup from './InputGroup'
import * as styles from './index.module.css'

View File

@ -1,12 +1,11 @@
import React, { ReactElement } from 'react'
import { HeadProps } from 'gatsby'
import { RainbowKitProvider } from '@rainbow-me/rainbowkit'
import { WagmiConfig } from 'wagmi'
import { RainbowKitProvider } from '@rainbow-me/rainbowkit'
import { chains, theme, wagmiConfig } from '../helpers/rainbowkit'
import Copy from '../components/atoms/Copy'
import Meta, { HeadMetaProps } from '../components/atoms/HeadMeta'
import Icon from '../components/atoms/Icon'
import Web3Donation from '../components/molecules/Web3Donation'
import { chains, theme, wagmiConfig } from '../helpers/rainbowkit'
import { useSiteMetadata } from '../hooks/useSiteMetadata'
import * as styles from './thanks.module.css'
@ -14,6 +13,10 @@ const meta: Partial<HeadMetaProps> = {
title: `Say Thanks`
}
const Web3Donation = React.lazy(
() => import('../components/molecules/Web3Donation')
)
function Coin({ address, title }: { address: string; title: string }) {
return (
<div className={styles.coin}>
@ -36,6 +39,7 @@ const BackButton = () => (
)
export default function Thanks(): ReactElement {
const isSSR = typeof window === 'undefined'
const { author } = useSiteMetadata()
const coins = Object.entries(author).filter(
([key]) => key === 'bitcoin' || key === 'ether'
@ -50,7 +54,11 @@ export default function Thanks(): ReactElement {
<WagmiConfig config={wagmiConfig}>
<RainbowKitProvider chains={chains} theme={theme}>
<Web3Donation address={author.ether} />
{!isSSR && (
<React.Suspense fallback={<div />}>
<Web3Donation address={author.ether} />
</React.Suspense>
)}
</RainbowKitProvider>
</WagmiConfig>