client.ts — astro Source File
Architecture documentation for client.ts, a typescript file in the astro codebase. 3 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR c5f3c713_1f42_3f72_0411_7043ce23ab8a["client.ts"] 5d6f4037_5bea_5d26_d23c_0c9bcb7db079["./static-html.js"] c5f3c713_1f42_3f72_0411_7043ce23ab8a --> 5d6f4037_5bea_5d26_d23c_0c9bcb7db079 d9988dd0_c044_f9d2_85cd_a31a0a2bdf80["react"] c5f3c713_1f42_3f72_0411_7043ce23ab8a --> d9988dd0_c044_f9d2_85cd_a31a0a2bdf80 5a354ac5_797d_df7e_4a72_d5cb5cd16bd0["client"] c5f3c713_1f42_3f72_0411_7043ce23ab8a --> 5a354ac5_797d_df7e_4a72_d5cb5cd16bd0 style c5f3c713_1f42_3f72_0411_7043ce23ab8a fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import { createElement, startTransition } from 'react';
import { createRoot, hydrateRoot, type Root } from 'react-dom/client';
import StaticHtml from './static-html.js';
function isAlreadyHydrated(element: HTMLElement) {
for (const key in element) {
if (key.startsWith('__reactContainer')) {
return key as keyof HTMLElement;
}
}
}
function createReactElementFromDOMElement(element: any): any {
let attrs: Record<string, string> = {};
for (const attr of element.attributes) {
attrs[attr.name] = attr.value;
}
// If the element has no children, we can create a simple React element
if (element.firstChild === null) {
return createElement(element.localName, attrs);
}
return createElement(
element.localName,
attrs,
Array.from(element.childNodes)
.map((c: any) => {
if (c.nodeType === Node.TEXT_NODE) {
return c.data;
} else if (c.nodeType === Node.ELEMENT_NODE) {
return createReactElementFromDOMElement(c);
} else {
return undefined;
}
})
.filter((a) => !!a),
);
}
function getChildren(childString: string, experimentalReactChildren: boolean) {
if (experimentalReactChildren && childString) {
let children = [];
let template = document.createElement('template');
template.innerHTML = childString;
for (let child of template.content.children) {
children.push(createReactElementFromDOMElement(child));
}
return children;
} else if (childString) {
return createElement(StaticHtml, { value: childString });
} else {
return undefined;
}
}
// Keep a map of roots so we can reuse them on re-renders
let rootMap = new WeakMap<HTMLElement, Root>();
const getOrCreateRoot = (element: HTMLElement, creator: () => Root) => {
let root = rootMap.get(element);
if (!root) {
// ... (62 more lines)
Domain
Subdomains
Dependencies
- ./static-html.js
- client
- react
Source
Frequently Asked Questions
What does client.ts do?
client.ts is a source file in the astro codebase, written in typescript. It belongs to the CoreAstro domain, CoreMiddleware subdomain.
What functions are defined in client.ts?
client.ts defines 4 function(s): createReactElementFromDOMElement, getChildren, getOrCreateRoot, isAlreadyHydrated.
What does client.ts depend on?
client.ts imports 3 module(s): ./static-html.js, client, react.
Where is client.ts in the architecture?
client.ts is located at packages/integrations/react/src/client.ts (domain: CoreAstro, subdomain: CoreMiddleware, directory: packages/integrations/react/src).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free