livebook/assets/js/content_editable/index.js

50 lines
1.2 KiB
JavaScript
Raw Normal View History

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;