Feat/activity optimistic activities (#4009)
* Fix naming * Fixed cache.evict bug for relation target deletion * Fixed cascade delete activity targets * Working version * Fix * fix * WIP * Fixed optimistic effect target inline cell * Removed openCreateActivityDrawer v1 * Ok for timeline * Removed console.log * Fix update record optimistic effect * Refactored activity queries into useActivities for everything * Fixed bugs * Cleaned * Fix lint --------- Co-authored-by: Charles Bochet <charles@twenty.com>
This commit is contained in:
@ -0,0 +1,25 @@
|
||||
import { ActivityTargetableObject } from '@/activities/types/ActivityTargetableEntity';
|
||||
import { getActivityTargetObjectFieldIdName } from '@/activities/utils/getTargetObjectFilterFieldName';
|
||||
|
||||
export const getActivityTargetsFilter = ({
|
||||
targetableObjects,
|
||||
}: {
|
||||
targetableObjects: ActivityTargetableObject[];
|
||||
}) => {
|
||||
const findManyActivitiyTargetsQueryFilter = Object.fromEntries(
|
||||
targetableObjects.map((targetableObject) => {
|
||||
const targetObjectFieldName = getActivityTargetObjectFieldIdName({
|
||||
nameSingular: targetableObject.targetObjectNameSingular,
|
||||
});
|
||||
|
||||
return [
|
||||
targetObjectFieldName,
|
||||
{
|
||||
eq: targetableObject.id,
|
||||
},
|
||||
];
|
||||
}),
|
||||
);
|
||||
|
||||
return findManyActivitiyTargetsQueryFilter;
|
||||
};
|
||||
@ -13,9 +13,14 @@ import { isDefined } from '~/utils/isDefined';
|
||||
export const useActivityConnectionUtils = () => {
|
||||
const mapConnectionToRecords = useMapConnectionToRecords();
|
||||
|
||||
const makeActivityWithoutConnection = (activityWithConnections: any) => {
|
||||
const makeActivityWithoutConnection = (
|
||||
activityWithConnections: Activity & {
|
||||
activityTargets: ObjectRecordConnection<ActivityTarget>;
|
||||
comments: ObjectRecordConnection<Comment>;
|
||||
},
|
||||
) => {
|
||||
if (!isDefined(activityWithConnections)) {
|
||||
return { activity: null };
|
||||
throw new Error('Activity with connections is not defined');
|
||||
}
|
||||
|
||||
const hasActivityTargetsConnection = isObjectRecordConnection(
|
||||
@ -77,11 +82,13 @@ export const useActivityConnectionUtils = () => {
|
||||
: [];
|
||||
|
||||
const activityTargets = {
|
||||
__typename: 'ActivityTargetConnection',
|
||||
edges: activityTargetEdges,
|
||||
pageInfo: getEmptyPageInfo(),
|
||||
} as ObjectRecordConnection<ActivityTarget>;
|
||||
|
||||
const comments = {
|
||||
__typename: 'CommentConnection',
|
||||
edges: commentEdges,
|
||||
pageInfo: getEmptyPageInfo(),
|
||||
} as ObjectRecordConnection<Comment>;
|
||||
@ -90,6 +97,9 @@ export const useActivityConnectionUtils = () => {
|
||||
...activity,
|
||||
activityTargets,
|
||||
comments,
|
||||
} as Activity & {
|
||||
activityTargets: ObjectRecordConnection<ActivityTarget>;
|
||||
comments: ObjectRecordConnection<Comment>;
|
||||
};
|
||||
|
||||
return { activityWithConnection };
|
||||
|
||||
Reference in New Issue
Block a user