import { type Node as YogaNode } from 'yoga-layout'; import { type Styles } from './styles.js'; import { type OutputTransformer } from './render-node-to-output.js'; type InkNode = { parentNode: DOMElement | undefined; yogaNode?: YogaNode; internal_static?: boolean; style: Styles; }; export type TextName = '#text'; export type ElementNames = 'ink-root' | 'ink-box' | 'ink-text' | 'ink-virtual-text'; export type NodeNames = ElementNames | TextName; export type DOMElement = { nodeName: ElementNames; attributes: Record; childNodes: DOMNode[]; internal_transform?: OutputTransformer; isStaticDirty?: boolean; staticNode?: DOMElement; onComputeLayout?: () => void; onRender?: () => void; onImmediateRender?: () => void; } & InkNode; export type TextNode = { nodeName: TextName; nodeValue: string; } & InkNode; export type DOMNode = T extends { nodeName: infer U; } ? U extends '#text' ? TextNode : DOMElement : never; export type DOMNodeAttribute = boolean | string | number; export declare const createNode: (nodeName: ElementNames) => DOMElement; export declare const appendChildNode: (node: DOMElement, childNode: DOMElement) => void; export declare const insertBeforeNode: (node: DOMElement, newChildNode: DOMNode, beforeChildNode: DOMNode) => void; export declare const removeChildNode: (node: DOMElement, removeNode: DOMNode) => void; export declare const setAttribute: (node: DOMElement, key: string, value: DOMNodeAttribute) => void; export declare const setStyle: (node: DOMNode, style: Styles) => void; export declare const createTextNode: (text: string) => TextNode; export declare const setTextNodeValue: (node: TextNode, text: string) => void; export {};