Activity as standard object (#6219)
In this PR I layout the first steps to migrate Activity to a traditional Standard objects Since this is a big transition, I'd rather split it into several deployments / PRs <img width="1512" alt="image" src="https://github.com/user-attachments/assets/012e2bbf-9d1b-4723-aaf6-269ef588b050"> --------- Co-authored-by: Charles Bochet <charles@twenty.com> Co-authored-by: bosiraphael <71827178+bosiraphael@users.noreply.github.com> Co-authored-by: Weiko <corentin@twenty.com> Co-authored-by: Faisal-imtiyaz123 <142205282+Faisal-imtiyaz123@users.noreply.github.com> Co-authored-by: Prateek Jain <prateekj1171998@gmail.com>
This commit is contained in:
@ -1,9 +1,11 @@
|
||||
import { useApolloClient } from '@apollo/client';
|
||||
|
||||
import { findActivitiesOperationSignatureFactory } from '@/activities/graphql/operation-signatures/factories/findActivitiesOperationSignatureFactory';
|
||||
import { Activity } from '@/activities/types/Activity';
|
||||
import { ActivityTarget } from '@/activities/types/ActivityTarget';
|
||||
import { ActivityTargetableObject } from '@/activities/types/ActivityTargetableEntity';
|
||||
import { Note } from '@/activities/types/Note';
|
||||
import { NoteTarget } from '@/activities/types/NoteTarget';
|
||||
import { Task } from '@/activities/types/Task';
|
||||
import { TaskTarget } from '@/activities/types/TaskTarget';
|
||||
import { useObjectMetadataItem } from '@/object-metadata/hooks/useObjectMetadataItem';
|
||||
import { useObjectMetadataItems } from '@/object-metadata/hooks/useObjectMetadataItems';
|
||||
import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular';
|
||||
@ -14,14 +16,18 @@ import { ObjectRecord } from '@/object-record/types/ObjectRecord';
|
||||
import { sortByAscString } from '~/utils/array/sortByAscString';
|
||||
import { isDefined } from '~/utils/isDefined';
|
||||
|
||||
export const usePrepareFindManyActivitiesQuery = () => {
|
||||
export const usePrepareFindManyActivitiesQuery = ({
|
||||
activityObjectNameSingular,
|
||||
}: {
|
||||
activityObjectNameSingular: CoreObjectNameSingular;
|
||||
}) => {
|
||||
const { objectMetadataItem: objectMetadataItemActivity } =
|
||||
useObjectMetadataItem({
|
||||
objectNameSingular: CoreObjectNameSingular.Activity,
|
||||
objectNameSingular: activityObjectNameSingular,
|
||||
});
|
||||
|
||||
const getActivityFromCache = useGetRecordFromCache({
|
||||
objectNameSingular: CoreObjectNameSingular.Activity,
|
||||
objectNameSingular: activityObjectNameSingular,
|
||||
});
|
||||
|
||||
const cache = useApolloClient().cache;
|
||||
@ -39,7 +45,7 @@ export const usePrepareFindManyActivitiesQuery = () => {
|
||||
}: {
|
||||
additionalFilter?: Record<string, unknown>;
|
||||
targetableObject: ActivityTargetableObject;
|
||||
shouldActivityBeExcluded?: (activityTarget: Activity) => boolean;
|
||||
shouldActivityBeExcluded?: (activityTarget: Task | Note) => boolean;
|
||||
}) => {
|
||||
const targetableObjectMetadataItem = objectMetadataItems.find(
|
||||
(objectMetadataItem) =>
|
||||
@ -60,8 +66,10 @@ export const usePrepareFindManyActivitiesQuery = () => {
|
||||
cache,
|
||||
});
|
||||
|
||||
const activityTargets: ActivityTarget[] =
|
||||
targetableObjectRecord?.activityTargets ?? [];
|
||||
const activityTargets: (TaskTarget | NoteTarget)[] =
|
||||
targetableObjectRecord?.taskTargets ??
|
||||
targetableObjectRecord?.noteTargets ??
|
||||
[];
|
||||
|
||||
const activityTargetIds = [
|
||||
...new Set(
|
||||
@ -71,7 +79,7 @@ export const usePrepareFindManyActivitiesQuery = () => {
|
||||
),
|
||||
];
|
||||
|
||||
const activities: Activity[] = activityTargetIds
|
||||
const activities: (Task | Note)[] = activityTargetIds
|
||||
.map((activityTargetId) => {
|
||||
const activityTarget = activityTargets.find(
|
||||
(activityTarget) => activityTarget.id === activityTargetId,
|
||||
@ -81,7 +89,7 @@ export const usePrepareFindManyActivitiesQuery = () => {
|
||||
return undefined;
|
||||
}
|
||||
|
||||
return getActivityFromCache<Activity>(activityTarget.activityId);
|
||||
return getActivityFromCache<Task | Note>(activityTarget.activityId);
|
||||
})
|
||||
.filter(isDefined);
|
||||
|
||||
@ -103,7 +111,10 @@ export const usePrepareFindManyActivitiesQuery = () => {
|
||||
});
|
||||
|
||||
const FIND_ACTIVITIES_OPERATION_SIGNATURE =
|
||||
findActivitiesOperationSignatureFactory({ objectMetadataItems });
|
||||
findActivitiesOperationSignatureFactory({
|
||||
objectNameSingular: activityObjectNameSingular,
|
||||
objectMetadataItems,
|
||||
});
|
||||
|
||||
upsertFindManyActivitiesInCache({
|
||||
objectRecordsToOverwrite: filteredActivities,
|
||||
|
||||
Reference in New Issue
Block a user