mirror of
https://github.com/livebook-dev/livebook.git
synced 2024-11-17 21:33:16 +08:00
936d0af5fb
* Set up markdown rendering, update theme. * Improve focus and handle expanding for markdown cells * Add keybindings for expanding/navigating cells * Improve editor autofocus when navigating with shortcuts * Add tests * Render markdown on the client * Don't render cell initial data and make a request instead
49 lines
1.2 KiB
JavaScript
49 lines
1.2 KiB
JavaScript
import { getAttributeOrThrow } from "../lib/attribute";
|
|
|
|
/**
|
|
* A hook used on [contenteditable] elements to update the specified
|
|
* attribute with the element text.
|
|
*
|
|
* Configuration:
|
|
*
|
|
* * `data-update-attribute` - the name of the attribute to update when content changes
|
|
*/
|
|
const ContentEditable = {
|
|
mounted() {
|
|
this.props = getProps(this);
|
|
|
|
this.__updateAttribute();
|
|
|
|
// Set the specified attribute on every content change
|
|
this.el.addEventListener("input", (event) => {
|
|
this.__updateAttribute();
|
|
});
|
|
|
|
// Make sure only plain text is pasted
|
|
this.el.addEventListener("paste", (event) => {
|
|
event.preventDefault();
|
|
const text = event.clipboardData.getData("text/plain");
|
|
document.execCommand("insertText", false, text);
|
|
});
|
|
},
|
|
|
|
updated() {
|
|
this.props = getProps(this);
|
|
|
|
// The element has been re-rendered so we have to add the attribute back
|
|
this.__updateAttribute();
|
|
},
|
|
|
|
__updateAttribute() {
|
|
const value = this.el.innerText.trim();
|
|
this.el.setAttribute(this.props.attribute, value);
|
|
},
|
|
};
|
|
|
|
function getProps(hook) {
|
|
return {
|
|
attribute: getAttributeOrThrow(hook.el, "data-update-attribute"),
|
|
};
|
|
}
|
|
|
|
export default ContentEditable;
|