- New task dropdown wasn't using the proper dropdown id - Action menu triggered by context menu (right click) on table cell was listening in edit mode.
120 lines
3.7 KiB
TypeScript
120 lines
3.7 KiB
TypeScript
import styled from '@emotion/styled';
|
|
import {
|
|
Button,
|
|
IconButton,
|
|
IconCheckbox,
|
|
IconNotes,
|
|
IconPlus,
|
|
MenuItem,
|
|
} from 'twenty-ui';
|
|
|
|
import { useOpenCreateActivityDrawer } from '@/activities/hooks/useOpenCreateActivityDrawer';
|
|
import { ActivityTargetableObject } from '@/activities/types/ActivityTargetableEntity';
|
|
import { PageHotkeyScope } from '@/types/PageHotkeyScope';
|
|
import { DropdownMenuItemsContainer } from '@/ui/layout/dropdown/components/DropdownMenuItemsContainer';
|
|
import { useDropdown } from '@/ui/layout/dropdown/hooks/useDropdown';
|
|
import { SHOW_PAGE_ADD_BUTTON_DROPDOWN_ID } from '@/ui/layout/show-page/constants/ShowPageAddButtonDropdownId';
|
|
|
|
import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular';
|
|
import { isWorkflowSubObjectMetadata } from '@/object-metadata/utils/isWorkflowSubObjectMetadata';
|
|
import { useIsFeatureEnabled } from '@/workspace/hooks/useIsFeatureEnabled';
|
|
import { Dropdown } from '../../dropdown/components/Dropdown';
|
|
import { DropdownMenu } from '../../dropdown/components/DropdownMenu';
|
|
|
|
const StyledContainer = styled.div`
|
|
z-index: 1;
|
|
`;
|
|
|
|
export const ShowPageAddButton = ({
|
|
activityTargetObject,
|
|
}: {
|
|
activityTargetObject: ActivityTargetableObject;
|
|
}) => {
|
|
const { closeDropdown } = useDropdown(SHOW_PAGE_ADD_BUTTON_DROPDOWN_ID);
|
|
|
|
const openNote = useOpenCreateActivityDrawer({
|
|
activityObjectNameSingular: CoreObjectNameSingular.Note,
|
|
});
|
|
const openTask = useOpenCreateActivityDrawer({
|
|
activityObjectNameSingular: CoreObjectNameSingular.Task,
|
|
});
|
|
|
|
const handleSelect = (objectNameSingular: CoreObjectNameSingular) => {
|
|
if (objectNameSingular === CoreObjectNameSingular.Note) {
|
|
openNote({
|
|
targetableObjects: [activityTargetObject],
|
|
});
|
|
} else if (objectNameSingular === CoreObjectNameSingular.Task) {
|
|
openTask({
|
|
targetableObjects: [activityTargetObject],
|
|
});
|
|
}
|
|
|
|
closeDropdown();
|
|
};
|
|
|
|
const isPageHeaderV2Enabled = useIsFeatureEnabled(
|
|
'IS_PAGE_HEADER_V2_ENABLED',
|
|
);
|
|
|
|
if (
|
|
activityTargetObject.targetObjectNameSingular ===
|
|
CoreObjectNameSingular.Task ||
|
|
activityTargetObject.targetObjectNameSingular ===
|
|
CoreObjectNameSingular.Note ||
|
|
isWorkflowSubObjectMetadata(activityTargetObject.targetObjectNameSingular)
|
|
) {
|
|
return;
|
|
}
|
|
|
|
return (
|
|
<StyledContainer>
|
|
<Dropdown
|
|
dropdownId={SHOW_PAGE_ADD_BUTTON_DROPDOWN_ID}
|
|
clickableComponent={
|
|
isPageHeaderV2Enabled ? (
|
|
<Button
|
|
Icon={IconPlus}
|
|
dataTestId="add-button"
|
|
size="small"
|
|
variant="secondary"
|
|
accent="default"
|
|
title="New note/task"
|
|
ariaLabel="New note/task"
|
|
/>
|
|
) : (
|
|
<IconButton
|
|
Icon={IconPlus}
|
|
size="medium"
|
|
dataTestId="add-showpage-button"
|
|
accent="default"
|
|
variant="secondary"
|
|
/>
|
|
)
|
|
}
|
|
dropdownComponents={
|
|
<DropdownMenu>
|
|
<DropdownMenuItemsContainer>
|
|
<MenuItem
|
|
onClick={() => handleSelect(CoreObjectNameSingular.Note)}
|
|
accent="default"
|
|
LeftIcon={IconNotes}
|
|
text="Note"
|
|
/>
|
|
<MenuItem
|
|
onClick={() => handleSelect(CoreObjectNameSingular.Task)}
|
|
accent="default"
|
|
LeftIcon={IconCheckbox}
|
|
text="Task"
|
|
/>
|
|
</DropdownMenuItemsContainer>
|
|
</DropdownMenu>
|
|
}
|
|
dropdownHotkeyScope={{
|
|
scope: PageHotkeyScope.ShowPage,
|
|
}}
|
|
/>
|
|
</StyledContainer>
|
|
);
|
|
};
|