mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-13 22:54:42 -04:00
28 lines
1,009 B
TypeScript
28 lines
1,009 B
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import React, { useMemo } from 'react'
|
|
import { useConvertMarkdownToReactDom } from '../hooks/use-convert-markdown-to-react-dom'
|
|
import { StoreProvider } from '../../../redux/store-provider'
|
|
import type { MarkdownRendererExtension } from '../extensions/base/markdown-renderer-extension'
|
|
|
|
export interface SimpleMarkdownRendererProps {
|
|
content: string
|
|
extensions: MarkdownRendererExtension[]
|
|
}
|
|
|
|
/**
|
|
* A markdown renderer for tests.
|
|
*
|
|
* @param content The content to be rendered.
|
|
* @param extensions The {@link MarkdownRendererExtension MarkdownExtensions} to use for rendering.
|
|
*/
|
|
export const TestMarkdownRenderer: React.FC<SimpleMarkdownRendererProps> = ({ content, extensions }) => {
|
|
const lines = useMemo(() => content.split('\n'), [content])
|
|
const dom = useConvertMarkdownToReactDom(lines, extensions, true, false)
|
|
|
|
return <StoreProvider>{dom}</StoreProvider>
|
|
}
|