26 lines
993 B
TypeScript
26 lines
993 B
TypeScript
|
/**
|
||
|
* Parse the given HTML into a body element.
|
||
|
*
|
||
|
* Note: The current implementation will return a shared reference, reset on
|
||
|
* each call to `createElement`. Therefore, you should not hold a reference to
|
||
|
* the value to operate upon asynchronously, as it may have unexpected results.
|
||
|
*
|
||
|
* @param {HTMLDocument} document The HTML document to use to parse.
|
||
|
* @param {string} html The HTML to parse.
|
||
|
*
|
||
|
* @return {HTMLBodyElement} Body element with parsed HTML.
|
||
|
*/
|
||
|
export function createElement( { implementation }, html ) {
|
||
|
// Because `createHTMLDocument` is an expensive operation, and with this
|
||
|
// function being internal to `rich-text` (full control in avoiding a risk
|
||
|
// of asynchronous operations on the shared reference), a single document
|
||
|
// is reused and reset for each call to the function.
|
||
|
if ( ! createElement.body ) {
|
||
|
createElement.body = implementation.createHTMLDocument( '' ).body;
|
||
|
}
|
||
|
|
||
|
createElement.body.innerHTML = html;
|
||
|
|
||
|
return createElement.body;
|
||
|
}
|