import * as React from 'react'; import * as marked from 'marked'; import * as hljs from 'highlight.js'; type MarkdownComponentProps = { text: string; className?: string; markedOptions?: marked.MarkedOptions; style?: React.CSSProperties } const defaultRenderer = new marked.Renderer(); defaultRenderer.link = (href, title, text) => ( `${ text }` ); class MarkdownComponent extends React.Component { constructor(props: MarkdownComponentProps) { super(props); const markedOptions: marked.MarkedOptions = { gfm: true, tables: true, breaks: false, pedantic: false, sanitize: true, smartLists: true, smartypants: false, langPrefix: 'hljs ', ...(this.props.markedOptions || {}), highlight: (code, lang) => { if (!!(lang && hljs.getLanguage(lang))) { return hljs.highlight(lang, code).value; } return code; } }; marked.setOptions(markedOptions); } render() { const { text, className, style } = this.props; const html = (marked(text || '', { renderer: this.props.markedOptions && this.props.markedOptions.renderer || defaultRenderer })); return (
); } } export const Markdown = MarkdownComponent;