2020-08-10 16:47:39 -04:00
|
|
|
// @flow
|
|
|
|
import React from 'react';
|
2020-08-11 16:32:03 -04:00
|
|
|
import classnames from 'classnames';
|
2021-07-19 22:02:59 -04:00
|
|
|
import { ENABLE_UI_NOTIFICATIONS } from 'config';
|
2022-03-22 15:03:39 -03:00
|
|
|
import { buildUnseenCountStr } from 'util/notifications';
|
2020-08-10 16:47:39 -04:00
|
|
|
|
|
|
|
type Props = {
|
2021-03-16 09:42:49 +08:00
|
|
|
unseenCount: number,
|
2020-08-11 16:32:03 -04:00
|
|
|
inline: boolean,
|
|
|
|
user: ?User,
|
2020-08-10 16:47:39 -04:00
|
|
|
};
|
|
|
|
|
2022-06-10 12:48:28 +08:00
|
|
|
export default function NotificationBubble(props: Props) {
|
2021-03-16 09:42:49 +08:00
|
|
|
const { unseenCount, inline = false, user } = props;
|
2021-07-19 22:02:59 -04:00
|
|
|
const notificationsEnabled = ENABLE_UI_NOTIFICATIONS || (user && user.experimental_ui);
|
2020-08-10 16:47:39 -04:00
|
|
|
|
2022-06-22 02:59:37 +02:00
|
|
|
if (!notificationsEnabled) {
|
2020-08-10 16:47:39 -04:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2020-08-11 16:32:03 -04:00
|
|
|
<span
|
|
|
|
className={classnames('notification__bubble', {
|
|
|
|
'notification__bubble--inline': inline,
|
2022-06-22 02:59:37 +02:00
|
|
|
'notification__bubble-hidden': unseenCount === 0,
|
2020-08-11 16:32:03 -04:00
|
|
|
})}
|
|
|
|
>
|
2021-01-11 10:43:39 -05:00
|
|
|
<span
|
|
|
|
className={classnames('notification__count', {
|
2021-03-16 09:42:49 +08:00
|
|
|
'notification__bubble--small': unseenCount > 9,
|
2021-01-11 10:43:39 -05:00
|
|
|
})}
|
|
|
|
>
|
2022-03-22 15:03:39 -03:00
|
|
|
{buildUnseenCountStr(unseenCount)}
|
2021-01-11 10:43:39 -05:00
|
|
|
</span>
|
2020-08-10 16:47:39 -04:00
|
|
|
</span>
|
|
|
|
);
|
|
|
|
}
|