Files
cinny/src/app/molecules/sidebar-avatar/SidebarAvatar.jsx
T

56 lines
1.4 KiB
React
Raw Normal View History

2021-07-28 18:45:52 +05:30
import React from 'react';
import PropTypes from 'prop-types';
import './SidebarAvatar.scss';
2021-11-23 16:33:35 +05:30
import { twemojify } from '../../../util/twemojify';
2021-07-28 18:45:52 +05:30
import Text from '../../atoms/text/Text';
import Tooltip from '../../atoms/tooltip/Tooltip';
2021-07-28 18:45:52 +05:30
import { blurOnBubbling } from '../../atoms/button/script';
const SidebarAvatar = React.forwardRef(({
className, tooltip, active, onClick,
onContextMenu, avatar, notificationBadge,
2021-07-28 18:45:52 +05:30
}, ref) => {
const classes = ['sidebar-avatar'];
if (active) classes.push('sidebar-avatar--active');
if (className) classes.push(className);
2021-07-28 18:45:52 +05:30
return (
<Tooltip
2021-11-23 16:33:35 +05:30
content={<Text variant="b1">{twemojify(tooltip)}</Text>}
2021-07-28 18:45:52 +05:30
placement="right"
>
<button
ref={ref}
className={classes.join(' ')}
2021-07-28 18:45:52 +05:30
type="button"
onMouseUp={(e) => blurOnBubbling(e, '.sidebar-avatar')}
onClick={onClick}
onContextMenu={onContextMenu}
2021-07-28 18:45:52 +05:30
>
2022-03-07 21:05:47 +05:30
{avatar}
{notificationBadge}
2021-07-28 18:45:52 +05:30
</button>
</Tooltip>
2021-07-28 18:45:52 +05:30
);
});
SidebarAvatar.defaultProps = {
className: null,
2021-07-28 18:45:52 +05:30
active: false,
onClick: null,
onContextMenu: null,
2022-03-07 21:05:47 +05:30
notificationBadge: null,
2021-07-28 18:45:52 +05:30
};
SidebarAvatar.propTypes = {
className: PropTypes.string,
2021-07-28 18:45:52 +05:30
tooltip: PropTypes.string.isRequired,
active: PropTypes.bool,
onClick: PropTypes.func,
onContextMenu: PropTypes.func,
2022-03-07 21:05:47 +05:30
avatar: PropTypes.node.isRequired,
notificationBadge: PropTypes.node,
2021-07-28 18:45:52 +05:30
};
export default SidebarAvatar;