/* eslint-disable */ import React from 'react'; import Markdown from 'remarkable'; import Helmet from 'react-helmet'; import highlight from './highlight'; import anchors from './anchors'; class MarkdownBlock extends React.Component { content() { if (this.props.source) { return ( ); } return React.Children.map(this.props.children, child => { if (typeof child === 'string') { return ( ); } return child; }); } renderMarkdown(source) { const alias = { js: 'jsx' }; const {siteConfig} = this.props; const md = new Markdown({ langPrefix: 'hljs css language-', highlight: highlight, html: true, linkify: true }); // Register anchors plugin md.use(anchors); // Allow client sites to register their own plugins if (siteConfig.markdownPlugins) { siteConfig.markdownPlugins.forEach(plugin => { md.use(plugin); }); } const html = md.render(source); // Ensure fenced code blocks use Highlight.js hljs class // https://github.com/jonschlinkert/remarkable/issues/224 return html.replace(/
/g, '
');
  }

  render() {
    const {siteConfig} = this.props;
    const highlight = Object.assign(
      {},
      {
        version: '9.12.0',
        theme: 'default'
      },
      siteConfig.highlight
    );

    // Use user-provided themeUrl if it exists, else construct one from version and theme.
    const highlightThemeURL = highlight.themeUrl
      ? highlight.themeUrl
      : `https://cdnjs.cloudflare.com/ajax/libs/highlight.js/${
          highlight.version
        }/styles/${highlight.theme}.min.css`;

    return (
      
{this.content()}
); } } MarkdownBlock.defaultProps = { siteConfig: {} }; export default MarkdownBlock;