ActivityTable.tsx 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import React, { FC, useState, useCallback } from 'react';
  2. import { pagePathUtils } from '@growi/core';
  3. import { UserPicture } from '@growi/ui/dist/components/User/UserPicture';
  4. import { format } from 'date-fns';
  5. import { CopyToClipboard } from 'react-copy-to-clipboard';
  6. import { useTranslation } from 'react-i18next';
  7. import { Tooltip } from 'reactstrap';
  8. import { IActivityHasId } from '~/interfaces/activity';
  9. type Props = {
  10. activityList: IActivityHasId[]
  11. }
  12. const formatDate = (date) => {
  13. return format(new Date(date), 'yyyy/MM/dd HH:mm:ss');
  14. };
  15. export const ActivityTable : FC<Props> = (props: Props) => {
  16. const { t } = useTranslation();
  17. const [tooltopOpen, setTooltipOpen] = useState(false);
  18. const showToolTip = useCallback(() => {
  19. setTooltipOpen(true);
  20. setTimeout(() => {
  21. setTooltipOpen(false);
  22. }, 1000);
  23. }, [setTooltipOpen]);
  24. return (
  25. <div className="table-responsive text-nowrap h-100">
  26. <table className="table table-default table-bordered table-user-list">
  27. <thead>
  28. <tr>
  29. <th scope="col">{t('admin:audit_log_management.user')}</th>
  30. <th scope="col">{t('admin:audit_log_management.date')}</th>
  31. <th scope="col">{t('admin:audit_log_management.action')}</th>
  32. <th scope="col">{t('admin:audit_log_management.ip')}</th>
  33. <th scope="col">{t('admin:audit_log_management.url')}</th>
  34. </tr>
  35. </thead>
  36. <tbody>
  37. {props.activityList.map((activity) => {
  38. return (
  39. <tr data-testid="activity-table" key={activity._id}>
  40. <td>
  41. { activity.user != null && (
  42. <>
  43. <UserPicture user={activity.user} />
  44. <a
  45. className="ml-2"
  46. href={pagePathUtils.userHomepagePath(activity.user)}
  47. >
  48. {activity.snapshot?.username}
  49. </a>
  50. </>
  51. )}
  52. </td>
  53. <td>{formatDate(activity.createdAt)}</td>
  54. <td>{t(`admin:audit_log_action.${activity.action}`)}</td>
  55. <td>{activity.ip}</td>
  56. <td>
  57. {activity.endpoint}
  58. <CopyToClipboard text={activity.endpoint} onCopy={showToolTip}>
  59. <button type="button" className="btn btn-outline-secondary border-0 pull-right" id="tooltipTarget">
  60. <i className="fa fa-clipboard" aria-hidden="true"></i>
  61. </button>
  62. </CopyToClipboard>
  63. <Tooltip placement="top" isOpen={tooltopOpen} fade={false} target="tooltipTarget">
  64. copied!
  65. </Tooltip>
  66. </td>
  67. </tr>
  68. );
  69. })}
  70. </tbody>
  71. </table>
  72. </div>
  73. );
  74. };