SeenUserInfo.jsx 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // import React from 'react';
  2. import PropTypes from 'prop-types';
  3. import React, { useState } from 'react';
  4. import {
  5. Button, Popover, PopoverBody,
  6. } from 'reactstrap';
  7. import UserPictureList from './UserPictureList';
  8. import { withUnstatedContainers } from '../UnstatedUtils';
  9. import PageContainer from '../../services/PageContainer';
  10. import FootstampIcon from '../FootstampIcon';
  11. /* eslint react/no-multi-comp: 0, react/prop-types: 0 */
  12. const SeenUserInfo = (props) => {
  13. const [popoverOpen, setPopoverOpen] = useState(false);
  14. const toggle = () => setPopoverOpen(!popoverOpen);
  15. const { pageContainer, disabled } = props;
  16. return (
  17. <div className="grw-seen-user-info">
  18. <Button id="po-seen-user" color="link" className="px-2">
  19. <span className="mr-1 footstamp-icon"><FootstampIcon /></span>
  20. <span className="seen-user-count">{pageContainer.state.countOfSeenUsers}</span>
  21. </Button>
  22. <Popover placement="bottom" isOpen={popoverOpen} target="po-seen-user" toggle={toggle} trigger="legacy" disabled={disabled}>
  23. <PopoverBody className="seen-user-popover">
  24. <div className="px-2 text-right user-list-content text-truncate text-muted">
  25. <UserPictureList users={pageContainer.state.seenUsers} />
  26. </div>
  27. </PopoverBody>
  28. </Popover>
  29. </div>
  30. );
  31. };
  32. SeenUserInfo.propTypes = {
  33. pageContainer: PropTypes.instanceOf(PageContainer).isRequired,
  34. disabled: PropTypes.bool,
  35. };
  36. /**
  37. * Wrapper component for using unstated
  38. */
  39. const SeenUserInfoWrapper = withUnstatedContainers(SeenUserInfo, [PageContainer]);
  40. export default (SeenUserInfoWrapper);