@ -21,6 +21,7 @@ import { PageHeader } from '@/ui/layout/page/PageHeader';
|
|||||||
import { ShowPageContainer } from '@/ui/layout/page/ShowPageContainer';
|
import { ShowPageContainer } from '@/ui/layout/page/ShowPageContainer';
|
||||||
import { ShowPageAddButton } from '@/ui/layout/show-page/components/ShowPageAddButton';
|
import { ShowPageAddButton } from '@/ui/layout/show-page/components/ShowPageAddButton';
|
||||||
import { ShowPageLeftContainer } from '@/ui/layout/show-page/components/ShowPageLeftContainer';
|
import { ShowPageLeftContainer } from '@/ui/layout/show-page/components/ShowPageLeftContainer';
|
||||||
|
import { ShowPageMoreButton } from '@/ui/layout/show-page/components/ShowPageMoreButton';
|
||||||
import { ShowPageRightContainer } from '@/ui/layout/show-page/components/ShowPageRightContainer';
|
import { ShowPageRightContainer } from '@/ui/layout/show-page/components/ShowPageRightContainer';
|
||||||
import { ShowPageSummaryCard } from '@/ui/layout/show-page/components/ShowPageSummaryCard';
|
import { ShowPageSummaryCard } from '@/ui/layout/show-page/components/ShowPageSummaryCard';
|
||||||
import { ShowPageRecoilScopeContext } from '@/ui/layout/states/ShowPageRecoilScopeContext';
|
import { ShowPageRecoilScopeContext } from '@/ui/layout/states/ShowPageRecoilScopeContext';
|
||||||
@ -208,6 +209,11 @@ export const RecordShowPage = () => {
|
|||||||
type: objectMetadataType,
|
type: objectMetadataType,
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
<ShowPageMoreButton
|
||||||
|
key="more"
|
||||||
|
recordId={record.id}
|
||||||
|
objectNameSingular={objectNameSingular}
|
||||||
|
/>
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
</PageHeader>
|
</PageHeader>
|
||||||
|
|||||||
@ -0,0 +1,78 @@
|
|||||||
|
import { useNavigate } from 'react-router-dom';
|
||||||
|
import styled from '@emotion/styled';
|
||||||
|
import { useRecoilValue } from 'recoil';
|
||||||
|
|
||||||
|
import { useDeleteOneRecord } from '@/object-record/hooks/useDeleteOneRecord';
|
||||||
|
import { PageHotkeyScope } from '@/types/PageHotkeyScope';
|
||||||
|
import { IconDotsVertical, IconTrash } from '@/ui/display/icon/index';
|
||||||
|
import { IconButton } from '@/ui/input/button/components/IconButton';
|
||||||
|
import { DropdownMenuItemsContainer } from '@/ui/layout/dropdown/components/DropdownMenuItemsContainer';
|
||||||
|
import { useDropdown } from '@/ui/layout/dropdown/hooks/useDropdown';
|
||||||
|
import { MenuItem } from '@/ui/navigation/menu-item/components/MenuItem';
|
||||||
|
import { navigationMemorizedUrlState } from '@/ui/navigation/states/navigationMemorizedUrlState';
|
||||||
|
|
||||||
|
import { Dropdown } from '../../dropdown/components/Dropdown';
|
||||||
|
import { DropdownMenu } from '../../dropdown/components/DropdownMenu';
|
||||||
|
import { DropdownScope } from '../../dropdown/scopes/DropdownScope';
|
||||||
|
|
||||||
|
const StyledContainer = styled.div`
|
||||||
|
z-index: 1;
|
||||||
|
`;
|
||||||
|
|
||||||
|
export const ShowPageMoreButton = ({
|
||||||
|
recordId,
|
||||||
|
objectNameSingular,
|
||||||
|
}: {
|
||||||
|
recordId: string;
|
||||||
|
objectNameSingular: string;
|
||||||
|
}) => {
|
||||||
|
const { closeDropdown, toggleDropdown } = useDropdown({
|
||||||
|
dropdownScopeId: 'more-show-page',
|
||||||
|
});
|
||||||
|
const navigationMemorizedUrl = useRecoilValue(navigationMemorizedUrlState);
|
||||||
|
const navigate = useNavigate();
|
||||||
|
|
||||||
|
const { deleteOneRecord: deleteOneRecord } = useDeleteOneRecord({
|
||||||
|
objectNameSingular,
|
||||||
|
});
|
||||||
|
|
||||||
|
const handleDelete = () => {
|
||||||
|
deleteOneRecord(recordId);
|
||||||
|
closeDropdown();
|
||||||
|
navigate(navigationMemorizedUrl, { replace: true });
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<StyledContainer>
|
||||||
|
<DropdownScope dropdownScopeId="more-show-page">
|
||||||
|
<Dropdown
|
||||||
|
clickableComponent={
|
||||||
|
<IconButton
|
||||||
|
Icon={IconDotsVertical}
|
||||||
|
size="medium"
|
||||||
|
dataTestId="more-showpage-button"
|
||||||
|
accent="default"
|
||||||
|
variant="secondary"
|
||||||
|
onClick={toggleDropdown}
|
||||||
|
/>
|
||||||
|
}
|
||||||
|
dropdownComponents={
|
||||||
|
<DropdownMenu>
|
||||||
|
<DropdownMenuItemsContainer>
|
||||||
|
<MenuItem
|
||||||
|
onClick={handleDelete}
|
||||||
|
accent="danger"
|
||||||
|
LeftIcon={IconTrash}
|
||||||
|
text="Delete"
|
||||||
|
/>
|
||||||
|
</DropdownMenuItemsContainer>
|
||||||
|
</DropdownMenu>
|
||||||
|
}
|
||||||
|
dropdownHotkeyScope={{
|
||||||
|
scope: PageHotkeyScope.ShowPage,
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</DropdownScope>
|
||||||
|
</StyledContainer>
|
||||||
|
);
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user