74 lines
1.9 KiB
TypeScript
74 lines
1.9 KiB
TypeScript
import styled from '@emotion/styled';
|
|
|
|
import {
|
|
Checkbox,
|
|
CheckboxShape,
|
|
} from '@/ui/input/checkbox/components/Checkbox';
|
|
import { OverflowingTextWithTooltip } from '@/ui/tooltip/OverflowingTextWithTooltip';
|
|
import { ActivityType } from '~/generated/graphql';
|
|
|
|
const StyledTitleContainer = styled.div`
|
|
color: ${({ theme }) => theme.font.color.primary};
|
|
display: flex;
|
|
flex-direction: row;
|
|
font-weight: ${({ theme }) => theme.font.weight.medium};
|
|
gap: ${({ theme }) => theme.spacing(2)};
|
|
line-height: ${({ theme }) => theme.text.lineHeight.lg};
|
|
|
|
width: 100%;
|
|
`;
|
|
|
|
const StyledTitleText = styled.div<{
|
|
completed?: boolean;
|
|
hasCheckbox?: boolean;
|
|
}>`
|
|
text-decoration: ${({ completed }) => (completed ? 'line-through' : 'none')};
|
|
width: ${({ hasCheckbox, theme }) =>
|
|
!hasCheckbox ? '100%;' : `calc(100% - ${theme.spacing(5)});`};
|
|
`;
|
|
|
|
const StyledCheckboxContainer = styled.div<{ hasCheckbox?: boolean }>`
|
|
align-items: center;
|
|
display: flex;
|
|
justify-content: center;
|
|
`;
|
|
|
|
type OwnProps = {
|
|
title: string;
|
|
completed?: boolean;
|
|
type: ActivityType;
|
|
onCompletionChange?: (value: boolean) => void;
|
|
};
|
|
|
|
export function TimelineActivityTitle({
|
|
title,
|
|
completed,
|
|
type,
|
|
onCompletionChange,
|
|
}: OwnProps) {
|
|
return (
|
|
<StyledTitleContainer>
|
|
{type === ActivityType.Task && (
|
|
<StyledCheckboxContainer
|
|
onClick={(event) => {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
onCompletionChange?.(!completed);
|
|
}}
|
|
>
|
|
<Checkbox
|
|
checked={completed ?? false}
|
|
shape={CheckboxShape.Rounded}
|
|
/>
|
|
</StyledCheckboxContainer>
|
|
)}
|
|
<StyledTitleText
|
|
completed={completed}
|
|
hasCheckbox={type === ActivityType.Task}
|
|
>
|
|
<OverflowingTextWithTooltip text={title ? title : '(No title)'} />
|
|
</StyledTitleText>
|
|
</StyledTitleContainer>
|
|
);
|
|
}
|