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

41 lines
1.1 KiB
TypeScript
Raw Normal View History

2020-10-30 20:34:04 +00:00
// Copyright 2018-2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
2018-11-14 19:10:32 +00:00
import React from 'react';
import classNames from 'classnames';
import type { LocalizerType } from '../../types/Util';
2018-11-14 19:10:32 +00:00
export type Props = {
2019-01-14 21:49:58 +00:00
i18n: LocalizerType;
2018-11-14 19:10:32 +00:00
color?: string;
};
2018-11-14 19:10:32 +00:00
2020-09-14 19:51:27 +00:00
export const TypingAnimation = ({ i18n, color }: Props): JSX.Element => (
<div className="module-typing-animation" title={i18n('typingAlt')}>
<div
className={classNames(
'module-typing-animation__dot',
'module-typing-animation__dot--first',
color ? `module-typing-animation__dot--${color}` : null
)}
/>
<div className="module-typing-animation__spacer" />
<div
className={classNames(
'module-typing-animation__dot',
'module-typing-animation__dot--second',
color ? `module-typing-animation__dot--${color}` : null
)}
/>
<div className="module-typing-animation__spacer" />
<div
className={classNames(
'module-typing-animation__dot',
'module-typing-animation__dot--third',
color ? `module-typing-animation__dot--${color}` : null
)}
/>
</div>
);