Add company relation for person table (#1612)
* - add company relation for person table * - also for context menu * - fix yarn.lock * - fix newline missing * - fixed tab * fix
This commit is contained in:
@ -15,12 +15,20 @@ export const useOpenCreateActivityDrawerForSelectedRowIds = () => {
|
|||||||
|
|
||||||
const openCreateActivityDrawer = useOpenCreateActivityDrawer();
|
const openCreateActivityDrawer = useOpenCreateActivityDrawer();
|
||||||
|
|
||||||
return (type: ActivityType, entityType: ActivityTargetableEntityType) => {
|
return (
|
||||||
const activityTargetableEntityArray: ActivityTargetableEntity[] =
|
type: ActivityType,
|
||||||
|
entityType: ActivityTargetableEntityType,
|
||||||
|
relatedEntities?: ActivityTargetableEntity[],
|
||||||
|
) => {
|
||||||
|
let activityTargetableEntityArray: ActivityTargetableEntity[] =
|
||||||
selectedRowIds.map((id) => ({
|
selectedRowIds.map((id) => ({
|
||||||
type: entityType,
|
type: entityType,
|
||||||
id,
|
id,
|
||||||
}));
|
}));
|
||||||
|
if (relatedEntities) {
|
||||||
|
activityTargetableEntityArray =
|
||||||
|
activityTargetableEntityArray.concat(relatedEntities);
|
||||||
|
}
|
||||||
openCreateActivityDrawer({
|
openCreateActivityDrawer({
|
||||||
type,
|
type,
|
||||||
targetableEntities: activityTargetableEntityArray,
|
targetableEntities: activityTargetableEntityArray,
|
||||||
|
|||||||
44
front/src/modules/people/hooks/useCreateActivityForPeople.ts
Normal file
44
front/src/modules/people/hooks/useCreateActivityForPeople.ts
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
import { useRecoilCallback, useRecoilValue } from 'recoil';
|
||||||
|
|
||||||
|
import { useOpenCreateActivityDrawerForSelectedRowIds } from '@/activities/hooks/useOpenCreateActivityDrawerForSelectedRowIds';
|
||||||
|
import {
|
||||||
|
ActivityTargetableEntity,
|
||||||
|
ActivityTargetableEntityType,
|
||||||
|
} from '@/activities/types/ActivityTargetableEntity';
|
||||||
|
import { selectedRowIdsSelector } from '@/ui/table/states/selectors/selectedRowIdsSelector';
|
||||||
|
import { tableEntitiesFamilyState } from '@/ui/table/states/tableEntitiesFamilyState';
|
||||||
|
import { ActivityType, Person } from '~/generated/graphql';
|
||||||
|
|
||||||
|
export const useCreateActivityForPeople = () => {
|
||||||
|
const openCreateActivityRightDrawer =
|
||||||
|
useOpenCreateActivityDrawerForSelectedRowIds();
|
||||||
|
const selectedRowIds = useRecoilValue(selectedRowIdsSelector);
|
||||||
|
|
||||||
|
return useRecoilCallback(
|
||||||
|
({ snapshot }) =>
|
||||||
|
(type: ActivityType) => {
|
||||||
|
const relatedEntites: ActivityTargetableEntity[] = [];
|
||||||
|
for (const id of selectedRowIds) {
|
||||||
|
const person = snapshot
|
||||||
|
.getLoadable(tableEntitiesFamilyState(id))
|
||||||
|
.getValue() as Person;
|
||||||
|
if (
|
||||||
|
person?.company?.id &&
|
||||||
|
!relatedEntites.find((x) => x.id === person?.company?.id)
|
||||||
|
) {
|
||||||
|
relatedEntites.push({
|
||||||
|
id: person.company.id,
|
||||||
|
type: ActivityTargetableEntityType.Company,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
openCreateActivityRightDrawer(
|
||||||
|
type,
|
||||||
|
ActivityTargetableEntityType.Person,
|
||||||
|
relatedEntites,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
[selectedRowIds, openCreateActivityRightDrawer],
|
||||||
|
);
|
||||||
|
};
|
||||||
@ -1,8 +1,6 @@
|
|||||||
import { getOperationName } from '@apollo/client/utilities';
|
import { getOperationName } from '@apollo/client/utilities';
|
||||||
import { useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil';
|
import { useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil';
|
||||||
|
|
||||||
import { useOpenCreateActivityDrawerForSelectedRowIds } from '@/activities/hooks/useOpenCreateActivityDrawerForSelectedRowIds';
|
|
||||||
import { ActivityTargetableEntityType } from '@/activities/types/ActivityTargetableEntity';
|
|
||||||
import { contextMenuEntriesState } from '@/ui/context-menu/states/contextMenuEntriesState';
|
import { contextMenuEntriesState } from '@/ui/context-menu/states/contextMenuEntriesState';
|
||||||
import { IconCheckbox, IconNotes, IconTrash } from '@/ui/icon';
|
import { IconCheckbox, IconNotes, IconTrash } from '@/ui/icon';
|
||||||
import { useResetTableRowSelection } from '@/ui/table/hooks/useResetTableRowSelection';
|
import { useResetTableRowSelection } from '@/ui/table/hooks/useResetTableRowSelection';
|
||||||
@ -12,15 +10,12 @@ import { ActivityType, useDeleteManyPersonMutation } from '~/generated/graphql';
|
|||||||
|
|
||||||
import { GET_PEOPLE } from '../graphql/queries/getPeople';
|
import { GET_PEOPLE } from '../graphql/queries/getPeople';
|
||||||
|
|
||||||
|
import { useCreateActivityForPeople } from './useCreateActivityForPeople';
|
||||||
|
|
||||||
export const usePersonTableContextMenuEntries = () => {
|
export const usePersonTableContextMenuEntries = () => {
|
||||||
const setContextMenuEntries = useSetRecoilState(contextMenuEntriesState);
|
const setContextMenuEntries = useSetRecoilState(contextMenuEntriesState);
|
||||||
|
|
||||||
const openCreateActivityRightDrawer =
|
const createActivityForPeople = useCreateActivityForPeople();
|
||||||
useOpenCreateActivityDrawerForSelectedRowIds();
|
|
||||||
|
|
||||||
const handleActivityClick = async (type: ActivityType) => {
|
|
||||||
openCreateActivityRightDrawer(type, ActivityTargetableEntityType.Person);
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectedRowIds = useRecoilValue(selectedRowIdsSelector);
|
const selectedRowIds = useRecoilValue(selectedRowIdsSelector);
|
||||||
const [tableRowIds, setTableRowIds] = useRecoilState(tableRowIdsState);
|
const [tableRowIds, setTableRowIds] = useRecoilState(tableRowIdsState);
|
||||||
@ -60,12 +55,12 @@ export const usePersonTableContextMenuEntries = () => {
|
|||||||
{
|
{
|
||||||
label: 'Note',
|
label: 'Note',
|
||||||
Icon: IconNotes,
|
Icon: IconNotes,
|
||||||
onClick: () => handleActivityClick(ActivityType.Note),
|
onClick: () => createActivityForPeople(ActivityType.Note),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Task',
|
label: 'Task',
|
||||||
Icon: IconCheckbox,
|
Icon: IconCheckbox,
|
||||||
onClick: () => handleActivityClick(ActivityType.Task),
|
onClick: () => createActivityForPeople(ActivityType.Task),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Delete',
|
label: 'Delete',
|
||||||
|
|||||||
@ -1,8 +1,6 @@
|
|||||||
import { getOperationName } from '@apollo/client/utilities';
|
import { getOperationName } from '@apollo/client/utilities';
|
||||||
import { useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil';
|
import { useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil';
|
||||||
|
|
||||||
import { useOpenCreateActivityDrawerForSelectedRowIds } from '@/activities/hooks/useOpenCreateActivityDrawerForSelectedRowIds';
|
|
||||||
import { ActivityTargetableEntityType } from '@/activities/types/ActivityTargetableEntity';
|
|
||||||
import { actionBarEntriesState } from '@/ui/action-bar/states/actionBarEntriesState';
|
import { actionBarEntriesState } from '@/ui/action-bar/states/actionBarEntriesState';
|
||||||
import { IconCheckbox, IconNotes, IconTrash } from '@/ui/icon';
|
import { IconCheckbox, IconNotes, IconTrash } from '@/ui/icon';
|
||||||
import { useResetTableRowSelection } from '@/ui/table/hooks/useResetTableRowSelection';
|
import { useResetTableRowSelection } from '@/ui/table/hooks/useResetTableRowSelection';
|
||||||
@ -12,18 +10,13 @@ import { ActivityType, useDeleteManyPersonMutation } from '~/generated/graphql';
|
|||||||
|
|
||||||
import { GET_PEOPLE } from '../graphql/queries/getPeople';
|
import { GET_PEOPLE } from '../graphql/queries/getPeople';
|
||||||
|
|
||||||
|
import { useCreateActivityForPeople } from './useCreateActivityForPeople';
|
||||||
|
|
||||||
export const usePersonTableActionBarEntries = () => {
|
export const usePersonTableActionBarEntries = () => {
|
||||||
const setActionBarEntries = useSetRecoilState(actionBarEntriesState);
|
|
||||||
|
|
||||||
const openCreateActivityRightDrawer =
|
|
||||||
useOpenCreateActivityDrawerForSelectedRowIds();
|
|
||||||
|
|
||||||
const handleActivityClick = async (type: ActivityType) => {
|
|
||||||
openCreateActivityRightDrawer(type, ActivityTargetableEntityType.Person);
|
|
||||||
};
|
|
||||||
|
|
||||||
const selectedRowIds = useRecoilValue(selectedRowIdsSelector);
|
const selectedRowIds = useRecoilValue(selectedRowIdsSelector);
|
||||||
const [tableRowIds, setTableRowIds] = useRecoilState(tableRowIdsState);
|
const [tableRowIds, setTableRowIds] = useRecoilState(tableRowIdsState);
|
||||||
|
const setActionBarEntries = useSetRecoilState(actionBarEntriesState);
|
||||||
|
const createActivityForPeople = useCreateActivityForPeople();
|
||||||
|
|
||||||
const resetRowSelection = useResetTableRowSelection();
|
const resetRowSelection = useResetTableRowSelection();
|
||||||
|
|
||||||
@ -64,12 +57,12 @@ export const usePersonTableActionBarEntries = () => {
|
|||||||
{
|
{
|
||||||
label: 'Note',
|
label: 'Note',
|
||||||
Icon: IconNotes,
|
Icon: IconNotes,
|
||||||
onClick: () => handleActivityClick(ActivityType.Note),
|
onClick: () => createActivityForPeople(ActivityType.Note),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Task',
|
label: 'Task',
|
||||||
Icon: IconCheckbox,
|
Icon: IconCheckbox,
|
||||||
onClick: () => handleActivityClick(ActivityType.Task),
|
onClick: () => createActivityForPeople(ActivityType.Task),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Delete',
|
label: 'Delete',
|
||||||
|
|||||||
Reference in New Issue
Block a user