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,20 +1,25 @@
|
||||
import { useRecoilValue } from 'recoil';
|
||||
|
||||
import { usePrepareFindManyActivitiesQuery } from '@/activities/hooks/usePrepareFindManyActivitiesQuery';
|
||||
import { objectShowPageTargetableObjectState } from '@/activities/timeline/states/objectShowPageTargetableObjectIdState';
|
||||
import { Activity } from '@/activities/types/Activity';
|
||||
import { objectShowPageTargetableObjectState } from '@/activities/timelineActivities/states/objectShowPageTargetableObjectIdState';
|
||||
import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular';
|
||||
import { isDefined } from '~/utils/isDefined';
|
||||
|
||||
// This hook should only be executed if the normalized cache is up-to-date
|
||||
// It will take a targetableObject and prepare the queries for the activities
|
||||
// based on the activityTargets of the targetableObject
|
||||
export const useRefreshShowPageFindManyActivitiesQueries = () => {
|
||||
export const useRefreshShowPageFindManyActivitiesQueries = ({
|
||||
activityObjectNameSingular,
|
||||
}: {
|
||||
activityObjectNameSingular: CoreObjectNameSingular;
|
||||
}) => {
|
||||
const objectShowPageTargetableObject = useRecoilValue(
|
||||
objectShowPageTargetableObjectState,
|
||||
);
|
||||
|
||||
const { prepareFindManyActivitiesQuery } =
|
||||
usePrepareFindManyActivitiesQuery();
|
||||
const { prepareFindManyActivitiesQuery } = usePrepareFindManyActivitiesQuery({
|
||||
activityObjectNameSingular,
|
||||
});
|
||||
|
||||
const refreshShowPageFindManyActivitiesQueries = () => {
|
||||
if (isDefined(objectShowPageTargetableObject)) {
|
||||
@ -24,21 +29,12 @@ export const useRefreshShowPageFindManyActivitiesQueries = () => {
|
||||
prepareFindManyActivitiesQuery({
|
||||
targetableObject: objectShowPageTargetableObject,
|
||||
additionalFilter: {
|
||||
completedAt: { is: 'NULL' },
|
||||
type: { eq: 'Task' },
|
||||
},
|
||||
shouldActivityBeExcluded: (activity: Activity) => {
|
||||
return activity.type !== 'Task';
|
||||
status: { eq: 'TODO' },
|
||||
},
|
||||
});
|
||||
prepareFindManyActivitiesQuery({
|
||||
targetableObject: objectShowPageTargetableObject,
|
||||
additionalFilter: {
|
||||
type: { eq: 'Note' },
|
||||
},
|
||||
shouldActivityBeExcluded: (activity: Activity) => {
|
||||
return activity.type !== 'Note';
|
||||
},
|
||||
additionalFilter: {},
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user