import { useTheme } from '@emotion/react'; import styled from '@emotion/styled'; import { ActivityTargetChips } from '@/activities/components/ActivityTargetChips'; import { useOpenActivityRightDrawer } from '@/activities/hooks/useOpenActivityRightDrawer'; import { IconCalendar, IconComment } from '@/ui/icon'; import { Checkbox, CheckboxShape, } from '@/ui/input/checkbox/components/Checkbox'; import { OverflowingTextWithTooltip } from '@/ui/tooltip/OverflowingTextWithTooltip'; import { beautifyExactDate, hasDatePassed } from '~/utils/date-utils'; import { TaskForList } from '../../types/TaskForList'; import { useCompleteTask } from '../hooks/useCompleteTask'; const StyledContainer = styled.div` align-items: center; align-self: stretch; border-bottom: 1px solid ${({ theme }) => theme.border.color.light}; cursor: pointer; display: inline-flex; height: ${({ theme }) => theme.spacing(12)}; min-width: calc(100% - ${({ theme }) => theme.spacing(8)}); padding: 0 ${({ theme }) => theme.spacing(4)}; `; const StyledTaskBody = styled.div` color: ${({ theme }) => theme.font.color.tertiary}; display: flex; flex-direction: row; flex-grow: 1; width: 1px; `; const StyledTaskTitle = styled.div<{ completed: boolean; }>` color: ${({ theme }) => theme.font.color.primary}; font-weight: ${({ theme }) => theme.font.weight.medium}; padding: 0 ${({ theme }) => theme.spacing(2)}; text-decoration: ${({ completed }) => (completed ? 'line-through' : 'none')}; `; const StyledCommentIcon = styled.div` align-items: center; color: ${({ theme }) => theme.font.color.light}; display: flex; margin-left: ${({ theme }) => theme.spacing(2)}; `; const StyledDueDate = styled.div<{ isPast: boolean; }>` align-items: center; color: ${({ theme, isPast }) => isPast ? theme.font.color.danger : theme.font.color.secondary}; display: flex; gap: ${({ theme }) => theme.spacing(1)}; padding-left: ${({ theme }) => theme.spacing(2)}; `; const StyledFieldsContainer = styled.div` display: flex; `; export function TaskRow({ task }: { task: TaskForList }) { const theme = useTheme(); const openActivityRightDrawer = useOpenActivityRightDrawer(); const body = JSON.parse(task.body ?? '{}')[0]?.content[0]?.text; const { completeTask } = useCompleteTask(task); return ( { openActivityRightDrawer(task.id); }} >
{ e.stopPropagation(); }} >
{task.title ?? 'Task Title'} {task.comments && task.comments.length > 0 && ( )} {task.dueAt && beautifyExactDate(task.dueAt)}
); }