PageHistory.tsx 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. import React, { useState, useEffect } from 'react';
  2. import { IRevisionHasPageId } from '@growi/core';
  3. import { useCurrentPageId } from '~/stores/context';
  4. import { useSWRxPageRevisions, useCurrentPagePath } from '~/stores/page';
  5. import loggerFactory from '~/utils/logger';
  6. import { PageRevisionTable } from './PageHistory/PageRevisionTable';
  7. import PaginationWrapper from './PaginationWrapper';
  8. import { RevisionComparer } from './RevisionComparer/RevisionComparer';
  9. const logger = loggerFactory('growi:PageHistory');
  10. export const PageHistory: React.FC<{ onClose: () => void }> = ({ onClose }) => {
  11. const [activePage, setActivePage] = useState(1);
  12. const { data: currentPageId } = useCurrentPageId();
  13. const { data: currentPagePath } = useCurrentPagePath();
  14. const { data: revisionsData, mutate: mutatePageRevisions } = useSWRxPageRevisions(activePage, 10, currentPageId);
  15. const [sourceRevision, setSourceRevision] = useState<IRevisionHasPageId>();
  16. const [targetRevision, setTargetRevision] = useState<IRevisionHasPageId>();
  17. useEffect(() => {
  18. if (revisionsData != null) {
  19. setSourceRevision(revisionsData.revisions[0]);
  20. setTargetRevision(revisionsData.revisions[0]);
  21. }
  22. }, [revisionsData]);
  23. useEffect(() => {
  24. mutatePageRevisions();
  25. });
  26. const pagingLimit = 10;
  27. if (revisionsData == null || sourceRevision == null || targetRevision == null || currentPageId == null || currentPagePath == null) {
  28. return (
  29. <div className="text-muted text-center">
  30. <i className="fa fa-2x fa-spinner fa-pulse mt-3"></i>
  31. </div>
  32. );
  33. }
  34. const pager = () => {
  35. return (
  36. <PaginationWrapper
  37. activePage={activePage}
  38. changePage={setActivePage}
  39. totalItemsCount={revisionsData.totalCounts}
  40. pagingLimit={pagingLimit}
  41. align="center"
  42. />
  43. );
  44. };
  45. return (
  46. <div className="revision-history" data-testid="page-history">
  47. <PageRevisionTable
  48. revisions={revisionsData.revisions}
  49. pagingLimit={pagingLimit}
  50. sourceRevision={sourceRevision}
  51. targetRevision={targetRevision}
  52. currentPageId={currentPageId}
  53. currentPagePath={currentPagePath}
  54. onChangeSourceInvoked={setSourceRevision}
  55. onChangeTargetInvoked={setTargetRevision}
  56. onClose={onClose}
  57. />
  58. <div className="my-3">
  59. {pager()}
  60. </div>
  61. <RevisionComparer
  62. sourceRevision={sourceRevision}
  63. targetRevision={targetRevision}
  64. currentPageId={currentPageId}
  65. currentPagePath={currentPagePath}
  66. onClose={onClose}
  67. />
  68. </div>
  69. );
  70. };