hono
Version:
Web framework built on Web Standards
50 lines (49 loc) • 1.16 kB
JavaScript
// src/jsx/dom/client.ts
import { useState } from "../hooks/index.js";
import { buildNode, renderNode } from "./render.js";
var createRoot = (element, options = {}) => {
let setJsxNode = void 0;
if (Object.keys(options).length > 0) {
console.warn("createRoot options are not supported yet");
}
return {
render(jsxNode) {
if (setJsxNode === null) {
throw new Error("Cannot update an unmounted root");
}
if (setJsxNode) {
setJsxNode(jsxNode);
} else {
renderNode(
buildNode({
tag: () => {
const [_jsxNode, _setJsxNode] = useState(jsxNode);
setJsxNode = _setJsxNode;
return _jsxNode;
},
props: {}
}),
element
);
}
},
unmount() {
setJsxNode?.(null);
setJsxNode = null;
}
};
};
var hydrateRoot = (element, reactNode, options = {}) => {
const root = createRoot(element, options);
root.render(reactNode);
return root;
};
var client_default = {
createRoot,
hydrateRoot
};
export {
createRoot,
client_default as default,
hydrateRoot
};