preact-habitat
Version:
A place for your happy widget in every DOM.
43 lines (37 loc) • 938 B
JavaScript
import { widgetDOMHostElements, preactRender } from "./lib";
const habitat = Widget => {
// Widget represents the Preact component we need to mount
let widget = Widget;
// preact root render helper
let root = null;
let render = (
{
selector = null,
inline = false,
clean = false,
clientSpecified = false,
defaultProps = {}
} = {}
) => {
let elements = widgetDOMHostElements({
selector,
inline,
clientSpecified
});
let loaded = () => {
if (elements.length > 0) {
let elements = widgetDOMHostElements({
selector,
inline,
clientSpecified
});
return preactRender(widget, elements, root, clean, defaultProps);
}
};
loaded();
document.addEventListener("DOMContentLoaded", loaded);
document.addEventListener("load", loaded);
};
return { render };
};
export default habitat;