PageHistory.jsx 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import React, { useState, 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. onChangeSourceInvoked={setSourceRevision}
  48. onChangeTargetInvoked={setTargetRevision}
  49. />
  50. <div className="my-3">
  51. {pager()}
  52. </div>
  53. <RevisionComparer
  54. sourceRevision={sourceRevision}
  55. targetRevision={targetRevision}
  56. currentPageId={currentPageId}
  57. />
  58. </div>
  59. );
  60. };
  61. export default PageHistory;