SeenUserList.jsx 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  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 SeenUserList = (props) => {
  13. const [popoverOpen, setPopoverOpen] = useState(false);
  14. const toggle = () => setPopoverOpen(!popoverOpen);
  15. const { pageContainer } = props;
  16. return (
  17. <div>
  18. <Button id="SeenUserPopover" type="button" className="btn btn-seen-user-list border-0 px-1 py-0" style={{ backgroundColor: 'transparent' }}>
  19. <span className="mr-2 svg footstamp-icon"><FootstampIcon /></span>
  20. <span className="seen-user-count">{pageContainer.state.countOfSeenUsers}</span>
  21. </Button>
  22. <Popover placement="bottom" isOpen={popoverOpen} target="SeenUserPopover" toggle={toggle} trigger="legacy">
  23. <PopoverBody className="col">
  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. SeenUserList.propTypes = {
  33. pageContainer: PropTypes.instanceOf(PageContainer).isRequired,
  34. };
  35. /**
  36. * Wrapper component for using unstated
  37. */
  38. const SeenUserListWrapper = withUnstatedContainers(SeenUserList, [PageContainer]);
  39. export default (SeenUserListWrapper);