| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748 |
- // import React from 'react';
- import PropTypes from 'prop-types';
- import React, { useState } from 'react';
- import {
- Button, Popover, PopoverBody,
- } from 'reactstrap';
- import UserPictureList from './UserPictureList';
- import { withUnstatedContainers } from '../UnstatedUtils';
- import PageContainer from '../../services/PageContainer';
- import FootstampIcon from '../FootstampIcon';
- /* eslint react/no-multi-comp: 0, react/prop-types: 0 */
- const SeenUserList = (props) => {
- const [popoverOpen, setPopoverOpen] = useState(false);
- const toggle = () => setPopoverOpen(!popoverOpen);
- const { pageContainer } = props;
- return (
- <div>
- <Button id="SeenUserPopover" type="button" className="btn btn-seen-user-list border-0 px-1 py-0" style={{ backgroundColor: 'transparent' }}>
- <span className="mr-2 svg footstamp-icon"><FootstampIcon /></span>
- <span className="seen-user-count">{pageContainer.state.countOfSeenUsers}</span>
- </Button>
- <Popover placement="bottom" isOpen={popoverOpen} target="SeenUserPopover" toggle={toggle} trigger="legacy">
- <PopoverBody className="col">
- <div className="px-2 text-right user-list-content text-truncate text-muted">
- <UserPictureList users={pageContainer.state.seenUsers} />
- </div>
- </PopoverBody>
- </Popover>
- </div>
- );
- };
- SeenUserList.propTypes = {
- pageContainer: PropTypes.instanceOf(PageContainer).isRequired,
- };
- /**
- * Wrapper component for using unstated
- */
- const SeenUserListWrapper = withUnstatedContainers(SeenUserList, [PageContainer]);
- export default (SeenUserListWrapper);
|