import React from 'react'; import PropTypes from 'prop-types'; import './ChannelSelector.scss'; import colorMXID from '../../../util/colorMXID'; import Text from '../../atoms/text/Text'; import Avatar from '../../atoms/avatar/Avatar'; import NotificationBadge from '../../atoms/badge/NotificationBadge'; import { blurOnBubbling } from '../../atoms/button/script'; function ChannelSelectorWrapper({ isSelected, onClick, content, options, }) { return (
{options}
); } ChannelSelectorWrapper.defaultProps = { options: null, }; ChannelSelectorWrapper.propTypes = { isSelected: PropTypes.bool.isRequired, onClick: PropTypes.func.isRequired, content: PropTypes.node.isRequired, options: PropTypes.node, }; function ChannelSelector({ name, roomId, imageSrc, iconSrc, isSelected, isUnread, notificationCount, isAlert, options, onClick, }) { return ( {name} { isUnread && ( )} )} options={options} onClick={onClick} /> ); } ChannelSelector.defaultProps = { imageSrc: null, iconSrc: null, options: null, }; ChannelSelector.propTypes = { name: PropTypes.string.isRequired, roomId: PropTypes.string.isRequired, imageSrc: PropTypes.string, iconSrc: PropTypes.string, isSelected: PropTypes.bool.isRequired, isUnread: PropTypes.bool.isRequired, notificationCount: PropTypes.number.isRequired, isAlert: PropTypes.bool.isRequired, options: PropTypes.node, onClick: PropTypes.func.isRequired, }; export default ChannelSelector;