Preview.tsx 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import React, {
  2. SyntheticEvent, RefObject,
  3. } from 'react';
  4. import type { RendererOptions } from '~/interfaces/renderer-options';
  5. import RevisionRenderer from '../Page/RevisionRenderer';
  6. import styles from './Preview.module.scss';
  7. const moduleClass = styles['page-editor-preview-body'] ?? '';
  8. type Props = {
  9. rendererOptions: RendererOptions,
  10. markdown?: string,
  11. pagePath?: string | null,
  12. expandContentWidth?: boolean,
  13. pastEnd?: number,
  14. onScroll?: (scrollTop: number) => void,
  15. }
  16. const Preview = React.forwardRef((props: Props, ref: RefObject<HTMLDivElement>): JSX.Element => {
  17. const {
  18. rendererOptions,
  19. markdown, pagePath, pastEnd,
  20. expandContentWidth,
  21. } = props;
  22. const fluidLayoutClass = expandContentWidth ? 'fluid-layout' : '';
  23. return (
  24. <div
  25. className={`${moduleClass} ${fluidLayoutClass} ${pagePath === '/Sidebar' ? 'preview-sidebar' : ''}`}
  26. ref={ref}
  27. style={{ paddingBottom: pastEnd }}
  28. onScroll={(event: SyntheticEvent<HTMLDivElement>) => {
  29. if (props.onScroll != null) {
  30. props.onScroll(event.currentTarget.scrollTop);
  31. }
  32. }}
  33. >
  34. { markdown != null && (
  35. <RevisionRenderer rendererOptions={rendererOptions} markdown={markdown}></RevisionRenderer>
  36. ) }
  37. </div>
  38. );
  39. });
  40. Preview.displayName = 'Preview';
  41. export default Preview;