@ -1,3 +1,4 @@
|
|||||||
|
import { isNonEmptyString } from '@sniptt/guards';
|
||||||
import { useRecoilState, useRecoilValue } from 'recoil';
|
import { useRecoilState, useRecoilValue } from 'recoil';
|
||||||
|
|
||||||
import { Activity, ActivityType } from '@/activities/types/Activity';
|
import { Activity, ActivityType } from '@/activities/types/Activity';
|
||||||
@ -47,7 +48,10 @@ export const useOpenCreateActivityDrawer = () => {
|
|||||||
|
|
||||||
const createdActivity = await createOneActivity?.({
|
const createdActivity = await createOneActivity?.({
|
||||||
authorId: currentWorkspaceMember?.id,
|
authorId: currentWorkspaceMember?.id,
|
||||||
assigneeId: assigneeId ?? currentWorkspaceMember?.id,
|
assigneeId:
|
||||||
|
assigneeId ?? isNonEmptyString(currentWorkspaceMember?.id)
|
||||||
|
? currentWorkspaceMember?.id
|
||||||
|
: undefined,
|
||||||
type: type,
|
type: type,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@ -1,3 +1,5 @@
|
|||||||
|
import { isNonEmptyString } from '@sniptt/guards';
|
||||||
|
|
||||||
import { useOpenCreateActivityDrawer } from '@/activities/hooks/useOpenCreateActivityDrawer';
|
import { useOpenCreateActivityDrawer } from '@/activities/hooks/useOpenCreateActivityDrawer';
|
||||||
import { PageAddButton } from '@/ui/layout/page/PageAddButton';
|
import { PageAddButton } from '@/ui/layout/page/PageAddButton';
|
||||||
import { useFilter } from '@/ui/object/object-filter-dropdown/hooks/useFilter';
|
import { useFilter } from '@/ui/object/object-filter-dropdown/hooks/useFilter';
|
||||||
@ -9,7 +11,9 @@ export const PageAddTaskButton = () => {
|
|||||||
const handleClick = () => {
|
const handleClick = () => {
|
||||||
openCreateActivity({
|
openCreateActivity({
|
||||||
type: 'Task',
|
type: 'Task',
|
||||||
assigneeId: selectedFilter?.value,
|
assigneeId: isNonEmptyString(selectedFilter?.value)
|
||||||
|
? selectedFilter?.value
|
||||||
|
: undefined,
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -1,21 +1,26 @@
|
|||||||
|
import { isNonEmptyString } from '@sniptt/guards';
|
||||||
import { DateTime } from 'luxon';
|
import { DateTime } from 'luxon';
|
||||||
|
import { undefined } from 'zod';
|
||||||
|
|
||||||
import { Activity } from '@/activities/types/Activity';
|
import { Activity } from '@/activities/types/Activity';
|
||||||
import { ActivityTargetableEntity } from '@/activities/types/ActivityTargetableEntity';
|
import { ActivityTargetableEntity } from '@/activities/types/ActivityTargetableEntity';
|
||||||
import { useFindManyObjectRecords } from '@/object-record/hooks/useFindManyObjectRecords';
|
import { useFindManyObjectRecords } from '@/object-record/hooks/useFindManyObjectRecords';
|
||||||
import { useFilter } from '@/ui/object/object-filter-dropdown/hooks/useFilter';
|
import { useFilter } from '@/ui/object/object-filter-dropdown/hooks/useFilter';
|
||||||
import { parseDate } from '~/utils/date-utils';
|
import { parseDate } from '~/utils/date-utils';
|
||||||
|
import { isDefined } from '~/utils/isDefined';
|
||||||
|
|
||||||
export const useTasks = (entity?: ActivityTargetableEntity) => {
|
export const useTasks = (entity?: ActivityTargetableEntity) => {
|
||||||
const { selectedFilter } = useFilter();
|
const { selectedFilter } = useFilter();
|
||||||
|
|
||||||
const { objects: activityTargets } = useFindManyObjectRecords({
|
const { objects: activityTargets } = useFindManyObjectRecords({
|
||||||
objectNamePlural: 'activityTargets',
|
objectNamePlural: 'activityTargets',
|
||||||
filter: {
|
filter: isDefined(entity)
|
||||||
[entity?.type === 'Company' ? 'companyId' : 'personId']: {
|
? {
|
||||||
eq: entity?.id,
|
[entity?.type === 'Company' ? 'companyId' : 'personId']: {
|
||||||
},
|
eq: entity?.id,
|
||||||
},
|
},
|
||||||
|
}
|
||||||
|
: undefined,
|
||||||
});
|
});
|
||||||
|
|
||||||
const { objects: completeTasksData } = useFindManyObjectRecords({
|
const { objects: completeTasksData } = useFindManyObjectRecords({
|
||||||
@ -23,10 +28,19 @@ export const useTasks = (entity?: ActivityTargetableEntity) => {
|
|||||||
skip: !entity && !selectedFilter,
|
skip: !entity && !selectedFilter,
|
||||||
filter: {
|
filter: {
|
||||||
completedAt: { is: 'NOT_NULL' },
|
completedAt: { is: 'NOT_NULL' },
|
||||||
id: {
|
id: isDefined(entity)
|
||||||
in: activityTargets?.map((activityTarget) => activityTarget.activityId),
|
? {
|
||||||
},
|
in: activityTargets?.map(
|
||||||
|
(activityTarget) => activityTarget.activityId,
|
||||||
|
),
|
||||||
|
}
|
||||||
|
: undefined,
|
||||||
type: { eq: 'Task' },
|
type: { eq: 'Task' },
|
||||||
|
assigneeId: isNonEmptyString(selectedFilter?.value)
|
||||||
|
? {
|
||||||
|
eq: selectedFilter?.value,
|
||||||
|
}
|
||||||
|
: undefined,
|
||||||
},
|
},
|
||||||
orderBy: {
|
orderBy: {
|
||||||
createdAt: 'DescNullsFirst',
|
createdAt: 'DescNullsFirst',
|
||||||
@ -38,10 +52,19 @@ export const useTasks = (entity?: ActivityTargetableEntity) => {
|
|||||||
skip: !entity && !selectedFilter,
|
skip: !entity && !selectedFilter,
|
||||||
filter: {
|
filter: {
|
||||||
completedAt: { is: 'NULL' },
|
completedAt: { is: 'NULL' },
|
||||||
id: {
|
id: isDefined(entity)
|
||||||
in: activityTargets?.map((activityTarget) => activityTarget.activityId),
|
? {
|
||||||
},
|
in: activityTargets?.map(
|
||||||
|
(activityTarget) => activityTarget.activityId,
|
||||||
|
),
|
||||||
|
}
|
||||||
|
: undefined,
|
||||||
type: { eq: 'Task' },
|
type: { eq: 'Task' },
|
||||||
|
assigneeId: isNonEmptyString(selectedFilter?.value)
|
||||||
|
? {
|
||||||
|
eq: selectedFilter?.value,
|
||||||
|
}
|
||||||
|
: undefined,
|
||||||
},
|
},
|
||||||
orderBy: {
|
orderBy: {
|
||||||
createdAt: 'DescNullsFirst',
|
createdAt: 'DescNullsFirst',
|
||||||
|
|||||||
Reference in New Issue
Block a user