import Dropdown from 'react-bootstrap/Dropdown' import { useShowModal } from './modal' import { useToast } from './toast' import ItemAct from './item-act' import AccordianItem from './accordian-item' import Flag from '@/svgs/flag-fill.svg' import { useCallback, useMemo } from 'react' import getColor from '@/lib/rainbow' import { gql, useMutation } from '@apollo/client' import { useItemContext } from './item' import { useLightning } from './lightning' export function DownZap ({ item, ...props }) { const { pendingDownSats } = useItemContext() const { meDontLikeSats } = item const downSats = meDontLikeSats + pendingDownSats const style = useMemo(() => (downSats ? { fill: getColor(downSats), filter: `drop-shadow(0 0 6px ${getColor(downSats)}90)` } : undefined), [downSats]) return ( } /> ) } function DownZapper ({ item, As, children }) { const toaster = useToast() const showModal = useShowModal() const strike = useLightning() const { setPendingDownSats } = useItemContext() const optimisticUpdate = useCallback((sats, { onClose } = {}) => { setPendingDownSats(pendingSats => pendingSats + sats) strike() onClose?.() return () => { setPendingDownSats(pendingSats => pendingSats - sats) } }, []) return ( { try { showModal(onClose =>
  • downzaps are just like zaps but cause items to lose ranking position
  • downzaps also reduce trust between you and whoever zaps it so you'll see less of what they zap in the future
  • all sats from downzaps go to rewards
  • } />
    ) } catch (error) { toaster.danger('failed to downzap item') } }} > {children}
    ) } export default function DontLikeThisDropdownItem ({ item }) { return ( downzap ) } export function OutlawDropdownItem ({ item }) { const toaster = useToast() const [toggleOutlaw] = useMutation( gql` mutation toggleOutlaw($id: ID!) { toggleOutlaw(id: $id) { outlawed } }`, { update (cache, { data: { toggleOutlaw } }) { cache.modify({ id: `Item:${item.id}`, fields: { outlawed: () => true } }) } } ) return ( { try { await toggleOutlaw({ variables: { id: item.id } }) } catch { toaster.danger('failed to outlaw') return } toaster.success('item outlawed') }} > outlaw ) }