diff --git a/packages/twenty-front/src/modules/object-record/record-show/record-detail-section/components/RecordDetailRelationRecordsListItem.tsx b/packages/twenty-front/src/modules/object-record/record-show/record-detail-section/components/RecordDetailRelationRecordsListItem.tsx index 6c9c2ed81d..cba3ca9c1c 100644 --- a/packages/twenty-front/src/modules/object-record/record-show/record-detail-section/components/RecordDetailRelationRecordsListItem.tsx +++ b/packages/twenty-front/src/modules/object-record/record-show/record-detail-section/components/RecordDetailRelationRecordsListItem.tsx @@ -1,7 +1,7 @@ import { css } from '@emotion/react'; import styled from '@emotion/styled'; import { motion } from 'framer-motion'; -import { useCallback, useContext } from 'react'; +import { useCallback, useContext, useState } from 'react'; import { AnimatedEaseInOut, IconChevronDown, @@ -17,6 +17,7 @@ import { useObjectMetadataItem } from '@/object-metadata/hooks/useObjectMetadata import { useObjectMetadataItems } from '@/object-metadata/hooks/useObjectMetadataItems'; import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular'; import { formatFieldMetadataItemAsColumnDefinition } from '@/object-metadata/utils/formatFieldMetadataItemAsColumnDefinition'; +import { getObjectTypename } from '@/object-record/cache/utils/getObjectTypename'; import { RecordChip } from '@/object-record/components/RecordChip'; import { useDeleteOneRecord } from '@/object-record/hooks/useDeleteOneRecord'; import { useUpdateOneRecord } from '@/object-record/hooks/useUpdateOneRecord'; @@ -39,6 +40,8 @@ import { Dropdown } from '@/ui/layout/dropdown/components/Dropdown'; import { DropdownMenuItemsContainer } from '@/ui/layout/dropdown/components/DropdownMenuItemsContainer'; import { useDropdown } from '@/ui/layout/dropdown/hooks/useDropdown'; import { DropdownScope } from '@/ui/layout/dropdown/scopes/DropdownScope'; +import { ConfirmationModal } from '@/ui/layout/modal/components/ConfirmationModal'; +import { createPortal } from 'react-dom'; import { RelationDefinitionType } from '~/generated-metadata/graphql'; const StyledListItem = styled(RecordDetailRecordsListItem)<{ @@ -94,6 +97,9 @@ export const RecordDetailRelationRecordsListItem = ({ }: RecordDetailRelationRecordsListItemProps) => { const { fieldDefinition } = useContext(FieldContext); + const [isDeleteRelationModalOpen, setIsDeleteRelationModalOpen] = + useState(false); + const { relationFieldMetadataId, relationObjectMetadataNameSingular, @@ -106,6 +112,10 @@ export const RecordDetailRelationRecordsListItem = ({ objectNameSingular: relationObjectMetadataNameSingular, }); + const relationObjectTypeName = getObjectTypename( + relationObjectMetadataNameSingular, + ); + const { objectMetadataItems } = useObjectMetadataItems(); const persistField = usePersistField(); @@ -158,8 +168,13 @@ export const RecordDetailRelationRecordsListItem = ({ }; const handleDelete = async () => { + setIsDeleteRelationModalOpen(true); closeDropdown(); + }; + + const handleConfirmDelete = async () => { await deleteOneRelationRecord(relationRecord.id); + setIsDeleteRelationModalOpen(false); }; const useUpdateOneObjectRecordMutation: RecordUpdateHook = () => { @@ -268,6 +283,24 @@ export const RecordDetailRelationRecordsListItem = ({ )} + {createPortal( + + Are you sure you want to delete this related{' '} + {relationObjectMetadataNameSingular}? +
+ This action will break all its relationships with other objects. + + } + onConfirmClick={handleConfirmDelete} + deleteButtonText={`Delete ${relationObjectTypeName}`} + />, + document.body, + )} ); };