ShareLinkPageContents.tsx 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import React, { useEffect } from 'react';
  2. import type { IPagePopulatedToShowRevision } from '@growi/core';
  3. import type { HtmlElementNode } from 'rehype-toc';
  4. import { useViewOptions } from '~/stores/renderer';
  5. import { useCurrentPageTocNode } from '~/stores/ui';
  6. import { registerGrowiFacade } from '~/utils/growi-facade';
  7. import loggerFactory from '~/utils/logger';
  8. import RevisionRenderer from '../Page/RevisionRenderer';
  9. const logger = loggerFactory('growi:Page');
  10. export type ShareLinkPageContentsProps = {
  11. page?: IPagePopulatedToShowRevision,
  12. }
  13. export const ShareLinkPageContents = (props: ShareLinkPageContentsProps): JSX.Element => {
  14. const { page } = props;
  15. const { mutate: mutateCurrentPageTocNode } = useCurrentPageTocNode();
  16. const { data: rendererOptions, mutate: mutateRendererOptions } = useViewOptions((toc: HtmlElementNode) => {
  17. mutateCurrentPageTocNode(toc);
  18. });
  19. // register to facade
  20. useEffect(() => {
  21. registerGrowiFacade({
  22. markdownRenderer: {
  23. optionsMutators: {
  24. viewOptionsMutator: mutateRendererOptions,
  25. },
  26. },
  27. });
  28. }, [mutateRendererOptions]);
  29. if (page == null || rendererOptions == null) {
  30. const entries = Object.entries({
  31. page, rendererOptions,
  32. })
  33. .map(([key, value]) => [key, value == null ? 'null' : undefined])
  34. .filter(([, value]) => value != null);
  35. logger.warn('Some of materials are missing.', Object.fromEntries(entries));
  36. return <></>;
  37. }
  38. const { _id: revisionId, body: markdown } = page.revision;
  39. return (
  40. <>
  41. { revisionId != null && (
  42. <RevisionRenderer rendererOptions={rendererOptions} markdown={markdown} />
  43. )}
  44. </>
  45. );
  46. };