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

70 lines
1.6 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2019 Signal Messenger, LLC
2020-10-30 20:34:04 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
import classNames from 'classnames';
import React from 'react';
import type { LocalizerType } from '../../types/Util';
import { getClassNamesFor } from '../../util/getClassNamesFor';
export enum ScrollDownButtonVariant {
UNREAD_MESSAGES = 'unread-messages',
UNREAD_MENTIONS = 'unread-mentions',
}
export type ScrollDownButtonPropsType = {
variant: ScrollDownButtonVariant;
count?: number;
onClick: VoidFunction;
i18n: LocalizerType;
};
2022-11-18 00:45:19 +00:00
export function ScrollDownButton({
variant,
count,
onClick,
2020-09-14 19:51:27 +00:00
i18n,
}: ScrollDownButtonPropsType): JSX.Element {
const getClassName = getClassNamesFor('ScrollDownButton');
2022-06-13 23:37:29 +00:00
let badgeText: string | undefined;
if (count) {
if (count < 100) {
badgeText = count.toString();
2022-06-13 23:37:29 +00:00
} else {
badgeText = '99+';
}
}
let altText: string;
switch (variant) {
case ScrollDownButtonVariant.UNREAD_MESSAGES:
altText = count ? i18n('icu:messagesBelow') : i18n('icu:scrollDown');
break;
case ScrollDownButtonVariant.UNREAD_MENTIONS:
altText = i18n('icu:mentionsBelow');
break;
default:
throw new Error(`Unexpected variant: ${variant}`);
}
2020-09-14 19:51:27 +00:00
return (
<button
type="button"
className={classNames(getClassName(''), getClassName(`__${variant}`))}
onClick={onClick}
title={altText}
>
{badgeText ? (
<div className={getClassName('__badge')}>{badgeText}</div>
) : null}
<div
className={classNames(
getClassName('__icon'),
getClassName(`__icon--${variant}`)
)}
/>
</button>
2020-09-14 19:51:27 +00:00
);
2022-11-18 00:45:19 +00:00
}