103 lines
2.6 KiB
JavaScript
103 lines
2.6 KiB
JavaScript
|
import { useMutation } from '@apollo/client'
|
||
|
import { gql } from 'apollo-server-micro'
|
||
|
import { useState } from 'react'
|
||
|
import { Alert, Button, Dropdown } from 'react-bootstrap'
|
||
|
import { useShowModal } from './modal'
|
||
|
import MoreIcon from '../svgs/more-fill.svg'
|
||
|
|
||
|
export default function Delete ({ itemId, children, onDelete }) {
|
||
|
const showModal = useShowModal()
|
||
|
|
||
|
const [deleteItem] = useMutation(
|
||
|
gql`
|
||
|
mutation deleteItem($id: ID!) {
|
||
|
deleteItem(id: $id) {
|
||
|
text
|
||
|
title
|
||
|
url
|
||
|
pollCost
|
||
|
deletedAt
|
||
|
}
|
||
|
}`, {
|
||
|
update (cache, { data: { deleteItem } }) {
|
||
|
cache.modify({
|
||
|
id: `Item:${itemId}`,
|
||
|
fields: {
|
||
|
text: () => deleteItem.text,
|
||
|
title: () => deleteItem.title,
|
||
|
url: () => deleteItem.url,
|
||
|
pollCost: () => deleteItem.pollCost,
|
||
|
deletedAt: () => deleteItem.deletedAt
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
)
|
||
|
return (
|
||
|
<span
|
||
|
className='pointer' onClick={() => {
|
||
|
showModal(onClose => {
|
||
|
return (
|
||
|
<DeleteConfirm
|
||
|
onConfirm={async () => {
|
||
|
const { error } = await deleteItem({ variables: { id: itemId } })
|
||
|
if (error) {
|
||
|
throw new Error({ message: error.toString() })
|
||
|
}
|
||
|
if (onDelete) {
|
||
|
onDelete()
|
||
|
}
|
||
|
onClose()
|
||
|
}}
|
||
|
/>
|
||
|
)
|
||
|
})
|
||
|
}}
|
||
|
>{children}
|
||
|
</span>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
function DeleteConfirm ({ onConfirm }) {
|
||
|
const [error, setError] = useState()
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
{error && <Alert variant='danger' onClose={() => setError(undefined)} dismissible>{error}</Alert>}
|
||
|
<p className='font-weight-bolder'>Are you sure? This is a gone forever kind of delete.</p>
|
||
|
<div className='d-flex justify-content-end'>
|
||
|
<Button
|
||
|
variant='danger' onClick={async () => {
|
||
|
try {
|
||
|
await onConfirm()
|
||
|
} catch (e) {
|
||
|
setError(e.message || e)
|
||
|
}
|
||
|
}}
|
||
|
>delete
|
||
|
</Button>
|
||
|
</div>
|
||
|
</>
|
||
|
)
|
||
|
}
|
||
|
|
||
|
export function DeleteDropdown (props) {
|
||
|
return (
|
||
|
<Dropdown className='pointer' as='span'>
|
||
|
<Dropdown.Toggle variant='success' id='dropdown-basic' as='a'>
|
||
|
<MoreIcon className='fill-grey ml-1' height={16} width={16} />
|
||
|
</Dropdown.Toggle>
|
||
|
|
||
|
<Dropdown.Menu>
|
||
|
<Delete {...props}>
|
||
|
<Dropdown.Item
|
||
|
className='text-center'
|
||
|
>
|
||
|
delete
|
||
|
</Dropdown.Item>
|
||
|
</Delete>
|
||
|
</Dropdown.Menu>
|
||
|
</Dropdown>
|
||
|
)
|
||
|
}
|