Skip to main content
Glama
DeleteTask.tsx2.31 kB
// SPDX-FileCopyrightText: Copyright Orangebot, Inc. and Medplum contributors // SPDX-License-Identifier: Apache-2.0 import { Alert, Button, Group, Modal } from '@mantine/core'; import { useDisclosure } from '@mantine/hooks'; import { notifications } from '@mantine/notifications'; import { normalizeErrorString } from '@medplum/core'; import type { MedplumClient } from '@medplum/core'; import type { Task } from '@medplum/fhirtypes'; import { useMedplum } from '@medplum/react'; import { IconAlertCircle, IconCircleCheck, IconCircleOff } from '@tabler/icons-react'; import type { JSX } from 'react'; import { useNavigate } from 'react-router'; import type { NavigateFunction } from 'react-router'; interface DeleteTaskProps { readonly task: Task; readonly onChange: (updatedTask: Task) => void; } export function DeleteTask(props: DeleteTaskProps): JSX.Element { const medplum = useMedplum(); const navigate = useNavigate(); const [opened, { toggle, close }] = useDisclosure(false); const handleDelete = async (task: Task, medplum: MedplumClient, navigate: NavigateFunction): Promise<void> => { // Get the task id const taskId = task.id as string; try { // Delete the task and navigate back to the main page await medplum.deleteResource('Task', taskId); notifications.show({ icon: <IconCircleCheck />, title: 'Success', message: 'Task deleted', }); navigate('/Task')?.catch(console.error); } catch (error) { notifications.show({ color: 'red', icon: <IconCircleOff />, title: 'Error', message: normalizeErrorString(error), }); } }; return ( <div> <Button fullWidth onClick={toggle} color="red"> Delete Task </Button> <Modal opened={opened} onClose={close} withCloseButton={false}> <Alert color="red" title="Warning" icon={<IconAlertCircle />}> Are you sure you want to delete this task? <Group> <Button onClick={() => handleDelete(props.task, medplum, navigate)} color="red"> Yes, Delete </Button> <Button onClick={close} color="red" variant="outline"> Cancel </Button> </Group> </Alert> </Modal> </div> ); }

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/medplum/medplum'

If you have feedback or need assistance with the MCP directory API, please join our Discord server