summaryrefslogtreecommitdiff
path: root/packages/renderers
diff options
context:
space:
mode:
Diffstat (limited to 'packages/renderers')
-rw-r--r--packages/renderers/renderer-preact/server.js15
-rw-r--r--packages/renderers/renderer-react/server.js36
2 files changed, 39 insertions, 12 deletions
diff --git a/packages/renderers/renderer-preact/server.js b/packages/renderers/renderer-preact/server.js
index 8fd4ccf2f..989e2d385 100644
--- a/packages/renderers/renderer-preact/server.js
+++ b/packages/renderers/renderer-preact/server.js
@@ -1,13 +1,16 @@
-import { h } from 'preact';
+import { h, Component as BaseComponent } from 'preact';
import { renderToString } from 'preact-render-to-string';
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;
+ if(typeof Component !== 'function') return false;
+
+ if(typeof Component.prototype.render === 'function') {
+ return BaseComponent.isPrototypeOf(Component);
+ }
+
+ const { html } = renderToStaticMarkup(Component, props, children);
+ return Boolean(html);
}
function renderToStaticMarkup(Component, props, children) {
diff --git a/packages/renderers/renderer-react/server.js b/packages/renderers/renderer-react/server.js
index 56f2f5aa8..8ac177c7c 100644
--- a/packages/renderers/renderer-react/server.js
+++ b/packages/renderers/renderer-react/server.js
@@ -1,13 +1,37 @@
-import { createElement as h } from 'react';
+import { Component as BaseComponent, createElement as h } from 'react';
import { renderToStaticMarkup as renderToString } from 'react-dom/server.js';
import StaticHtml from './static-html.js';
+const reactTypeof = Symbol.for('react.element');
+
function check(Component, props, children) {
- try {
- const { html } = renderToStaticMarkup(Component, props, children);
- return Boolean(html);
- } catch (e) {}
- return false;
+ if(typeof Component !== 'function') return false;
+
+ if(typeof Component.prototype.render === 'function') {
+ return BaseComponent.isPrototypeOf(Component);
+ }
+
+ let error = null;
+ let isReactComponent = false;
+ function Tester(...args) {
+ try {
+ const vnode = Component(...args);
+ if(vnode && vnode['$$typeof'] === reactTypeof) {
+ isReactComponent = true;
+ }
+ } catch(err) {
+ error = err;
+ }
+
+ return h('div');
+ }
+
+ renderToStaticMarkup(Tester, props, children);
+
+ if(error) {
+ throw error;
+ }
+ return isReactComponent;
}
function renderToStaticMarkup(Component, props, children) {