* WIP * WIP * POC working on hard coded completedAt field * Finished isRecordMatchingFilter, mock of pg_graphql filtering mechanism * Fixed and cleaned * Unregister unused optimistic effects * Fix lint * Fixes from review --------- Co-authored-by: Charles Bochet <charles@twenty.com>
30 lines
740 B
TypeScript
30 lines
740 B
TypeScript
import { useCallback } from 'react';
|
|
|
|
import { Activity } from '@/activities/types/Activity';
|
|
import { useUpdateOneRecord } from '@/object-record/hooks/useUpdateOneRecord';
|
|
|
|
type Task = Pick<Activity, 'id' | 'completedAt'>;
|
|
|
|
export const useCompleteTask = (task: Task) => {
|
|
const { updateOneRecord: updateOneActivity } = useUpdateOneRecord<Activity>({
|
|
objectNameSingular: 'activity',
|
|
});
|
|
|
|
const completeTask = useCallback(
|
|
async (value: boolean) => {
|
|
const completedAt = value ? new Date().toISOString() : null;
|
|
await updateOneActivity?.({
|
|
idToUpdate: task.id,
|
|
input: {
|
|
completedAt,
|
|
},
|
|
});
|
|
},
|
|
[task.id, updateOneActivity],
|
|
);
|
|
|
|
return {
|
|
completeTask,
|
|
};
|
|
};
|