@hyperframes/sdk that is not covered in openComposition, the Composition interface, edit operations, types, or adapters.
History Module
Composition session via the "patch" event. Standalone sessions created by openComposition() attach a history module automatically — you only need createHistory directly when you are building a host application that manages its own undo stack, or when you want non-default coalesce/depth settings.
createHistory
session.on('patch') and builds an undo/redo stack. Coalesces rapid same-operation bursts on the same element into a single undo entry so a slider drag produces one undo step, not hundreds.
HistoryModule
Pops the top entry from the undo stack and applies its inverse patches via
session.applyPatches() tagged with ORIGIN_APPLY_PATCHES. Returns true when an entry was popped, false when the stack was empty.Pops the top entry from the redo stack and re-applies its forward patches. Returns
true when an entry was popped, false when the stack was empty. Any new op clears the redo stack.Returns
true when there is at least one entry on the undo stack.Returns
true when there is at least one entry on the redo stack.Unsubscribes from the session’s
"patch" event and clears both stacks. Call when the session is closed.HistoryOptions
Only ops whose
origin value appears in this array enter the undo stack. When omitted, all origins are tracked except ORIGIN_APPLY_PATCHES (which is always excluded to prevent undo loops). Use this to restrict the undo stack to UI-driven edits while letting programmatic patches pass through silently.Window in milliseconds within which same-operation bursts on the same paths are merged into a single undo entry. The timestamp slides forward on each coalesced event, so continuous editing keeps merging until there is a gap longer than
coalesceMs. Default: 300.Maximum depth of the undo stack. Oldest entries are dropped when the limit is exceeded. Default:
100.HistoryEntry
PatchEvent fields so the history module can reconstruct the forward and inverse change sets without re-parsing.
Standalone sessions (the default) attach history automatically. Pass
{ history: false } to openComposition() when you want to manage undo/redo yourself via createHistory or the host’s own stack.Persist Queue
"change" events on a session and schedules async writes through a PersistAdapter. One write is in flight at a time; the latest HTML always wins (last-write-wins coalescing). Standalone sessions wired with a persist adapter attach this automatically via openComposition(). Use createPersistQueue directly only when you are building an embedded host that owns persistence separately from the SDK session.
createPersistQueue
PersistQueueModule
Cancels any pending debounced write and immediately writes the current serialized HTML to the adapter. Resolves when the write commits. Use before app close or page unload.
Cancels any pending write and unsubscribes from the session’s
"change" event. Does not flush — call flush() first if you need to ensure the final state is written.PersistQueueOptions
The adapter path to write to. Passed directly to
adapter.write(path, content). Default: "composition.html".Called when
adapter.write() rejects. Receives a PersistErrorEvent with { error: { message, cause? } }. Use this to surface persistence failures in your UI or logging layer.Document Utilities
SdkDocument model and HyperFramesElement trees from parsed HTML. These are the same functions the SDK uses internally on every openComposition() call. You rarely need them directly — they are exposed for hosts that parse HTML outside of a session, or for testing.
buildDocument
ensureHfIds first so every element gets a stable data-hf-id. Uses linkedom for DOM parsing — node-safe, works in agents, CI, and server-side code. Returns an SdkDocument snapshot; mutations on the live session do not update the returned value.
buildRoots
linkedom Document. Walks the live DOM directly — no serialize/re-parse round trip. This is what the session’s query API uses against its mutable document after each op.
flatElements
roots and all their descendants in document order (depth-first pre-order). Useful for searching across the full element tree without writing your own recursive walk.
Constants
ORIGIN_APPLY_PATCHES
applyPatches() and by the history module’s undo() / redo() methods. Host patch listeners must skip this origin to avoid undo loops:
Symbol so it survives realm boundaries — postMessage, structured clone, and JSON serialization all preserve it correctly. T3 embedded hosts that forward patch events across frames or workers rely on this property. The namespace prefix (@hyperframes/sdk:) makes accidental collision with a host-chosen origin string negligible.
ORIGIN_LOCAL
setText, setStyle, …) or dispatch() without an explicit origin option. You can filter on "local" to track only user-driven UI edits in a history module’s trackedOrigins list.
Errors
UnsupportedOpError
dispatch() when an op type is not handled by the current engine version. The code property is stable and part of the public API contract — switch on it rather than the message string.
comp.can(op) to avoid this error in the hot path:
resolveNearestHfElement
el upward through parentElement, returning the nearest ancestor (inclusive) that carries [data-hf-id] and is not [data-hf-root]. Returns null when the walk exits the DOM without finding a match, when the matched node is the composition root, or when isVisible(node) returns false for the matched node.
This is a pure function (no window or DOM API calls beyond getAttribute) and is unit-testable in a plain Node environment. createIframePreviewAdapter uses it internally to translate raw hit-test results into SDK element IDs. Full treatment of hit-testing and the visual editor canvas pattern is in the Canvas Integration guide.
resolveElementAffordances
@hyperframes/sdk/editing subpath. Full documentation is in the Editing Affordances guide.
Undo, Redo & Patches
How the history module, ORIGIN_APPLY_PATCHES, and applyPatches() work together.
Persistence
Wiring a PersistAdapter, handling errors, and restoring from version history.