Document API is in alpha and subject to breaking changes while the contract and adapters continue to evolve. The current API is not yet comprehensive, and more commands and namespaces are being added on an ongoing basis.
Why use Document API
- Build automations without editor-specific code.
- Work with predictable inputs and outputs defined per operation.
- Check capabilities up front and branch safely when features are unavailable.
Node addressing
Every block in a document has anodeId β a string that uniquely identifies it.
For mutation targeting and getNode(...), use NodeAddress:
find(...) returns SDM/1 SDAddress values (for example kind: "content"), while query.match(...) returns NodeAddress values (kind: "block" / kind: "inline"). Use query.match(...) when you need deterministic mutation-ready refs and node addresses.
Stable IDs across loads
For DOCX documents,nodeId is derived from the fileβs native w14:paraId attribute. In practice, this is usually stable when you reopen the same unchanged DOCX across separate editor sessions, machines, or headless CLI pipelines.
For nodes created at runtime (not imported from DOCX), nodeId falls back to sdBlockId, a UUID generated when the editor opens. This fallback is volatile and changes on every load.
| ID source | Stable across loads? | When used |
|---|---|---|
paraId (from DOCX) | Best effort (usually stable for unchanged DOCX blocks) | Paragraphs, tables, rows, cells imported from DOCX |
sdBlockId (runtime) | No (session-scoped) | Nodes created programmatically before first export |

