import Alert from 'react-bootstrap/Alert' import styles from './banners.module.css' import { useEffect, useState } from 'react' import { useMe } from '@/components/me' import { useMutation } from '@apollo/client' import { WELCOME_BANNER_MUTATION } from '@/fragments/users' import { useToast } from '@/components/toast' import { BALANCE_LIMIT_MSATS } from '@/lib/constants' import { msatsToSats, numWithUnits } from '@/lib/format' export function WelcomeBanner ({ Banner }) { const me = useMe() const toaster = useToast() const [hidden, setHidden] = useState(true) const handleClose = async () => { window.localStorage.setItem('hideWelcomeBanner', true) setHidden(true) if (me) { try { await hideWelcomeBanner() } catch (err) { console.log(err) toaster.danger('mutation failed') } } } const [hideWelcomeBanner] = useMutation(WELCOME_BANNER_MUTATION, { update (cache) { cache.modify({ id: `User:${me.id}`, fields: { hideWelcomeBanner () { return true } } }) } }) useEffect(() => { setHidden(me?.privates?.hideWelcomeBanner || (!me && window.localStorage.getItem('hideWelcomeBanner'))) }, [me?.privates?.hideWelcomeBanner]) if (hidden) return null return Banner ? : ( 👋 Welcome to Stacker News!

To get started, check out our{' '} FAQs or{' '} content guidelines, or go ahead and{' '} { me ? ( make a post ) : ( <> sign up or create an{' '} anonymous post ) }.

) } export function MadnessBanner ({ handleClose }) { const me = useMe() return ( ⚡️ Million Sat Madness Is Here! {me ? (
We're giving away 3 million sats to the top Stacker News contributors in March. See the leaderboard!
How does Million Sat Madness work? Click here.
) : (
We're giving away 3 million sats to the top Stacker News contributors in March. Sign up!
Need help? Check out our FAQs.
)}
) } export function WalletLimitBanner () { const me = useMe() const limitReached = me?.privates?.sats >= msatsToSats(BALANCE_LIMIT_MSATS) if (!me || !limitReached) return return ( Your wallet is over the current limit ({numWithUnits(msatsToSats(BALANCE_LIMIT_MSATS))})

Deposits to your wallet from outside of SN are blocked.

Please spend or withdraw sats to restore full wallet functionality.

) } export function WalletSecurityBanner () { return ( Wallet Security Disclaimer

Your wallet's credentials for spending are stored in the browser and never go to the server. However, you should definitely set a budget in your wallet if you can.

Also, for the time being, you will have to reenter your credentials on other devices.

) } export function AuthBanner () { return ( Please add a second auth method to avoid losing access to your account. ) }