signal-desktop/ts/components/conversation/TimelineFloatingHeader.tsx

54 lines
1.3 KiB
TypeScript
Raw Normal View History

2022-01-26 23:05:26 +00:00
// Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import classNames from 'classnames';
2022-03-09 22:44:57 +00:00
import type { CSSProperties, ReactElement } from 'react';
2022-01-28 18:31:20 +00:00
import React, { useEffect, useState } from 'react';
2022-01-26 23:05:26 +00:00
import type { LocalizerType } from '../../types/Util';
import { TimelineDateHeader } from './TimelineDateHeader';
import { Spinner } from '../Spinner';
export const TimelineFloatingHeader = ({
i18n,
isLoading,
2022-03-09 22:44:57 +00:00
style,
2022-01-26 23:05:26 +00:00
timestamp,
visible,
}: Readonly<{
i18n: LocalizerType;
isLoading: boolean;
2022-03-09 22:44:57 +00:00
style?: CSSProperties;
2022-01-26 23:05:26 +00:00
timestamp: number;
visible: boolean;
2022-01-28 18:31:20 +00:00
}>): ReactElement => {
const [hasRendered, setHasRendered] = useState(false);
useEffect(() => {
setHasRendered(true);
}, []);
return (
2022-01-26 23:05:26 +00:00
<div
className={classNames(
2022-01-28 18:31:20 +00:00
'TimelineFloatingHeader',
`TimelineFloatingHeader--${
visible && hasRendered ? 'visible' : 'hidden'
2022-01-26 23:05:26 +00:00
}`
)}
2022-03-09 22:44:57 +00:00
style={style}
2022-01-26 23:05:26 +00:00
>
2022-01-28 18:31:20 +00:00
<TimelineDateHeader floating i18n={i18n} timestamp={timestamp} />
<div
className={classNames(
'TimelineFloatingHeader__spinner-container',
`TimelineFloatingHeader__spinner-container--${
isLoading ? 'visible' : 'hidden'
}`
)}
>
<Spinner direction="on-background" size="20px" svgSize="small" />
</div>
2022-01-26 23:05:26 +00:00
</div>
2022-01-28 18:31:20 +00:00
);
};