2023-07-24 18:35:05 +00:00
|
|
|
import Dropdown from 'react-bootstrap/Dropdown'
|
2023-01-10 23:13:37 +00:00
|
|
|
import { useShowModal } from './modal'
|
2023-08-25 23:21:51 +00:00
|
|
|
import { useToast } from './toast'
|
2024-05-28 17:18:54 +00:00
|
|
|
import ItemAct from './item-act'
|
2023-12-20 00:15:08 +00:00
|
|
|
import AccordianItem from './accordian-item'
|
2024-03-20 00:37:31 +00:00
|
|
|
import Flag from '@/svgs/flag-fill.svg'
|
2024-06-12 18:24:04 +00:00
|
|
|
import { useCallback, useMemo } from 'react'
|
2024-03-20 00:37:31 +00:00
|
|
|
import getColor from '@/lib/rainbow'
|
2023-12-23 20:26:16 +00:00
|
|
|
import { gql, useMutation } from '@apollo/client'
|
2024-06-12 18:24:04 +00:00
|
|
|
import { useItemContext } from './item'
|
|
|
|
import { useLightning } from './lightning'
|
2022-09-21 19:57:36 +00:00
|
|
|
|
2024-05-28 17:18:54 +00:00
|
|
|
export function DownZap ({ item, ...props }) {
|
2024-06-12 18:24:04 +00:00
|
|
|
const { pendingDownSats } = useItemContext()
|
2024-05-28 17:18:54 +00:00
|
|
|
const { meDontLikeSats } = item
|
2024-06-12 18:24:04 +00:00
|
|
|
|
|
|
|
const downSats = meDontLikeSats + pendingDownSats
|
|
|
|
|
|
|
|
const style = useMemo(() => (downSats
|
2023-12-20 01:55:19 +00:00
|
|
|
? {
|
2024-06-12 18:24:04 +00:00
|
|
|
fill: getColor(downSats),
|
|
|
|
filter: `drop-shadow(0 0 6px ${getColor(downSats)}90)`
|
2023-12-20 01:55:19 +00:00
|
|
|
}
|
2024-06-12 18:24:04 +00:00
|
|
|
: undefined), [downSats])
|
2023-12-20 01:55:19 +00:00
|
|
|
return (
|
2024-05-28 17:18:54 +00:00
|
|
|
<DownZapper item={item} As={({ ...oprops }) => <Flag {...props} {...oprops} style={style} />} />
|
2023-12-20 01:55:19 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2024-05-28 17:18:54 +00:00
|
|
|
function DownZapper ({ item, As, children }) {
|
2023-08-25 23:21:51 +00:00
|
|
|
const toaster = useToast()
|
2023-01-10 23:13:37 +00:00
|
|
|
const showModal = useShowModal()
|
2024-06-12 18:24:04 +00:00
|
|
|
const strike = useLightning()
|
|
|
|
const { setPendingDownSats } = useItemContext()
|
|
|
|
|
|
|
|
const optimisticUpdate = useCallback((sats, { onClose } = {}) => {
|
|
|
|
setPendingDownSats(pendingSats => pendingSats + sats)
|
|
|
|
strike()
|
|
|
|
onClose?.()
|
|
|
|
return () => {
|
|
|
|
setPendingDownSats(pendingSats => pendingSats - sats)
|
|
|
|
}
|
|
|
|
}, [])
|
2022-09-21 19:57:36 +00:00
|
|
|
|
|
|
|
return (
|
2023-12-20 01:55:19 +00:00
|
|
|
<As
|
2023-02-16 22:23:59 +00:00
|
|
|
onClick={async () => {
|
|
|
|
try {
|
2023-09-14 02:08:03 +00:00
|
|
|
showModal(onClose =>
|
|
|
|
<ItemAct
|
2024-06-12 18:24:04 +00:00
|
|
|
onClose={onClose} item={item} down optimisticUpdate={optimisticUpdate}
|
2023-12-20 00:15:08 +00:00
|
|
|
>
|
|
|
|
<AccordianItem
|
|
|
|
header='what is a downzap?' body={
|
|
|
|
<ul>
|
|
|
|
<li>downzaps are just like zaps but cause items to lose ranking position</li>
|
|
|
|
<li>downzaps also reduce trust between you and whoever zaps it so you'll see less of what they zap in the future</li>
|
|
|
|
<li>all sats from downzaps go to rewards</li>
|
|
|
|
</ul>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</ItemAct>)
|
2023-02-16 22:23:59 +00:00
|
|
|
} catch (error) {
|
2023-12-20 00:15:08 +00:00
|
|
|
toaster.danger('failed to downzap item')
|
2023-02-16 22:23:59 +00:00
|
|
|
}
|
|
|
|
}}
|
2023-12-20 01:55:19 +00:00
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</As>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2024-05-28 17:18:54 +00:00
|
|
|
export default function DontLikeThisDropdownItem ({ item }) {
|
2023-12-20 01:55:19 +00:00
|
|
|
return (
|
|
|
|
<DownZapper
|
|
|
|
As={Dropdown.Item}
|
2024-05-28 17:18:54 +00:00
|
|
|
item={item}
|
2023-02-16 22:23:59 +00:00
|
|
|
>
|
2023-12-20 00:15:08 +00:00
|
|
|
<span className='text-danger'>downzap</span>
|
2023-12-20 01:55:19 +00:00
|
|
|
</DownZapper>
|
2022-09-21 19:57:36 +00:00
|
|
|
)
|
|
|
|
}
|
2023-12-23 20:26:16 +00:00
|
|
|
|
|
|
|
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 (
|
|
|
|
<Dropdown.Item onClick={async () => {
|
|
|
|
try {
|
|
|
|
await toggleOutlaw({ variables: { id: item.id } })
|
|
|
|
} catch {
|
|
|
|
toaster.danger('failed to outlaw')
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
toaster.success('item outlawed')
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
outlaw
|
|
|
|
</Dropdown.Item>
|
|
|
|
)
|
|
|
|
}
|