Published
Edited
Apr 18, 2022
Insert cell
Insert cell
Insert cell
Insert cell
Lexical = import('https://cdn.skypack.dev/lexical@0.2.2?min')
Insert cell
config = ({
theme: exampleTheme,
})
Insert cell
editor = Lexical.createEditor(config)
Insert cell
html`<h2>This is the editable element</h2>
<div class="my-editable-element" contenteditable="true"></div>
`
Insert cell
{
editor.setRootElement(document.querySelector('.my-editable-element'));
}
Insert cell
stringifiedEditorState = JSON.stringify(editor.getEditorState().toJSON());
Insert cell
{
// example of updating the editor state.
editor.update(() => {
// Get the RootNode from the EditorState
const root = Lexical.$getRoot();

// Get the selection from the EditorState
const selection = Lexical.$getSelection();

// Create a new ParagraphNode
const paragraphNode = Lexical.$createParagraphNode();

// Create a new TextNode
const textNode = Lexical.$createTextNode('Hello world');

// Append the text node to the paragraph
paragraphNode.append(textNode);

// Finally, append the paragraph to the root
root.append(paragraphNode);
});
}
Insert cell
{
editor.registerUpdateListener(({editorState}) => {
// The latest EditorState can be found as `editorState`.
// To read the contents of the EditorState, use the following API:

editorState.read(() => {
// Just like editor.update(), .read() expects a closure where you can use
// the $ prefixed helper functions.
console.log("root node ", Lexical.$getRoot())
});
});
}
Insert cell
Insert cell
exampleTheme = ({
ltr: 'ltr',
rtl: 'rtl',
placeholder: 'editor-placeholder',
paragraph: 'editor-paragraph',
});
Insert cell
<style>

.ltr {
text-align: left;
}

.rtl {
text-align: right;
}

.editor-placeholder {
color: #999;
overflow: hidden;
position: absolute;
top: 15px;
left: 15px;
user-select: none;
pointer-events: none;
}

.editor-paragraph {
margin: 0 0 15px 0;
position: relative;
font-size: 2em;
}
</style>
Insert cell

One platform to build and deploy the best data apps

Experiment and prototype by building visualizations in live JavaScript notebooks. Collaborate with your team and decide which concepts to build out.
Use Observable Framework to build data apps locally. Use data loaders to build in any language or library, including Python, SQL, and R.
Seamlessly deploy to Observable. Test before you ship, use automatic deploy-on-commit, and ensure your projects are always up-to-date.
Learn more