PageHistory.jsx 2.2 KB

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