Home / File/ client.ts — astro Source File

client.ts — astro Source File

Architecture documentation for client.ts, a typescript file in the astro codebase. 3 imports, 0 dependents.

File typescript CoreAstro CoreMiddleware 3 imports 4 functions

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

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