diff options
author | 2021-05-28 17:19:40 -0500 | |
---|---|---|
committer | 2021-05-28 17:19:40 -0500 | |
commit | 3df41d23089142ea9b0895110f28a2d4a43a9059 (patch) | |
tree | 4b590cdb86e647b479730f5b4f83ee7c147aaf69 /packages/renderers/renderer-react/server.js | |
parent | 630c36f3516bb500ca6a4bfe84c972b1093b8177 (diff) | |
download | astro-3df41d23089142ea9b0895110f28a2d4a43a9059.tar.gz astro-3df41d23089142ea9b0895110f28a2d4a43a9059.tar.zst astro-3df41d23089142ea9b0895110f28a2d4a43a9059.zip |
Bugbash! (#263)
* fix(vscode): Markdown frontmatter should use TSX, not YAML
* test: add test for #153
* chore: bump deps
* chore: update to use @astrojs scope
* fix: Markdown parse error when only child is `{expression}`
* fix: update renderer edge cases
* fix: failing test
* fix: update renderer
Diffstat (limited to 'packages/renderers/renderer-react/server.js')
-rw-r--r-- | packages/renderers/renderer-react/server.js | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/packages/renderers/renderer-react/server.js b/packages/renderers/renderer-react/server.js new file mode 100644 index 000000000..3518f6447 --- /dev/null +++ b/packages/renderers/renderer-react/server.js @@ -0,0 +1,21 @@ +import { createElement as h } from 'react'; +import { renderToStaticMarkup as renderToString } from 'react-dom/server.js'; +import StaticHtml from './static-html.js'; + +function check(Component, props, children) { + try { + const { html } = renderToStaticMarkup(Component, props, children) + return Boolean(html) + } catch (e) {} + return false; +} + +function renderToStaticMarkup(Component, props, children) { + const html = renderToString(h(Component, { ...props, children: h(StaticHtml, { value: children }), innerHTML: children })); + return { html }; +} + +export default { + check, + renderToStaticMarkup, +}; |