@pie-lib/editable-html 11.10.0 → 11.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,7 +3,28 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
- # [11.10.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/editable-html@11.1.1...@pie-lib/editable-html@11.10.0) (2025-08-07)
6
+ # [11.11.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/editable-html@11.1.1...@pie-lib/editable-html@11.11.0) (2025-09-15)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * fixed pie-lib/icons import [PD-5126] ([dcb506c](https://github.com/pie-framework/pie-lib/commit/dcb506c914a177f6d88bf73247a023bfe71dac1f))
12
+
13
+
14
+ ### Features
15
+
16
+ * split pie-toolbox into multiple packages [PD-5126] ([7d55a25](https://github.com/pie-framework/pie-lib/commit/7d55a2552d084cd3d0d5c00dc77411b2ced2f5e2))
17
+
18
+
19
+
20
+
21
+
22
+ ## [11.10.1](https://github.com/pie-framework/pie-lib/compare/@pie-lib/editable-html@11.1.1...@pie-lib/editable-html@11.10.1) (2025-08-11)
23
+
24
+
25
+ ### Bug Fixes
26
+
27
+ * fixed pie-lib/icons import [PD-5126] ([dcb506c](https://github.com/pie-framework/pie-lib/commit/dcb506c914a177f6d88bf73247a023bfe71dac1f))
7
28
 
8
29
 
9
30
  ### Features
@@ -14,6 +35,12 @@ See [Conventional Commits](https://conventionalcommits.org) for commit guideline
14
35
 
15
36
 
16
37
 
38
+ # [11.10.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/editable-html@11.1.1...@pie-lib/editable-html@11.10.0) (2025-08-07)
39
+
40
+ ### Features
41
+
42
+ - split pie-toolbox into multiple packages [PD-5126](<[7d55a25](https://github.com/pie-framework/pie-lib/commit/7d55a2552d084cd3d0d5c00dc77411b2ced2f5e2)>)
43
+
17
44
  # [11.9.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/editable-html@11.1.1...@pie-lib/editable-html@11.9.0) (2025-07-31)
18
45
 
19
46
  **Note:** Version bump only for package @pie-lib/editable-html
package/lib/editor.js CHANGED
@@ -55,6 +55,8 @@ var _slatePlainSerializer = _interopRequireDefault(require("slate-plain-serializ
55
55
 
56
56
  var _propTypes = _interopRequireDefault(require("prop-types"));
57
57
 
58
+ var _debounce = _interopRequireDefault(require("lodash/debounce"));
59
+
58
60
  var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
59
61
 
60
62
  var _classnames = _interopRequireDefault(require("classnames"));
@@ -911,12 +913,11 @@ var Editor = /*#__PURE__*/function (_React$Component) {
911
913
  _this.toggleHtmlMode = _this.toggleHtmlMode.bind((0, _assertThisInitialized2["default"])(_this));
912
914
  _this.handleToolbarFocus = _this.handleToolbarFocus.bind((0, _assertThisInitialized2["default"])(_this));
913
915
  _this.handleToolbarBlur = _this.handleToolbarBlur.bind((0, _assertThisInitialized2["default"])(_this));
914
-
915
- _this.onResize = function () {
916
+ _this.onResize = (0, _debounce["default"])(function () {
916
917
  if (!_this.state.isHtmlMode && _props.onChange) {
917
918
  _props.onChange(_this.state.value, true);
918
919
  }
919
- };
920
+ }, 50);
920
921
 
921
922
  _this.handlePlugins(_this.props);
922
923
 
package/lib/editor.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/editor.jsx"],"names":["log","defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","defaultLanguageCharactersProps","createToolbarOpts","toolbarOpts","error","isHtmlMode","MAX_CHARACTERS_LIMIT","Editor","props","interacted","keypadInteractionDetected","open","extraDialogProps","callback","setState","dialog","prevState","isEditedInHtmlMode","state","newToolbarOpts","normalizedResponseAreaProps","responseAreaProps","htmlPluginOpts","currentValue","value","toggleHtmlMode","handleAlertDialog","handleDialog","pluginProps","customPlugins","plugins","activePlugins","math","onClick","onMathClick","onFocus","onPluginFocus","onBlur","onPluginBlur","mathMlOptions","textAlign","getValue","onChange","html","extraCSSRules","image","disableImageAlignmentButtons","onDelete","imageSupport","node","done","src","data","get","e","newPendingImages","pendingImages","filter","img","key","oldScheduled","scheduled","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onEditingDone","bind","handler","add","maxImageWidth","maxImageHeight","toolbar","disableScrollbar","disableUnderline","autoWidth","autoWidthToolbar","onDone","nonEmpty","toolbarInFocus","focusedNode","focusToolbar","editor","blur","startText","text","resetValue","then","table","responseArea","type","maxResponseAreas","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","focus","createChange","change","uploadSoundSupport","mmlOutput","mmlEditing","runSerializationOnMarkup","relatedTarget","target","stashedValue","stashValue","c","collapseToStartOf","selectedNode","document","previewText","renderHtmlPreviewContent","openHtmlModeConfirmationDialog","classes","ref","elementRef","title","onConfirmText","onCloseText","onConfirm","handleHtmlModeSaveConfirmation","onClose","htmlModeContinueEditing","resolve","event","toolbarElement","toolbarRef","closest","className","isRawDoneButton","doneButtonRef","current","skipBlurHandling","Promise","preBlurValue","handleBlur","editorDOM","querySelector","setTimeout","stateValue","wrapperRef","editorElement","activeElement","isInCurrentComponent","contains","removeEventListener","handleDomBlur","isFocused","isTouchDevice","window","navigator","maxTouchPoints","__TEMPORARY_CHANGE_DATA","domEl","setNodeByKey","addEventListener","shouldFocusEditor","force","stopReset","reduce","s","p","toObject","newValue","Value","fromJSON","toJSON","me","charactersLimit","limit","handlePlugins","v","calcRegex","endsWith","undefined","match","parseInt","isNaN","object","last","nodes","parent","getParent","Block","pos","dropContext","transfer","file","files","fragment","inline","Inline","create","isVoid","loading","range","select","ch","insertInline","InsertImageHandler","fileChosen","insertFragment","selection","startBlock","defaultBlock","defaultMarks","getInsertMarksAtRange","frag","Plain","deserialize","placeholder","size","isEmpty","display","width","maxWidth","whiteSpace","opacity","pointerEvents","userSelect","React","createRef","handleToolbarFocus","handleToolbarBlur","onResize","toolbarContainsFocus","onRef","isResponseAreaEditor","includes","responseAreaEditor","setAttribute","autoFocus","nextProps","differentCharacterProps","differentMathMlProps","differentImageMaxDimensionsProps","equals","prevProps","zeroWidthEls","querySelectorAll","Array","from","forEach","el","style","minWidth","minHeight","height","maxHeight","valueToSize","disabled","spellCheck","highlightShape","isEditor","onKeyDown","showParagraphs","separateParagraphs","otherPluginProps","sizeStyle","buildSizeStyle","names","withBg","toolbarOnTop","uploading","r","slateEditor","editorRef","getFocusedValue","onDropPaste","normalize","noPadding","showParagraph","separateParagraph","renderPlaceholder","changeData","Component","PropTypes","bool","func","isRequired","any","SlateTypes","shape","number","oneOfType","string","oneOf","arrayOf","rules","language","characterIcon","characters","values","allValid","every","ALL_PLUGINS","Error","join","styles","backgroundColor","top","left","transform","fontFamily","tableLayout","borderCollapse","color","background","borderTop","padding","border","content","fontSize","marginBottom","marginTop"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Editor as SlateEditor, findNode, getEventRange, getEventTransfer } from 'slate-react';\nimport SlateTypes from 'slate-prop-types';\nimport { Value, Block, Inline } from 'slate';\nimport Plain from 'slate-plain-serializer';\nimport PropTypes from 'prop-types';\nimport isEqual from 'lodash/isEqual';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { withStyles } from '@material-ui/core/styles';\n\nimport { color } from '@pie-lib/render-ui';\nimport AlertDialog from '../../config-ui/src/alert-dialog';\nimport { PreviewPrompt } from '@pie-lib/render-ui';\n\nimport { getBase64, htmlToValue } from './serialization';\nimport InsertImageHandler from './plugins/image/insert-image-handler';\nimport * as serialization from './serialization';\nimport { buildPlugins, ALL_PLUGINS, DEFAULT_PLUGINS } from './plugins';\n\nexport { ALL_PLUGINS, DEFAULT_PLUGINS, serialization };\n\nconst log = debug('editable-html:editor');\n\nconst defaultToolbarOpts = {\n position: 'bottom',\n alignment: 'left',\n alwaysVisible: false,\n showDone: true,\n doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n options: {},\n respAreaToolbar: () => {},\n onHandleAreaChange: () => {},\n};\n\nconst defaultLanguageCharactersProps = [];\n\nconst createToolbarOpts = (toolbarOpts, error, isHtmlMode) => {\n return {\n ...defaultToolbarOpts,\n ...toolbarOpts,\n error,\n isHtmlMode,\n };\n};\n\n/**\n * The maximum number of characters the editor can support\n * @type {number}\n */\nconst MAX_CHARACTERS_LIMIT = 1000000;\n\nexport class Editor extends React.Component {\n static propTypes = {\n autoFocus: PropTypes.bool,\n editorRef: PropTypes.func.isRequired,\n error: PropTypes.any,\n onRef: PropTypes.func.isRequired,\n onChange: PropTypes.func.isRequired,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n onKeyDown: PropTypes.func,\n focus: PropTypes.func.isRequired,\n value: SlateTypes.value.isRequired,\n imageSupport: PropTypes.object,\n mathMlOptions: PropTypes.shape({\n mmlOutput: PropTypes.bool,\n mmlEditing: PropTypes.bool,\n }),\n disableImageAlignmentButtons: PropTypes.bool,\n uploadSoundSupport: PropTypes.shape({\n add: PropTypes.func,\n delete: PropTypes.func,\n }),\n charactersLimit: PropTypes.number,\n width: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n minHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n classes: PropTypes.object.isRequired,\n highlightShape: PropTypes.bool,\n disabled: PropTypes.bool,\n spellCheck: PropTypes.bool,\n nonEmpty: PropTypes.bool,\n disableScrollbar: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n autoWidthToolbar: PropTypes.bool,\n pluginProps: PropTypes.any,\n // customPlugins should be inside pluginProps (a property inside pluginProps)\n // customPlugins: PropTypes.arrayOf(\n // PropTypes.shape({\n // event: PropTypes.string,\n // icon: PropTypes.string,\n // iconType: PropTypes.string,\n // iconAlt: PropTypes.string\n // }),\n // ),\n placeholder: PropTypes.string,\n isEditor: PropTypes.bool,\n responseAreaProps: PropTypes.shape({\n type: PropTypes.oneOf([\n 'explicit-constructed-response',\n 'inline-dropdown',\n 'drag-in-the-blank',\n 'math-templated',\n ]),\n options: PropTypes.object,\n respAreaToolbar: PropTypes.func,\n onHandleAreaChange: PropTypes.func,\n maxResponseAreas: PropTypes.number,\n error: PropTypes.any,\n }),\n extraCSSRules: PropTypes.shape({\n names: PropTypes.arrayOf(PropTypes.string),\n rules: PropTypes.string,\n }),\n languageCharactersProps: PropTypes.arrayOf(\n PropTypes.shape({\n language: PropTypes.string,\n characterIcon: PropTypes.string,\n characters: PropTypes.arrayOf(PropTypes.arrayOf(PropTypes.string)),\n }),\n ),\n runSerializationOnMarkup: PropTypes.func,\n toolbarOpts: PropTypes.shape({\n position: PropTypes.oneOf(['bottom', 'top']),\n alignment: PropTypes.oneOf(['left', 'right']),\n alwaysVisible: PropTypes.bool,\n showDone: PropTypes.bool,\n doneOn: PropTypes.string,\n minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n }),\n activePlugins: PropTypes.arrayOf((values) => {\n const allValid = values.every((v) => ALL_PLUGINS.includes(v));\n\n return !allValid && new Error(`Invalid values: ${values}, values must be one of [${ALL_PLUGINS.join(',')}]`);\n }),\n className: PropTypes.string,\n maxImageWidth: PropTypes.number,\n maxImageHeight: PropTypes.number,\n };\n\n static defaultProps = {\n disableUnderline: true,\n onFocus: () => {},\n onBlur: () => {},\n onKeyDown: () => {},\n runSerializationOnMarkup: () => {},\n mathMlOptions: {\n mmlOutput: false,\n mmlEditing: false,\n },\n toolbarOpts: defaultToolbarOpts,\n responseAreaProps: defaultResponseAreaProps,\n languageCharactersProps: defaultLanguageCharactersProps,\n extraCSSRules: null,\n isEditor: false,\n };\n\n constructor(props) {\n super(props);\n this.state = {\n value: props.value,\n toolbarOpts: createToolbarOpts(props.toolbarOpts, props.error),\n pendingImages: [],\n isHtmlMode: false,\n isEditedInHtmlMode: false,\n focusToolbar: false,\n dialog: {\n open: false,\n },\n };\n\n this.keyPadCharacterRef = React.createRef();\n this.doneButtonRef = React.createRef();\n this.keypadInteractionDetected = false;\n\n this.toggleHtmlMode = this.toggleHtmlMode.bind(this);\n this.handleToolbarFocus = this.handleToolbarFocus.bind(this);\n this.handleToolbarBlur = this.handleToolbarBlur.bind(this);\n\n this.onResize = () => {\n if (!this.state.isHtmlMode && props.onChange) {\n props.onChange(this.state.value, true);\n }\n };\n\n this.handlePlugins(this.props);\n }\n\n handleToolbarFocus() {\n if (this.state.focusToolbar) {\n return;\n }\n\n this.setState({ focusToolbar: true });\n }\n\n setKeypadInteraction = (interacted) => {\n this.keypadInteractionDetected = interacted;\n };\n\n handleToolbarBlur() {\n setTimeout(() => {\n if (!this.toolbarContainsFocus()) {\n this.setState({ focusToolbar: false });\n }\n }, 0);\n }\n\n toolbarContainsFocus() {\n if (!this.toolbarRef) return false;\n const toolbarElement = this.toolbarRef;\n const activeElement = document.activeElement;\n\n return toolbarElement && toolbarElement.contains(activeElement);\n }\n\n handleDialog = (open, extraDialogProps = {}, callback) => {\n this.setState(\n {\n dialog: {\n open,\n ...extraDialogProps,\n },\n },\n callback,\n );\n };\n\n toggleHtmlMode = () => {\n this.setState(\n (prevState) => ({\n isHtmlMode: !prevState.isHtmlMode,\n isEditedInHtmlMode: false,\n }),\n () => {\n const { error } = this.props;\n const { toolbarOpts } = this.state;\n const newToolbarOpts = createToolbarOpts(toolbarOpts, error, this.state.isHtmlMode);\n this.setState({\n toolbarOpts: newToolbarOpts,\n });\n },\n );\n };\n\n handlePlugins = (props) => {\n const normalizedResponseAreaProps = {\n ...defaultResponseAreaProps,\n ...props.responseAreaProps,\n };\n\n const htmlPluginOpts = {\n currentValue: this.props.value,\n isHtmlMode: this.state.isHtmlMode,\n isEditedInHtmlMode: this.state.isEditedInHtmlMode,\n toggleHtmlMode: this.toggleHtmlMode,\n handleAlertDialog: this.handleDialog,\n };\n let { customPlugins } = props.pluginProps || {};\n customPlugins = customPlugins || [];\n\n this.plugins = buildPlugins(props.activePlugins, customPlugins, {\n math: {\n onClick: this.onMathClick,\n onFocus: this.onPluginFocus,\n onBlur: this.onPluginBlur,\n ...props.mathMlOptions,\n },\n textAlign: {\n getValue: () => this.state.value,\n onChange: this.onChange,\n },\n html: htmlPluginOpts,\n extraCSSRules: props.extraCSSRules || {},\n image: {\n disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n onDelete:\n props.imageSupport &&\n props.imageSupport.delete &&\n ((node, done) => {\n const src = node.data.get('src');\n\n props.imageSupport.delete(src, (e) => {\n const newPendingImages = this.state.pendingImages.filter((img) => img.key !== node.key);\n const { scheduled: oldScheduled } = this.state;\n const newState = {\n pendingImages: newPendingImages,\n scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled,\n };\n\n this.setState(newState, () => done(e, this.state.value));\n });\n }),\n insertImageRequested:\n props.imageSupport &&\n ((addedImage, getHandler) => {\n const { pendingImages } = this.state;\n const onFinish = (result) => {\n let cb;\n\n if (this.state.scheduled && result) {\n // finish editing only on success\n cb = this.onEditingDone.bind(this);\n }\n\n const newPendingImages = this.state.pendingImages.filter((img) => img.key !== addedImage.key);\n const newState = {\n pendingImages: newPendingImages,\n };\n\n if (newPendingImages.length === 0) {\n newState.scheduled = false;\n }\n\n this.setState(newState, cb);\n };\n const callback = () => {\n /**\n * The handler is the object through which the outer context\n * communicates file upload events like: fileChosen, cancel, progress\n */\n const handler = getHandler(onFinish, () => this.state.value);\n props.imageSupport.add(handler);\n };\n\n this.setState(\n {\n pendingImages: [...pendingImages, addedImage],\n },\n callback,\n );\n }),\n onFocus: this.onPluginFocus,\n onBlur: this.onPluginBlur,\n maxImageWidth: props.maxImageWidth,\n maxImageHeight: props.maxImageHeight,\n },\n toolbar: {\n /**\n * To minimize converting html -> state -> html\n * We only emit markup once 'done' is clicked.\n */\n disableScrollbar: !!props.disableScrollbar,\n disableUnderline: props.disableUnderline,\n autoWidth: props.autoWidthToolbar,\n onDone: () => {\n const { nonEmpty } = props;\n\n log('[onDone]');\n this.setState({ toolbarInFocus: false, focusedNode: null, focusToolbar: false });\n this.editor.blur();\n\n if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n this.resetValue(true).then(() => {\n this.onEditingDone();\n });\n } else {\n this.onEditingDone();\n }\n },\n },\n table: {\n onFocus: () => {\n log('[table:onFocus]...');\n this.onPluginFocus();\n },\n onBlur: () => {\n log('[table:onBlur]...');\n this.onPluginBlur();\n },\n },\n responseArea: {\n type: normalizedResponseAreaProps.type,\n options: normalizedResponseAreaProps.options,\n maxResponseAreas: normalizedResponseAreaProps.maxResponseAreas,\n respAreaToolbar: normalizedResponseAreaProps.respAreaToolbar,\n onHandleAreaChange: normalizedResponseAreaProps.onHandleAreaChange,\n error: normalizedResponseAreaProps.error,\n onFocus: () => {\n log('[table:onFocus]...');\n this.onPluginFocus();\n },\n onBlur: () => {\n log('[table:onBlur]...');\n this.onPluginBlur();\n },\n },\n languageCharacters: props.languageCharactersProps,\n keyPadCharacterRef: this.keyPadCharacterRef,\n setKeypadInteraction: this.setKeypadInteraction,\n media: {\n focus: this.focus,\n createChange: () => this.state.value.change(),\n onChange: this.onChange,\n uploadSoundSupport: props.uploadSoundSupport,\n },\n });\n\n if (props.mathMlOptions.mmlOutput || props.mathMlOptions.mmlEditing) {\n this.props.runSerializationOnMarkup();\n }\n };\n\n componentDidMount() {\n // onRef is needed to get the ref of the component because we export it using withStyles\n this.props.onRef(this);\n\n window.addEventListener('resize', this.onResize);\n\n const isResponseAreaEditor = this.props.className?.includes('response-area-editor');\n\n if (isResponseAreaEditor && this.editor) {\n const responseAreaEditor = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n if (responseAreaEditor) {\n responseAreaEditor.setAttribute('aria-label', 'Answer');\n }\n }\n\n if (this.editor && this.props.autoFocus) {\n Promise.resolve().then(() => {\n if (this.editor) {\n const editorDOM = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n this.editor.focus();\n\n if (editorDOM) {\n editorDOM.focus();\n }\n }\n });\n }\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n const { isHtmlMode, toolbarOpts } = this.state;\n const newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);\n\n if (!isEqual(newToolbarOpts, toolbarOpts)) {\n this.setState({\n toolbarOpts: newToolbarOpts,\n });\n }\n\n const differentCharacterProps = !isEqual(nextProps.languageCharactersProps, this.props.languageCharactersProps);\n const differentMathMlProps = !isEqual(nextProps.mathMlOptions, this.props.mathMlOptions);\n const differentImageMaxDimensionsProps =\n !isEqual(nextProps.maxImageWidth, this.props.maxImageWidth) ||\n !isEqual(nextProps.maxImageHeight, this.props.maxImageHeight);\n\n if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {\n this.handlePlugins(nextProps);\n }\n\n if (!nextProps.value?.document?.equals(this.props.value?.document)) {\n this.setState({\n focus: false,\n value: nextProps.value,\n });\n }\n }\n\n componentDidUpdate(prevProps, prevState) {\n // The cursor is on a zero width element and when that is placed near void elements, it is not visible\n // so we increase the width to at least 2px in order for the user to see it\n\n // Trigger plugins and finish editing if:\n // 1. The 'isHtmlMode' state has been toggled.\n // 2. We're currently in 'isHtmlMode' and the editor value has been modified.\n if (\n this.state.isHtmlMode !== prevState.isHtmlMode ||\n (this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode)\n ) {\n this.handlePlugins(this.props);\n }\n\n const zeroWidthEls = document.querySelectorAll('[data-slate-zero-width=\"z\"]');\n\n Array.from(zeroWidthEls).forEach((el) => {\n el.style.minWidth = '2px';\n el.style.display = 'inline-block';\n });\n }\n\n onPluginBlur = (e) => {\n log('[onPluginBlur]', e && e.relatedTarget);\n const target = e && e.relatedTarget;\n\n const node = target ? findNode(target, this.state.value) : null;\n log('[onPluginBlur] node: ', node);\n this.setState({ focusedNode: node }, () => {\n this.resetValue();\n });\n };\n\n onPluginFocus = (e) => {\n log('[onPluginFocus]', e && e.target);\n const target = e && e.target;\n if (target) {\n const node = findNode(target, this.state.value);\n log('[onPluginFocus] node: ', node);\n\n const stashedValue = this.state.stashedValue || this.state.value;\n this.setState({ focusedNode: node, stashedValue });\n } else {\n this.setState({ focusedNode: null });\n }\n this.stashValue();\n };\n\n onMathClick = (node) => {\n this.editor.change((c) => c.collapseToStartOf(node));\n this.setState({ selectedNode: node });\n };\n\n onEditingDone = () => {\n const { isHtmlMode, dialog, value, pendingImages } = this.state;\n\n // Handling HTML mode and dialog state\n if (isHtmlMode) {\n // Early return if HTML mode is enabled\n if (dialog?.open) return;\n\n const currentValue = htmlToValue(value.document.text);\n const previewText = this.renderHtmlPreviewContent();\n\n this.openHtmlModeConfirmationDialog(currentValue, previewText);\n return;\n }\n\n if (pendingImages.length) {\n // schedule image processing\n this.setState({ scheduled: true });\n return;\n }\n\n // Finalizing editing\n log('[onEditingDone]');\n this.setState({ pendingImages: [], stashedValue: null, focusedNode: null });\n log('[onEditingDone] value: ', this.state.value);\n this.props.onChange(this.state.value, true);\n };\n\n /**\n * Renders the HTML preview content to be displayed inside the dialog.\n * This content includes the edited HTML and a prompt for the user.\n */\n renderHtmlPreviewContent = () => {\n const { classes } = this.props;\n return (\n <div ref={(ref) => (this.elementRef = ref)}>\n <div>Preview of Edited Html:</div>\n <PreviewPrompt defaultClassName={classes.previewText} prompt={this.state.value.document.text} />\n <div>Would you like to save these changes ?</div>\n </div>\n );\n };\n\n /**\n * Opens a confirmation dialog in HTML mode, displaying the preview of the current HTML content\n * and offering options to save or continue editing.\n */\n openHtmlModeConfirmationDialog = (currentValue, previewText) => {\n this.setState({\n dialog: {\n open: true,\n title: 'Content Preview & Save',\n text: previewText,\n onConfirmText: 'Save changes',\n onCloseText: 'Continue editing',\n onConfirm: () => {\n this.handleHtmlModeSaveConfirmation(currentValue);\n },\n onClose: this.htmlModeContinueEditing,\n },\n });\n };\n\n /**\n * Handles the save confirmation action in HTML mode. This updates the value to the confirmed\n * content, updates value on props, and exits the HTML mode.\n * @param {string} currentValue - The confirmed value of the HTML content to save.\n */\n handleHtmlModeSaveConfirmation = (currentValue) => {\n this.setState({ value: currentValue });\n this.props.onChange(currentValue, true);\n this.handleDialog(false);\n this.toggleHtmlMode();\n };\n\n /**\n * Closes the dialog in HTML mode and allows the user to continue editing the html content.\n * This function is invoked when the user opts to not save the current changes.\n */\n htmlModeContinueEditing = () => {\n this.handleDialog(false);\n };\n\n /**\n * Remove onResize event listener\n */\n componentWillUnmount() {\n window.removeEventListener('resize', this.onResize);\n }\n\n // Allowing time for onChange to take effect if it is called\n handleBlur = (resolve) => {\n const { nonEmpty } = this.props;\n const {\n toolbarOpts: { doneOn },\n } = this.state;\n\n this.setState({ toolbarInFocus: false, focusedNode: null });\n\n if (this.editor) {\n this.editor.blur();\n }\n\n if (doneOn === 'blur') {\n if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n this.resetValue(true).then(() => {\n this.onEditingDone();\n resolve();\n });\n } else {\n this.onEditingDone();\n resolve();\n }\n }\n };\n\n onBlur = (event) => {\n log('[onBlur]');\n const relatedTarget = event.relatedTarget;\n const toolbarElement = this.toolbarRef && relatedTarget?.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n\n // Check if relatedTarget is a done button\n const isRawDoneButton =\n this.doneButtonRef && relatedTarget?.closest(`[class*=\"${this.doneButtonRef.current?.className}\"]`);\n\n // Skip onBlur handling if relatedTarget is a button from the KeyPad characters\n this.skipBlurHandling = this.keypadInteractionDetected && relatedTarget !== null;\n\n if (toolbarElement && !isRawDoneButton && !this.state.focusToolbar) {\n this.setState({\n focusToolbar: true,\n });\n }\n\n const node = relatedTarget ? findNode(relatedTarget, this.state.value) : null;\n\n log('[onBlur] node: ', node);\n\n return new Promise((resolve) => {\n if (!this.skipBlurHandling) {\n this.setKeypadInteraction(false);\n this.setState(\n { preBlurValue: this.state.value, focusedNode: !node ? null : node },\n this.handleBlur.bind(this, resolve),\n );\n }\n\n this.props.onBlur(event);\n });\n };\n\n handleDomBlur = (e) => {\n const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n\n setTimeout(() => {\n const { value: stateValue } = this.state;\n\n if (!this.wrapperRef) {\n return;\n }\n\n const editorElement = !editorDOM || document.activeElement.closest(`[class*=\"${editorDOM.className}\"]`);\n const toolbarElement =\n !this.toolbarRef || document.activeElement.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n const isInCurrentComponent = this.wrapperRef.contains(editorElement) || this.wrapperRef.contains(toolbarElement);\n\n if (!isInCurrentComponent) {\n editorDOM.removeEventListener('blur', this.handleDomBlur);\n\n if (stateValue.isFocused) {\n this.onBlur(e);\n }\n }\n }, 50);\n };\n\n /*\n * Needs to be wrapped otherwise it causes issues because of race conditions\n * Known issue for slatejs. See: https://github.com/ianstormtaylor/slate/issues/2097\n * Using timeout I wasn't able to test this\n *\n * Note: The use of promises has been causing issues with MathQuill\n * */\n onFocus = (event, change) =>\n new Promise((resolve) => {\n const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n const isTouchDevice =\n typeof window !== 'undefined' && ('ontouchstart' in window || navigator?.maxTouchPoints > 0);\n\n log('[onFocus]', document.activeElement);\n\n if (this.keypadInteractionDetected && this.__TEMPORARY_CHANGE_DATA) {\n this.__TEMPORARY_CHANGE_DATA = null;\n }\n\n /**\n * This is a temporary hack - @see changeData below for some more information.\n */\n if (this.__TEMPORARY_CHANGE_DATA) {\n const { key, data } = this.__TEMPORARY_CHANGE_DATA;\n const domEl = document.querySelector(`[data-key=\"${key}\"]`);\n\n if (domEl) {\n let change = this.state.value.change().setNodeByKey(key, { data });\n this.setState({ value: change.value }, () => {\n this.__TEMPORARY_CHANGE_DATA = null;\n });\n }\n }\n\n /**\n * This is needed just in case the browser decides to make the editor\n * lose focus without triggering the onBlur event (can happen in a few cases).\n * This will also trigger onBlur if the user clicks outside of the page when the editor\n * is focused.\n */\n if (editorDOM === document.activeElement) {\n editorDOM.removeEventListener('blur', this.handleDomBlur);\n editorDOM.addEventListener('blur', this.handleDomBlur);\n }\n\n this.stashValue();\n this.props.onFocus();\n\n // Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation\n const shouldFocusEditor = !this.keypadInteractionDetected && !isTouchDevice;\n\n if (shouldFocusEditor) {\n change?.focus();\n }\n\n resolve();\n });\n\n stashValue = () => {\n log('[stashValue]');\n\n if (!this.state.stashedValue) {\n this.setState({ stashedValue: this.state.value });\n }\n };\n\n /**\n * Reset the value if the user didn't click done.\n */\n resetValue = (force) => {\n const { value, focusedNode } = this.state;\n\n const stopReset = this.plugins.reduce((s, p) => {\n return s || (p.stopReset && p.stopReset(this.state.value));\n }, false);\n\n log('[resetValue]', value.isFocused, focusedNode, 'stopReset: ', stopReset);\n if ((this.state.stashedValue && !value.isFocused && !focusedNode && !stopReset) || force) {\n log('[resetValue] resetting...');\n log('stashed', this.state.stashedValue.document.toObject());\n log('current', this.state.value.document.toObject());\n\n const newValue = Value.fromJSON(this.state.stashedValue.toJSON());\n\n log('newValue: ', newValue.document);\n return new Promise((resolve) => {\n setTimeout(() => {\n this.setState({ value: newValue, stashedValue: null }, () => {\n log('value now: ', this.state.value.document.toJSON());\n resolve();\n });\n }, 50);\n });\n } else {\n return Promise.resolve({});\n }\n };\n\n onChange = (change, done) => {\n log('[onChange]');\n window.me = this;\n\n const { value } = change;\n const { charactersLimit } = this.props;\n let limit = charactersLimit;\n if (!limit || limit > MAX_CHARACTERS_LIMIT) {\n limit = MAX_CHARACTERS_LIMIT;\n }\n\n if (value && value.document && value.document.text && value.document.text.length > limit) {\n return;\n }\n\n // Mark the editor as edited when in HTML mode and its content has changed.\n // This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.\n const isEditedInHtmlMode = !this.state.isHtmlMode\n ? false\n : this.state.value.document.text !== value.document.text\n ? true\n : this.state.isEditedInHtmlMode;\n\n if (isEditedInHtmlMode != this.state.isEditedInHtmlMode) {\n this.handlePlugins(this.props);\n }\n\n this.setState({ value, isEditedInHtmlMode }, () => {\n log('[onChange], call done()');\n\n if (done) {\n done();\n }\n });\n };\n\n getFocusedValue = () => {\n if (this.state.value.isFocused) {\n return this.state.value;\n }\n\n return this.state.preBlurValue;\n };\n\n valueToSize = (v) => {\n if (!v) {\n return;\n }\n const calcRegex = /^calc\\((.*)\\)$/;\n\n if (typeof v === 'string') {\n if (v.endsWith('%')) {\n return undefined;\n } else if (\n v.endsWith('px') ||\n v.endsWith('vh') ||\n v.endsWith('vw') ||\n v.endsWith('ch') ||\n v.endsWith('em') ||\n v.match(calcRegex)\n ) {\n return v;\n } else {\n const value = parseInt(v, 10);\n return isNaN(value) ? value : `${value}px`;\n }\n }\n if (typeof v === 'number') {\n return `${v}px`;\n }\n };\n\n buildSizeStyle() {\n const { minWidth, width, maxWidth, minHeight, height, maxHeight } = this.props;\n\n return {\n width: this.valueToSize(width),\n minWidth: this.valueToSize(minWidth),\n maxWidth: this.valueToSize(maxWidth),\n height: this.valueToSize(height),\n minHeight: this.valueToSize(minHeight),\n maxHeight: this.valueToSize(maxHeight),\n };\n }\n\n validateNode = (node) => {\n if (node.object !== 'block') return;\n\n const last = node.nodes.last();\n if (!last) return;\n\n if (last.type !== 'image') return;\n\n log('[validateNode] last is image..');\n\n const parent = last.getParent(last.key);\n const p = Block.getParent(last.key);\n log('[validateNode] parent:', parent, p);\n\n return undefined;\n };\n\n changeData = (key, data) => {\n log('[changeData]. .. ', key, data);\n\n /**\n * HACK ALERT: We should be calling setState here and storing the change data:\n *\n * <code>this.setState({changeData: { key, data}})</code>\n * However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no\n * more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these\n * brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle\n * on this hack rather than spend more time on this.\n */\n\n // Uncomment this line to see the bug described above.\n // this.setState({changeData: {key, data}})\n\n this.__TEMPORARY_CHANGE_DATA = { key, data };\n };\n\n focus = (pos, node) => {\n const position = pos || 'end';\n\n this.props.focus(position, node);\n };\n\n onDropPaste = async (event, change, dropContext) => {\n const editor = change.editor;\n const transfer = getEventTransfer(event);\n const file = transfer.files && transfer.files[0];\n\n const type = transfer.type;\n const fragment = transfer.fragment;\n const text = transfer.text;\n\n if (file && (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png')) {\n if (!this.props.imageSupport) {\n return;\n }\n try {\n log('[onDropPaste]');\n const src = await getBase64(file);\n const inline = Inline.create({\n type: 'image',\n isVoid: true,\n data: {\n loading: false,\n src,\n },\n });\n\n if (dropContext) {\n this.focus();\n } else {\n const range = getEventRange(event, editor);\n if (range) {\n change.select(range);\n }\n }\n\n const ch = change.insertInline(inline);\n this.onChange(ch);\n const handler = new InsertImageHandler(\n inline,\n () => {},\n () => this.state.value,\n this.onChange,\n true,\n );\n handler.fileChosen(file);\n this.props.imageSupport.add(handler);\n } catch (err) {\n log('[onDropPaste] error: ', err);\n }\n } else if (type === 'fragment') {\n change.insertFragment(fragment);\n } else if (type === 'text' || type === 'html') {\n if (!text) {\n return;\n }\n const {\n value: { document, selection, startBlock },\n } = change;\n\n if (startBlock.isVoid) {\n return;\n }\n\n const defaultBlock = startBlock;\n const defaultMarks = document.getInsertMarksAtRange(selection);\n const frag = Plain.deserialize(text, {\n defaultBlock,\n defaultMarks,\n }).document;\n change.insertFragment(frag);\n }\n };\n\n renderPlaceholder = (props) => {\n const { editor } = props;\n const { document } = editor.value;\n\n if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {\n return false;\n }\n\n return (\n <span\n contentEditable={false}\n style={{\n display: 'inline-block',\n width: 'fit-content', // for centering the placeholder if text-align is set to center\n maxWidth: '100%',\n whiteSpace: 'nowrap',\n opacity: '0.33',\n pointerEvents: 'none',\n userSelect: 'none',\n }}\n >\n {editor.props.placeholder}\n </span>\n );\n };\n\n render() {\n const {\n disabled,\n spellCheck,\n highlightShape,\n classes,\n className,\n isEditor,\n placeholder,\n pluginProps,\n onKeyDown,\n } = this.props;\n // We don't want to send customPlugins to slate.\n // Not sure if they would do any harm, but I think it's better to not send them.\n // We use custom plugins to be able to add custom buttons\n // eslint-disable-next-line no-unused-vars\n const { customPlugins, showParagraphs, separateParagraphs, ...otherPluginProps } = pluginProps || {};\n\n const { value, focusedNode, toolbarOpts, dialog, scheduled } = this.state;\n\n log('[render] value: ', value);\n const sizeStyle = this.buildSizeStyle();\n const names = classNames(\n {\n [classes.withBg]: highlightShape,\n [classes.toolbarOnTop]: toolbarOpts.alwaysVisible && toolbarOpts.position === 'top',\n [classes.scheduled]: scheduled,\n },\n className,\n );\n\n return (\n <div\n ref={(ref) => (this.wrapperRef = ref)}\n style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n className={names}\n id={`editor-${value?.document?.key}`}\n >\n {scheduled && <div className={classes.uploading}>Uploading image and then saving...</div>}\n <SlateEditor\n plugins={this.plugins}\n innerRef={(r) => {\n if (r) {\n this.slateEditor = r;\n }\n }}\n ref={(r) => (this.editor = r && this.props.editorRef(r))}\n toolbarRef={(r) => {\n if (r) {\n this.toolbarRef = r;\n }\n }}\n doneButtonRef={this.doneButtonRef}\n value={value}\n focusToolbar={this.state.focusToolbar}\n onToolbarFocus={this.handleToolbarFocus}\n onToolbarBlur={this.handleToolbarBlur}\n focus={this.focus}\n onKeyDown={onKeyDown}\n onChange={this.onChange}\n getFocusedValue={this.getFocusedValue}\n onBlur={this.onBlur}\n onDrop={(event, editor) => this.onDropPaste(event, editor, true)}\n onPaste={(event, editor) => this.onDropPaste(event, editor)}\n onFocus={this.onFocus}\n onEditingDone={this.onEditingDone}\n focusedNode={focusedNode}\n normalize={this.normalize}\n readOnly={disabled}\n spellCheck={spellCheck}\n autoCorrect={spellCheck}\n className={classNames(\n {\n [classes.noPadding]: toolbarOpts?.noPadding,\n [classes.showParagraph]: showParagraphs && !showParagraphs.disabled,\n [classes.separateParagraph]: separateParagraphs && !separateParagraphs.disabled,\n },\n classes.slateEditor,\n )}\n style={{\n minHeight: sizeStyle.minHeight,\n height: sizeStyle.height,\n maxHeight: sizeStyle.maxHeight,\n }}\n pluginProps={otherPluginProps}\n toolbarOpts={toolbarOpts}\n placeholder={placeholder}\n renderPlaceholder={this.renderPlaceholder}\n onDataChange={this.changeData}\n />\n <AlertDialog\n open={dialog.open}\n title={dialog.title}\n text={dialog.text}\n onClose={dialog.onClose}\n onConfirm={dialog.onConfirm}\n onConfirmText={dialog.onConfirmText}\n onCloseText={dialog.onCloseText}\n />\n </div>\n );\n }\n}\n\n// TODO color - hardcoded gray background and keypad colors will need to change too\nconst styles = {\n withBg: {\n backgroundColor: 'rgba(0,0,0,0.06)',\n },\n scheduled: {\n opacity: 0.5,\n pointerEvents: 'none',\n position: 'relative',\n },\n uploading: {\n position: 'absolute',\n top: '50%',\n left: '50%',\n transform: 'translate(-50%, -50%)',\n },\n slateEditor: {\n fontFamily: 'Roboto, sans-serif',\n\n '& table': {\n tableLayout: 'fixed',\n width: '100%',\n borderCollapse: 'collapse',\n color: color.text(),\n backgroundColor: color.background(),\n },\n '& table:not([border=\"1\"]) tr': {\n borderTop: '1px solid #dfe2e5',\n // TODO perhaps secondary color for background, for now disable\n // '&:nth-child(2n)': {\n // backgroundColor: '#f6f8fa'\n // }\n },\n '& td, th': {\n padding: '.6em 1em',\n textAlign: 'center',\n },\n '& table:not([border=\"1\"]) td, th': {\n border: '1px solid #dfe2e5',\n },\n },\n showParagraph: {\n // a div that has a div after it\n '& > div:has(+ div)::after': {\n display: 'block',\n content: '\"¶\"',\n fontSize: '1em',\n color: '#146EB3',\n },\n },\n separateParagraph: {\n // a div that has a div after it\n '& > div:has(+ div)': {\n marginBottom: '1em',\n },\n },\n toolbarOnTop: {\n marginTop: '45px',\n },\n noPadding: {\n padding: '0 !important',\n },\n previewText: {\n marginBottom: '36px',\n marginTop: '6px',\n padding: '20px',\n backgroundColor: 'rgba(0,0,0,0.06)',\n },\n};\n\nexport default withStyles(styles)(Editor);\n"],"file":"editor.js"}
1
+ {"version":3,"sources":["../src/editor.jsx"],"names":["log","defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","defaultLanguageCharactersProps","createToolbarOpts","toolbarOpts","error","isHtmlMode","MAX_CHARACTERS_LIMIT","Editor","props","interacted","keypadInteractionDetected","open","extraDialogProps","callback","setState","dialog","prevState","isEditedInHtmlMode","state","newToolbarOpts","normalizedResponseAreaProps","responseAreaProps","htmlPluginOpts","currentValue","value","toggleHtmlMode","handleAlertDialog","handleDialog","pluginProps","customPlugins","plugins","activePlugins","math","onClick","onMathClick","onFocus","onPluginFocus","onBlur","onPluginBlur","mathMlOptions","textAlign","getValue","onChange","html","extraCSSRules","image","disableImageAlignmentButtons","onDelete","imageSupport","node","done","src","data","get","e","newPendingImages","pendingImages","filter","img","key","oldScheduled","scheduled","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onEditingDone","bind","handler","add","maxImageWidth","maxImageHeight","toolbar","disableScrollbar","disableUnderline","autoWidth","autoWidthToolbar","onDone","nonEmpty","toolbarInFocus","focusedNode","focusToolbar","editor","blur","startText","text","resetValue","then","table","responseArea","type","maxResponseAreas","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","focus","createChange","change","uploadSoundSupport","mmlOutput","mmlEditing","runSerializationOnMarkup","relatedTarget","target","stashedValue","stashValue","c","collapseToStartOf","selectedNode","document","previewText","renderHtmlPreviewContent","openHtmlModeConfirmationDialog","classes","ref","elementRef","title","onConfirmText","onCloseText","onConfirm","handleHtmlModeSaveConfirmation","onClose","htmlModeContinueEditing","resolve","event","toolbarElement","toolbarRef","closest","className","isRawDoneButton","doneButtonRef","current","skipBlurHandling","Promise","preBlurValue","handleBlur","editorDOM","querySelector","setTimeout","stateValue","wrapperRef","editorElement","activeElement","isInCurrentComponent","contains","removeEventListener","handleDomBlur","isFocused","isTouchDevice","window","navigator","maxTouchPoints","__TEMPORARY_CHANGE_DATA","domEl","setNodeByKey","addEventListener","shouldFocusEditor","force","stopReset","reduce","s","p","toObject","newValue","Value","fromJSON","toJSON","me","charactersLimit","limit","handlePlugins","v","calcRegex","endsWith","undefined","match","parseInt","isNaN","object","last","nodes","parent","getParent","Block","pos","dropContext","transfer","file","files","fragment","inline","Inline","create","isVoid","loading","range","select","ch","insertInline","InsertImageHandler","fileChosen","insertFragment","selection","startBlock","defaultBlock","defaultMarks","getInsertMarksAtRange","frag","Plain","deserialize","placeholder","size","isEmpty","display","width","maxWidth","whiteSpace","opacity","pointerEvents","userSelect","React","createRef","handleToolbarFocus","handleToolbarBlur","onResize","toolbarContainsFocus","onRef","isResponseAreaEditor","includes","responseAreaEditor","setAttribute","autoFocus","nextProps","differentCharacterProps","differentMathMlProps","differentImageMaxDimensionsProps","equals","prevProps","zeroWidthEls","querySelectorAll","Array","from","forEach","el","style","minWidth","minHeight","height","maxHeight","valueToSize","disabled","spellCheck","highlightShape","isEditor","onKeyDown","showParagraphs","separateParagraphs","otherPluginProps","sizeStyle","buildSizeStyle","names","withBg","toolbarOnTop","uploading","r","slateEditor","editorRef","getFocusedValue","onDropPaste","normalize","noPadding","showParagraph","separateParagraph","renderPlaceholder","changeData","Component","PropTypes","bool","func","isRequired","any","SlateTypes","shape","number","oneOfType","string","oneOf","arrayOf","rules","language","characterIcon","characters","values","allValid","every","ALL_PLUGINS","Error","join","styles","backgroundColor","top","left","transform","fontFamily","tableLayout","borderCollapse","color","background","borderTop","padding","border","content","fontSize","marginBottom","marginTop"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Editor as SlateEditor, findNode, getEventRange, getEventTransfer } from 'slate-react';\nimport SlateTypes from 'slate-prop-types';\nimport { Value, Block, Inline } from 'slate';\nimport Plain from 'slate-plain-serializer';\nimport PropTypes from 'prop-types';\nimport debounce from 'lodash/debounce';\nimport isEqual from 'lodash/isEqual';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { withStyles } from '@material-ui/core/styles';\n\nimport { color } from '@pie-lib/render-ui';\nimport AlertDialog from '../../config-ui/src/alert-dialog';\nimport { PreviewPrompt } from '@pie-lib/render-ui';\n\nimport { getBase64, htmlToValue } from './serialization';\nimport InsertImageHandler from './plugins/image/insert-image-handler';\nimport * as serialization from './serialization';\nimport { buildPlugins, ALL_PLUGINS, DEFAULT_PLUGINS } from './plugins';\n\nexport { ALL_PLUGINS, DEFAULT_PLUGINS, serialization };\n\nconst log = debug('editable-html:editor');\n\nconst defaultToolbarOpts = {\n position: 'bottom',\n alignment: 'left',\n alwaysVisible: false,\n showDone: true,\n doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n options: {},\n respAreaToolbar: () => {},\n onHandleAreaChange: () => {},\n};\n\nconst defaultLanguageCharactersProps = [];\n\nconst createToolbarOpts = (toolbarOpts, error, isHtmlMode) => {\n return {\n ...defaultToolbarOpts,\n ...toolbarOpts,\n error,\n isHtmlMode,\n };\n};\n\n/**\n * The maximum number of characters the editor can support\n * @type {number}\n */\nconst MAX_CHARACTERS_LIMIT = 1000000;\n\nexport class Editor extends React.Component {\n static propTypes = {\n autoFocus: PropTypes.bool,\n editorRef: PropTypes.func.isRequired,\n error: PropTypes.any,\n onRef: PropTypes.func.isRequired,\n onChange: PropTypes.func.isRequired,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n onKeyDown: PropTypes.func,\n focus: PropTypes.func.isRequired,\n value: SlateTypes.value.isRequired,\n imageSupport: PropTypes.object,\n mathMlOptions: PropTypes.shape({\n mmlOutput: PropTypes.bool,\n mmlEditing: PropTypes.bool,\n }),\n disableImageAlignmentButtons: PropTypes.bool,\n uploadSoundSupport: PropTypes.shape({\n add: PropTypes.func,\n delete: PropTypes.func,\n }),\n charactersLimit: PropTypes.number,\n width: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n minHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n maxHeight: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n classes: PropTypes.object.isRequired,\n highlightShape: PropTypes.bool,\n disabled: PropTypes.bool,\n spellCheck: PropTypes.bool,\n nonEmpty: PropTypes.bool,\n disableScrollbar: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n autoWidthToolbar: PropTypes.bool,\n pluginProps: PropTypes.any,\n // customPlugins should be inside pluginProps (a property inside pluginProps)\n // customPlugins: PropTypes.arrayOf(\n // PropTypes.shape({\n // event: PropTypes.string,\n // icon: PropTypes.string,\n // iconType: PropTypes.string,\n // iconAlt: PropTypes.string\n // }),\n // ),\n placeholder: PropTypes.string,\n isEditor: PropTypes.bool,\n responseAreaProps: PropTypes.shape({\n type: PropTypes.oneOf([\n 'explicit-constructed-response',\n 'inline-dropdown',\n 'drag-in-the-blank',\n 'math-templated',\n ]),\n options: PropTypes.object,\n respAreaToolbar: PropTypes.func,\n onHandleAreaChange: PropTypes.func,\n maxResponseAreas: PropTypes.number,\n error: PropTypes.any,\n }),\n extraCSSRules: PropTypes.shape({\n names: PropTypes.arrayOf(PropTypes.string),\n rules: PropTypes.string,\n }),\n languageCharactersProps: PropTypes.arrayOf(\n PropTypes.shape({\n language: PropTypes.string,\n characterIcon: PropTypes.string,\n characters: PropTypes.arrayOf(PropTypes.arrayOf(PropTypes.string)),\n }),\n ),\n runSerializationOnMarkup: PropTypes.func,\n toolbarOpts: PropTypes.shape({\n position: PropTypes.oneOf(['bottom', 'top']),\n alignment: PropTypes.oneOf(['left', 'right']),\n alwaysVisible: PropTypes.bool,\n showDone: PropTypes.bool,\n doneOn: PropTypes.string,\n minWidth: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n }),\n activePlugins: PropTypes.arrayOf((values) => {\n const allValid = values.every((v) => ALL_PLUGINS.includes(v));\n\n return !allValid && new Error(`Invalid values: ${values}, values must be one of [${ALL_PLUGINS.join(',')}]`);\n }),\n className: PropTypes.string,\n maxImageWidth: PropTypes.number,\n maxImageHeight: PropTypes.number,\n };\n\n static defaultProps = {\n disableUnderline: true,\n onFocus: () => {},\n onBlur: () => {},\n onKeyDown: () => {},\n runSerializationOnMarkup: () => {},\n mathMlOptions: {\n mmlOutput: false,\n mmlEditing: false,\n },\n toolbarOpts: defaultToolbarOpts,\n responseAreaProps: defaultResponseAreaProps,\n languageCharactersProps: defaultLanguageCharactersProps,\n extraCSSRules: null,\n isEditor: false,\n };\n\n constructor(props) {\n super(props);\n this.state = {\n value: props.value,\n toolbarOpts: createToolbarOpts(props.toolbarOpts, props.error),\n pendingImages: [],\n isHtmlMode: false,\n isEditedInHtmlMode: false,\n focusToolbar: false,\n dialog: {\n open: false,\n },\n };\n\n this.keyPadCharacterRef = React.createRef();\n this.doneButtonRef = React.createRef();\n this.keypadInteractionDetected = false;\n\n this.toggleHtmlMode = this.toggleHtmlMode.bind(this);\n this.handleToolbarFocus = this.handleToolbarFocus.bind(this);\n this.handleToolbarBlur = this.handleToolbarBlur.bind(this);\n\n this.onResize = debounce(() => {\n if (!this.state.isHtmlMode && props.onChange) {\n props.onChange(this.state.value, true);\n }\n }, 50);\n\n this.handlePlugins(this.props);\n }\n\n handleToolbarFocus() {\n if (this.state.focusToolbar) {\n return;\n }\n\n this.setState({ focusToolbar: true });\n }\n\n setKeypadInteraction = (interacted) => {\n this.keypadInteractionDetected = interacted;\n };\n\n handleToolbarBlur() {\n setTimeout(() => {\n if (!this.toolbarContainsFocus()) {\n this.setState({ focusToolbar: false });\n }\n }, 0);\n }\n\n toolbarContainsFocus() {\n if (!this.toolbarRef) return false;\n const toolbarElement = this.toolbarRef;\n const activeElement = document.activeElement;\n\n return toolbarElement && toolbarElement.contains(activeElement);\n }\n\n handleDialog = (open, extraDialogProps = {}, callback) => {\n this.setState(\n {\n dialog: {\n open,\n ...extraDialogProps,\n },\n },\n callback,\n );\n };\n\n toggleHtmlMode = () => {\n this.setState(\n (prevState) => ({\n isHtmlMode: !prevState.isHtmlMode,\n isEditedInHtmlMode: false,\n }),\n () => {\n const { error } = this.props;\n const { toolbarOpts } = this.state;\n const newToolbarOpts = createToolbarOpts(toolbarOpts, error, this.state.isHtmlMode);\n this.setState({\n toolbarOpts: newToolbarOpts,\n });\n },\n );\n };\n\n handlePlugins = (props) => {\n const normalizedResponseAreaProps = {\n ...defaultResponseAreaProps,\n ...props.responseAreaProps,\n };\n\n const htmlPluginOpts = {\n currentValue: this.props.value,\n isHtmlMode: this.state.isHtmlMode,\n isEditedInHtmlMode: this.state.isEditedInHtmlMode,\n toggleHtmlMode: this.toggleHtmlMode,\n handleAlertDialog: this.handleDialog,\n };\n let { customPlugins } = props.pluginProps || {};\n customPlugins = customPlugins || [];\n\n this.plugins = buildPlugins(props.activePlugins, customPlugins, {\n math: {\n onClick: this.onMathClick,\n onFocus: this.onPluginFocus,\n onBlur: this.onPluginBlur,\n ...props.mathMlOptions,\n },\n textAlign: {\n getValue: () => this.state.value,\n onChange: this.onChange,\n },\n html: htmlPluginOpts,\n extraCSSRules: props.extraCSSRules || {},\n image: {\n disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n onDelete:\n props.imageSupport &&\n props.imageSupport.delete &&\n ((node, done) => {\n const src = node.data.get('src');\n\n props.imageSupport.delete(src, (e) => {\n const newPendingImages = this.state.pendingImages.filter((img) => img.key !== node.key);\n const { scheduled: oldScheduled } = this.state;\n const newState = {\n pendingImages: newPendingImages,\n scheduled: oldScheduled && newPendingImages.length === 0 ? false : oldScheduled,\n };\n\n this.setState(newState, () => done(e, this.state.value));\n });\n }),\n insertImageRequested:\n props.imageSupport &&\n ((addedImage, getHandler) => {\n const { pendingImages } = this.state;\n const onFinish = (result) => {\n let cb;\n\n if (this.state.scheduled && result) {\n // finish editing only on success\n cb = this.onEditingDone.bind(this);\n }\n\n const newPendingImages = this.state.pendingImages.filter((img) => img.key !== addedImage.key);\n const newState = {\n pendingImages: newPendingImages,\n };\n\n if (newPendingImages.length === 0) {\n newState.scheduled = false;\n }\n\n this.setState(newState, cb);\n };\n const callback = () => {\n /**\n * The handler is the object through which the outer context\n * communicates file upload events like: fileChosen, cancel, progress\n */\n const handler = getHandler(onFinish, () => this.state.value);\n props.imageSupport.add(handler);\n };\n\n this.setState(\n {\n pendingImages: [...pendingImages, addedImage],\n },\n callback,\n );\n }),\n onFocus: this.onPluginFocus,\n onBlur: this.onPluginBlur,\n maxImageWidth: props.maxImageWidth,\n maxImageHeight: props.maxImageHeight,\n },\n toolbar: {\n /**\n * To minimize converting html -> state -> html\n * We only emit markup once 'done' is clicked.\n */\n disableScrollbar: !!props.disableScrollbar,\n disableUnderline: props.disableUnderline,\n autoWidth: props.autoWidthToolbar,\n onDone: () => {\n const { nonEmpty } = props;\n\n log('[onDone]');\n this.setState({ toolbarInFocus: false, focusedNode: null, focusToolbar: false });\n this.editor.blur();\n\n if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n this.resetValue(true).then(() => {\n this.onEditingDone();\n });\n } else {\n this.onEditingDone();\n }\n },\n },\n table: {\n onFocus: () => {\n log('[table:onFocus]...');\n this.onPluginFocus();\n },\n onBlur: () => {\n log('[table:onBlur]...');\n this.onPluginBlur();\n },\n },\n responseArea: {\n type: normalizedResponseAreaProps.type,\n options: normalizedResponseAreaProps.options,\n maxResponseAreas: normalizedResponseAreaProps.maxResponseAreas,\n respAreaToolbar: normalizedResponseAreaProps.respAreaToolbar,\n onHandleAreaChange: normalizedResponseAreaProps.onHandleAreaChange,\n error: normalizedResponseAreaProps.error,\n onFocus: () => {\n log('[table:onFocus]...');\n this.onPluginFocus();\n },\n onBlur: () => {\n log('[table:onBlur]...');\n this.onPluginBlur();\n },\n },\n languageCharacters: props.languageCharactersProps,\n keyPadCharacterRef: this.keyPadCharacterRef,\n setKeypadInteraction: this.setKeypadInteraction,\n media: {\n focus: this.focus,\n createChange: () => this.state.value.change(),\n onChange: this.onChange,\n uploadSoundSupport: props.uploadSoundSupport,\n },\n });\n\n if (props.mathMlOptions.mmlOutput || props.mathMlOptions.mmlEditing) {\n this.props.runSerializationOnMarkup();\n }\n };\n\n componentDidMount() {\n // onRef is needed to get the ref of the component because we export it using withStyles\n this.props.onRef(this);\n\n window.addEventListener('resize', this.onResize);\n\n const isResponseAreaEditor = this.props.className?.includes('response-area-editor');\n\n if (isResponseAreaEditor && this.editor) {\n const responseAreaEditor = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n if (responseAreaEditor) {\n responseAreaEditor.setAttribute('aria-label', 'Answer');\n }\n }\n\n if (this.editor && this.props.autoFocus) {\n Promise.resolve().then(() => {\n if (this.editor) {\n const editorDOM = document.querySelector(`[data-key=\"${this.editor.value.document.key}\"]`);\n\n this.editor.focus();\n\n if (editorDOM) {\n editorDOM.focus();\n }\n }\n });\n }\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n const { isHtmlMode, toolbarOpts } = this.state;\n const newToolbarOpts = createToolbarOpts(nextProps.toolbarOpts, nextProps.error, isHtmlMode);\n\n if (!isEqual(newToolbarOpts, toolbarOpts)) {\n this.setState({\n toolbarOpts: newToolbarOpts,\n });\n }\n\n const differentCharacterProps = !isEqual(nextProps.languageCharactersProps, this.props.languageCharactersProps);\n const differentMathMlProps = !isEqual(nextProps.mathMlOptions, this.props.mathMlOptions);\n const differentImageMaxDimensionsProps =\n !isEqual(nextProps.maxImageWidth, this.props.maxImageWidth) ||\n !isEqual(nextProps.maxImageHeight, this.props.maxImageHeight);\n\n if (differentCharacterProps || differentMathMlProps || differentImageMaxDimensionsProps) {\n this.handlePlugins(nextProps);\n }\n\n if (!nextProps.value?.document?.equals(this.props.value?.document)) {\n this.setState({\n focus: false,\n value: nextProps.value,\n });\n }\n }\n\n componentDidUpdate(prevProps, prevState) {\n // The cursor is on a zero width element and when that is placed near void elements, it is not visible\n // so we increase the width to at least 2px in order for the user to see it\n\n // Trigger plugins and finish editing if:\n // 1. The 'isHtmlMode' state has been toggled.\n // 2. We're currently in 'isHtmlMode' and the editor value has been modified.\n if (\n this.state.isHtmlMode !== prevState.isHtmlMode ||\n (this.state.isHtmlMode && !prevState.isEditedInHtmlMode && this.state.isEditedInHtmlMode)\n ) {\n this.handlePlugins(this.props);\n }\n\n const zeroWidthEls = document.querySelectorAll('[data-slate-zero-width=\"z\"]');\n\n Array.from(zeroWidthEls).forEach((el) => {\n el.style.minWidth = '2px';\n el.style.display = 'inline-block';\n });\n }\n\n onPluginBlur = (e) => {\n log('[onPluginBlur]', e && e.relatedTarget);\n const target = e && e.relatedTarget;\n\n const node = target ? findNode(target, this.state.value) : null;\n log('[onPluginBlur] node: ', node);\n this.setState({ focusedNode: node }, () => {\n this.resetValue();\n });\n };\n\n onPluginFocus = (e) => {\n log('[onPluginFocus]', e && e.target);\n const target = e && e.target;\n if (target) {\n const node = findNode(target, this.state.value);\n log('[onPluginFocus] node: ', node);\n\n const stashedValue = this.state.stashedValue || this.state.value;\n this.setState({ focusedNode: node, stashedValue });\n } else {\n this.setState({ focusedNode: null });\n }\n this.stashValue();\n };\n\n onMathClick = (node) => {\n this.editor.change((c) => c.collapseToStartOf(node));\n this.setState({ selectedNode: node });\n };\n\n onEditingDone = () => {\n const { isHtmlMode, dialog, value, pendingImages } = this.state;\n\n // Handling HTML mode and dialog state\n if (isHtmlMode) {\n // Early return if HTML mode is enabled\n if (dialog?.open) return;\n\n const currentValue = htmlToValue(value.document.text);\n const previewText = this.renderHtmlPreviewContent();\n\n this.openHtmlModeConfirmationDialog(currentValue, previewText);\n return;\n }\n\n if (pendingImages.length) {\n // schedule image processing\n this.setState({ scheduled: true });\n return;\n }\n\n // Finalizing editing\n log('[onEditingDone]');\n this.setState({ pendingImages: [], stashedValue: null, focusedNode: null });\n log('[onEditingDone] value: ', this.state.value);\n this.props.onChange(this.state.value, true);\n };\n\n /**\n * Renders the HTML preview content to be displayed inside the dialog.\n * This content includes the edited HTML and a prompt for the user.\n */\n renderHtmlPreviewContent = () => {\n const { classes } = this.props;\n return (\n <div ref={(ref) => (this.elementRef = ref)}>\n <div>Preview of Edited Html:</div>\n <PreviewPrompt defaultClassName={classes.previewText} prompt={this.state.value.document.text} />\n <div>Would you like to save these changes ?</div>\n </div>\n );\n };\n\n /**\n * Opens a confirmation dialog in HTML mode, displaying the preview of the current HTML content\n * and offering options to save or continue editing.\n */\n openHtmlModeConfirmationDialog = (currentValue, previewText) => {\n this.setState({\n dialog: {\n open: true,\n title: 'Content Preview & Save',\n text: previewText,\n onConfirmText: 'Save changes',\n onCloseText: 'Continue editing',\n onConfirm: () => {\n this.handleHtmlModeSaveConfirmation(currentValue);\n },\n onClose: this.htmlModeContinueEditing,\n },\n });\n };\n\n /**\n * Handles the save confirmation action in HTML mode. This updates the value to the confirmed\n * content, updates value on props, and exits the HTML mode.\n * @param {string} currentValue - The confirmed value of the HTML content to save.\n */\n handleHtmlModeSaveConfirmation = (currentValue) => {\n this.setState({ value: currentValue });\n this.props.onChange(currentValue, true);\n this.handleDialog(false);\n this.toggleHtmlMode();\n };\n\n /**\n * Closes the dialog in HTML mode and allows the user to continue editing the html content.\n * This function is invoked when the user opts to not save the current changes.\n */\n htmlModeContinueEditing = () => {\n this.handleDialog(false);\n };\n\n /**\n * Remove onResize event listener\n */\n componentWillUnmount() {\n window.removeEventListener('resize', this.onResize);\n }\n\n // Allowing time for onChange to take effect if it is called\n handleBlur = (resolve) => {\n const { nonEmpty } = this.props;\n const {\n toolbarOpts: { doneOn },\n } = this.state;\n\n this.setState({ toolbarInFocus: false, focusedNode: null });\n\n if (this.editor) {\n this.editor.blur();\n }\n\n if (doneOn === 'blur') {\n if (nonEmpty && this.state.value.startText?.text?.length === 0) {\n this.resetValue(true).then(() => {\n this.onEditingDone();\n resolve();\n });\n } else {\n this.onEditingDone();\n resolve();\n }\n }\n };\n\n onBlur = (event) => {\n log('[onBlur]');\n const relatedTarget = event.relatedTarget;\n const toolbarElement = this.toolbarRef && relatedTarget?.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n\n // Check if relatedTarget is a done button\n const isRawDoneButton =\n this.doneButtonRef && relatedTarget?.closest(`[class*=\"${this.doneButtonRef.current?.className}\"]`);\n\n // Skip onBlur handling if relatedTarget is a button from the KeyPad characters\n this.skipBlurHandling = this.keypadInteractionDetected && relatedTarget !== null;\n\n if (toolbarElement && !isRawDoneButton && !this.state.focusToolbar) {\n this.setState({\n focusToolbar: true,\n });\n }\n\n const node = relatedTarget ? findNode(relatedTarget, this.state.value) : null;\n\n log('[onBlur] node: ', node);\n\n return new Promise((resolve) => {\n if (!this.skipBlurHandling) {\n this.setKeypadInteraction(false);\n this.setState(\n { preBlurValue: this.state.value, focusedNode: !node ? null : node },\n this.handleBlur.bind(this, resolve),\n );\n }\n\n this.props.onBlur(event);\n });\n };\n\n handleDomBlur = (e) => {\n const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n\n setTimeout(() => {\n const { value: stateValue } = this.state;\n\n if (!this.wrapperRef) {\n return;\n }\n\n const editorElement = !editorDOM || document.activeElement.closest(`[class*=\"${editorDOM.className}\"]`);\n const toolbarElement =\n !this.toolbarRef || document.activeElement.closest(`[class*=\"${this.toolbarRef.className}\"]`);\n const isInCurrentComponent = this.wrapperRef.contains(editorElement) || this.wrapperRef.contains(toolbarElement);\n\n if (!isInCurrentComponent) {\n editorDOM.removeEventListener('blur', this.handleDomBlur);\n\n if (stateValue.isFocused) {\n this.onBlur(e);\n }\n }\n }, 50);\n };\n\n /*\n * Needs to be wrapped otherwise it causes issues because of race conditions\n * Known issue for slatejs. See: https://github.com/ianstormtaylor/slate/issues/2097\n * Using timeout I wasn't able to test this\n *\n * Note: The use of promises has been causing issues with MathQuill\n * */\n onFocus = (event, change) =>\n new Promise((resolve) => {\n const editorDOM = document.querySelector(`[data-key=\"${this.state.value.document.key}\"]`);\n const isTouchDevice =\n typeof window !== 'undefined' && ('ontouchstart' in window || navigator?.maxTouchPoints > 0);\n\n log('[onFocus]', document.activeElement);\n\n if (this.keypadInteractionDetected && this.__TEMPORARY_CHANGE_DATA) {\n this.__TEMPORARY_CHANGE_DATA = null;\n }\n\n /**\n * This is a temporary hack - @see changeData below for some more information.\n */\n if (this.__TEMPORARY_CHANGE_DATA) {\n const { key, data } = this.__TEMPORARY_CHANGE_DATA;\n const domEl = document.querySelector(`[data-key=\"${key}\"]`);\n\n if (domEl) {\n let change = this.state.value.change().setNodeByKey(key, { data });\n this.setState({ value: change.value }, () => {\n this.__TEMPORARY_CHANGE_DATA = null;\n });\n }\n }\n\n /**\n * This is needed just in case the browser decides to make the editor\n * lose focus without triggering the onBlur event (can happen in a few cases).\n * This will also trigger onBlur if the user clicks outside of the page when the editor\n * is focused.\n */\n if (editorDOM === document.activeElement) {\n editorDOM.removeEventListener('blur', this.handleDomBlur);\n editorDOM.addEventListener('blur', this.handleDomBlur);\n }\n\n this.stashValue();\n this.props.onFocus();\n\n // Added for accessibility: Ensures the editor gains focus when tabbed to for improved keyboard navigation\n const shouldFocusEditor = !this.keypadInteractionDetected && !isTouchDevice;\n\n if (shouldFocusEditor) {\n change?.focus();\n }\n\n resolve();\n });\n\n stashValue = () => {\n log('[stashValue]');\n\n if (!this.state.stashedValue) {\n this.setState({ stashedValue: this.state.value });\n }\n };\n\n /**\n * Reset the value if the user didn't click done.\n */\n resetValue = (force) => {\n const { value, focusedNode } = this.state;\n\n const stopReset = this.plugins.reduce((s, p) => {\n return s || (p.stopReset && p.stopReset(this.state.value));\n }, false);\n\n log('[resetValue]', value.isFocused, focusedNode, 'stopReset: ', stopReset);\n if ((this.state.stashedValue && !value.isFocused && !focusedNode && !stopReset) || force) {\n log('[resetValue] resetting...');\n log('stashed', this.state.stashedValue.document.toObject());\n log('current', this.state.value.document.toObject());\n\n const newValue = Value.fromJSON(this.state.stashedValue.toJSON());\n\n log('newValue: ', newValue.document);\n return new Promise((resolve) => {\n setTimeout(() => {\n this.setState({ value: newValue, stashedValue: null }, () => {\n log('value now: ', this.state.value.document.toJSON());\n resolve();\n });\n }, 50);\n });\n } else {\n return Promise.resolve({});\n }\n };\n\n onChange = (change, done) => {\n log('[onChange]');\n window.me = this;\n\n const { value } = change;\n const { charactersLimit } = this.props;\n let limit = charactersLimit;\n if (!limit || limit > MAX_CHARACTERS_LIMIT) {\n limit = MAX_CHARACTERS_LIMIT;\n }\n\n if (value && value.document && value.document.text && value.document.text.length > limit) {\n return;\n }\n\n // Mark the editor as edited when in HTML mode and its content has changed.\n // This status will later be used to decide whether to prompt a warning to the user when exiting HTML mode.\n const isEditedInHtmlMode = !this.state.isHtmlMode\n ? false\n : this.state.value.document.text !== value.document.text\n ? true\n : this.state.isEditedInHtmlMode;\n\n if (isEditedInHtmlMode != this.state.isEditedInHtmlMode) {\n this.handlePlugins(this.props);\n }\n\n this.setState({ value, isEditedInHtmlMode }, () => {\n log('[onChange], call done()');\n\n if (done) {\n done();\n }\n });\n };\n\n getFocusedValue = () => {\n if (this.state.value.isFocused) {\n return this.state.value;\n }\n\n return this.state.preBlurValue;\n };\n\n valueToSize = (v) => {\n if (!v) {\n return;\n }\n const calcRegex = /^calc\\((.*)\\)$/;\n\n if (typeof v === 'string') {\n if (v.endsWith('%')) {\n return undefined;\n } else if (\n v.endsWith('px') ||\n v.endsWith('vh') ||\n v.endsWith('vw') ||\n v.endsWith('ch') ||\n v.endsWith('em') ||\n v.match(calcRegex)\n ) {\n return v;\n } else {\n const value = parseInt(v, 10);\n return isNaN(value) ? value : `${value}px`;\n }\n }\n if (typeof v === 'number') {\n return `${v}px`;\n }\n };\n\n buildSizeStyle() {\n const { minWidth, width, maxWidth, minHeight, height, maxHeight } = this.props;\n\n return {\n width: this.valueToSize(width),\n minWidth: this.valueToSize(minWidth),\n maxWidth: this.valueToSize(maxWidth),\n height: this.valueToSize(height),\n minHeight: this.valueToSize(minHeight),\n maxHeight: this.valueToSize(maxHeight),\n };\n }\n\n validateNode = (node) => {\n if (node.object !== 'block') return;\n\n const last = node.nodes.last();\n if (!last) return;\n\n if (last.type !== 'image') return;\n\n log('[validateNode] last is image..');\n\n const parent = last.getParent(last.key);\n const p = Block.getParent(last.key);\n log('[validateNode] parent:', parent, p);\n\n return undefined;\n };\n\n changeData = (key, data) => {\n log('[changeData]. .. ', key, data);\n\n /**\n * HACK ALERT: We should be calling setState here and storing the change data:\n *\n * <code>this.setState({changeData: { key, data}})</code>\n * However this is causing issues with the Mathquill instance. The 'input' event stops firing on the element and no\n * more changes get through. The issues seem to be related to the promises in onBlur/onFocus. But removing these\n * brings it's own problems. A major clean up is planned for this component so I've decided to temporarily settle\n * on this hack rather than spend more time on this.\n */\n\n // Uncomment this line to see the bug described above.\n // this.setState({changeData: {key, data}})\n\n this.__TEMPORARY_CHANGE_DATA = { key, data };\n };\n\n focus = (pos, node) => {\n const position = pos || 'end';\n\n this.props.focus(position, node);\n };\n\n onDropPaste = async (event, change, dropContext) => {\n const editor = change.editor;\n const transfer = getEventTransfer(event);\n const file = transfer.files && transfer.files[0];\n\n const type = transfer.type;\n const fragment = transfer.fragment;\n const text = transfer.text;\n\n if (file && (file.type === 'image/jpeg' || file.type === 'image/jpg' || file.type === 'image/png')) {\n if (!this.props.imageSupport) {\n return;\n }\n try {\n log('[onDropPaste]');\n const src = await getBase64(file);\n const inline = Inline.create({\n type: 'image',\n isVoid: true,\n data: {\n loading: false,\n src,\n },\n });\n\n if (dropContext) {\n this.focus();\n } else {\n const range = getEventRange(event, editor);\n if (range) {\n change.select(range);\n }\n }\n\n const ch = change.insertInline(inline);\n this.onChange(ch);\n const handler = new InsertImageHandler(\n inline,\n () => {},\n () => this.state.value,\n this.onChange,\n true,\n );\n handler.fileChosen(file);\n this.props.imageSupport.add(handler);\n } catch (err) {\n log('[onDropPaste] error: ', err);\n }\n } else if (type === 'fragment') {\n change.insertFragment(fragment);\n } else if (type === 'text' || type === 'html') {\n if (!text) {\n return;\n }\n const {\n value: { document, selection, startBlock },\n } = change;\n\n if (startBlock.isVoid) {\n return;\n }\n\n const defaultBlock = startBlock;\n const defaultMarks = document.getInsertMarksAtRange(selection);\n const frag = Plain.deserialize(text, {\n defaultBlock,\n defaultMarks,\n }).document;\n change.insertFragment(frag);\n }\n };\n\n renderPlaceholder = (props) => {\n const { editor } = props;\n const { document } = editor.value;\n\n if (!editor.props.placeholder || document.text !== '' || document.nodes.size !== 1 || !document.isEmpty) {\n return false;\n }\n\n return (\n <span\n contentEditable={false}\n style={{\n display: 'inline-block',\n width: 'fit-content', // for centering the placeholder if text-align is set to center\n maxWidth: '100%',\n whiteSpace: 'nowrap',\n opacity: '0.33',\n pointerEvents: 'none',\n userSelect: 'none',\n }}\n >\n {editor.props.placeholder}\n </span>\n );\n };\n\n render() {\n const {\n disabled,\n spellCheck,\n highlightShape,\n classes,\n className,\n isEditor,\n placeholder,\n pluginProps,\n onKeyDown,\n } = this.props;\n // We don't want to send customPlugins to slate.\n // Not sure if they would do any harm, but I think it's better to not send them.\n // We use custom plugins to be able to add custom buttons\n // eslint-disable-next-line no-unused-vars\n const { customPlugins, showParagraphs, separateParagraphs, ...otherPluginProps } = pluginProps || {};\n\n const { value, focusedNode, toolbarOpts, dialog, scheduled } = this.state;\n\n log('[render] value: ', value);\n const sizeStyle = this.buildSizeStyle();\n const names = classNames(\n {\n [classes.withBg]: highlightShape,\n [classes.toolbarOnTop]: toolbarOpts.alwaysVisible && toolbarOpts.position === 'top',\n [classes.scheduled]: scheduled,\n },\n className,\n );\n\n return (\n <div\n ref={(ref) => (this.wrapperRef = ref)}\n style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n className={names}\n id={`editor-${value?.document?.key}`}\n >\n {scheduled && <div className={classes.uploading}>Uploading image and then saving...</div>}\n <SlateEditor\n plugins={this.plugins}\n innerRef={(r) => {\n if (r) {\n this.slateEditor = r;\n }\n }}\n ref={(r) => (this.editor = r && this.props.editorRef(r))}\n toolbarRef={(r) => {\n if (r) {\n this.toolbarRef = r;\n }\n }}\n doneButtonRef={this.doneButtonRef}\n value={value}\n focusToolbar={this.state.focusToolbar}\n onToolbarFocus={this.handleToolbarFocus}\n onToolbarBlur={this.handleToolbarBlur}\n focus={this.focus}\n onKeyDown={onKeyDown}\n onChange={this.onChange}\n getFocusedValue={this.getFocusedValue}\n onBlur={this.onBlur}\n onDrop={(event, editor) => this.onDropPaste(event, editor, true)}\n onPaste={(event, editor) => this.onDropPaste(event, editor)}\n onFocus={this.onFocus}\n onEditingDone={this.onEditingDone}\n focusedNode={focusedNode}\n normalize={this.normalize}\n readOnly={disabled}\n spellCheck={spellCheck}\n autoCorrect={spellCheck}\n className={classNames(\n {\n [classes.noPadding]: toolbarOpts?.noPadding,\n [classes.showParagraph]: showParagraphs && !showParagraphs.disabled,\n [classes.separateParagraph]: separateParagraphs && !separateParagraphs.disabled,\n },\n classes.slateEditor,\n )}\n style={{\n minHeight: sizeStyle.minHeight,\n height: sizeStyle.height,\n maxHeight: sizeStyle.maxHeight,\n }}\n pluginProps={otherPluginProps}\n toolbarOpts={toolbarOpts}\n placeholder={placeholder}\n renderPlaceholder={this.renderPlaceholder}\n onDataChange={this.changeData}\n />\n <AlertDialog\n open={dialog.open}\n title={dialog.title}\n text={dialog.text}\n onClose={dialog.onClose}\n onConfirm={dialog.onConfirm}\n onConfirmText={dialog.onConfirmText}\n onCloseText={dialog.onCloseText}\n />\n </div>\n );\n }\n}\n\n// TODO color - hardcoded gray background and keypad colors will need to change too\nconst styles = {\n withBg: {\n backgroundColor: 'rgba(0,0,0,0.06)',\n },\n scheduled: {\n opacity: 0.5,\n pointerEvents: 'none',\n position: 'relative',\n },\n uploading: {\n position: 'absolute',\n top: '50%',\n left: '50%',\n transform: 'translate(-50%, -50%)',\n },\n slateEditor: {\n fontFamily: 'Roboto, sans-serif',\n\n '& table': {\n tableLayout: 'fixed',\n width: '100%',\n borderCollapse: 'collapse',\n color: color.text(),\n backgroundColor: color.background(),\n },\n '& table:not([border=\"1\"]) tr': {\n borderTop: '1px solid #dfe2e5',\n // TODO perhaps secondary color for background, for now disable\n // '&:nth-child(2n)': {\n // backgroundColor: '#f6f8fa'\n // }\n },\n '& td, th': {\n padding: '.6em 1em',\n textAlign: 'center',\n },\n '& table:not([border=\"1\"]) td, th': {\n border: '1px solid #dfe2e5',\n },\n },\n showParagraph: {\n // a div that has a div after it\n '& > div:has(+ div)::after': {\n display: 'block',\n content: '\"¶\"',\n fontSize: '1em',\n color: '#146EB3',\n },\n },\n separateParagraph: {\n // a div that has a div after it\n '& > div:has(+ div)': {\n marginBottom: '1em',\n },\n },\n toolbarOnTop: {\n marginTop: '45px',\n },\n noPadding: {\n padding: '0 !important',\n },\n previewText: {\n marginBottom: '36px',\n marginTop: '6px',\n padding: '20px',\n backgroundColor: 'rgba(0,0,0,0.06)',\n },\n};\n\nexport default withStyles(styles)(Editor);\n"],"file":"editor.js"}
package/lib/index.js CHANGED
@@ -122,7 +122,7 @@ var EditableHtml = /*#__PURE__*/function (_React$Component) {
122
122
  var html = (0, _serialization.valueToHtml)(value);
123
123
  var htmlParsed = (0, _parseHtml.parseDegrees)(html);
124
124
 
125
- if (html !== _this.props.markup && _this.props.onChange) {
125
+ if (htmlParsed !== _this.props.markup && _this.props.onChange) {
126
126
  _this.props.onChange(htmlParsed);
127
127
  }
128
128
 
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.jsx"],"names":["log","EditableHtml","props","markup","v","setState","value","done","html","htmlParsed","onChange","onDone","position","node","select","editorRef","change","c","lastText","document","getNextText","key","getLastText","editorDOM","querySelector","activeElement","blur","focus","moveFocusTo","text","length","moveAnchorTo","range","Range","fromJSON","anchorKey","anchorOffset","focusKey","focusOffset","isFocused","isBackward","onEditingDone","extraCSSRules","Object","assign","extraCSSRulesOpts","state","allowValidation","current","equals","toolbarOpts","error","runSerializationOnMarkup","ref","rootRef","React","Component","PropTypes","any","func","isRequired","string","bool","object","shape","names","arrayOf","rules"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Editor, { DEFAULT_PLUGINS, ALL_PLUGINS } from './editor';\nimport { extraCSSRulesOpts, htmlToValue, valueToHtml, reduceMultipleBrs } from './serialization';\nimport { parseDegrees } from './parse-html';\nimport constants from './constants';\nimport debug from 'debug';\nimport { Range } from 'slate';\n\nconst log = debug('@pie-lib:editable-html');\n\n/**\n * Wrapper around the editor that exposes a `markup` and `onChange(markup:string)` api.\n * Because of the mismatch between the markup and the `Value` we need to convert the incoming markup to a value and\n * compare it. TODO: This is an interim fix, we'll need to strip back `Editor` and look how best to maintain the\n * `markup` api whilst avoiding the serialization mismatch. We should be making better use of schemas w/ normalize.\n */\nexport default class EditableHtml extends React.Component {\n static propTypes = {\n error: PropTypes.any,\n onChange: PropTypes.func.isRequired,\n onDone: PropTypes.func,\n markup: PropTypes.string.isRequired,\n allowValidation: PropTypes.bool,\n toolbarOpts: PropTypes.object,\n extraCSSRules: PropTypes.shape({\n names: PropTypes.arrayOf(PropTypes.string),\n rules: PropTypes.string,\n }),\n };\n\n static defaultProps = {\n onDone: () => {},\n allowValidation: false,\n };\n\n constructor(props) {\n super(props);\n\n if (props.extraCSSRules) {\n Object.assign(extraCSSRulesOpts, this.props.extraCSSRules);\n }\n\n const v = htmlToValue(props.markup);\n this.state = {\n value: v,\n };\n }\n\n // eslint-disable-next-line react/no-deprecated\n componentWillReceiveProps(props) {\n if (!props.allowValidation && props.markup === this.props.markup) {\n return;\n }\n\n const v = htmlToValue(props.markup);\n const current = htmlToValue(this.props.markup);\n\n if (v.equals && !v.equals(current)) {\n this.setState({ value: v });\n }\n }\n\n runSerializationOnMarkup = () => {\n if (!this.props.markup) {\n return;\n }\n\n const v = htmlToValue(reduceMultipleBrs(this.props.markup));\n\n this.setState({ value: v });\n };\n\n onChange = (value, done) => {\n const html = valueToHtml(value);\n const htmlParsed = parseDegrees(html);\n\n if (html !== this.props.markup && this.props.onChange) {\n this.props.onChange(htmlParsed);\n }\n\n if (done && this.props.onDone) {\n this.props.onDone(htmlParsed);\n }\n };\n\n focus = (position, node, select = false) => {\n if (this.editorRef) {\n this.editorRef.change((c) => {\n const lastText = node ? c.value.document.getNextText(node.key) : c.value.document.getLastText();\n const editorDOM = document.querySelector(`[data-key=\"${this.editorRef.value.document.key}\"]`);\n\n if (editorDOM !== document.activeElement) {\n document.activeElement.blur();\n }\n\n c.focus();\n\n if (position === 'end' && lastText) {\n c.moveFocusTo(lastText.key, lastText.text?.length).moveAnchorTo(lastText.key, lastText.text?.length);\n if (select) {\n const range = Range.fromJSON({\n anchorKey: lastText.key,\n anchorOffset: 0,\n focusKey: lastText.key,\n focusOffset: lastText.text?.length,\n isFocused: true,\n isBackward: false,\n });\n c.select(range);\n }\n }\n\n if (position === 'beginning' && lastText) {\n c.moveFocusTo(lastText.key, 0).moveAnchorTo(lastText.key, 0);\n }\n editorDOM.focus();\n });\n }\n };\n\n finishEditing = () => {\n if (this.editorRef) {\n this.editorRef.props.onEditingDone();\n }\n };\n\n render() {\n const { value } = this.state;\n const { toolbarOpts, error } = this.props;\n\n if (toolbarOpts) {\n toolbarOpts.error = error;\n }\n\n const props = {\n ...this.props,\n markup: null,\n value,\n onChange: this.onChange,\n focus: this.focus,\n runSerializationOnMarkup: this.runSerializationOnMarkup,\n };\n\n return (\n <Editor\n onRef={(ref) => {\n if (ref) {\n this.rootRef = ref;\n }\n }}\n editorRef={(ref) => ref && (this.editorRef = ref)}\n {...props}\n />\n );\n }\n}\n\n/**\n * Export lower level Editor and serialization functions.\n */\nexport { htmlToValue, valueToHtml, Editor, DEFAULT_PLUGINS, ALL_PLUGINS, constants };\n"],"file":"index.js"}
1
+ {"version":3,"sources":["../src/index.jsx"],"names":["log","EditableHtml","props","markup","v","setState","value","done","html","htmlParsed","onChange","onDone","position","node","select","editorRef","change","c","lastText","document","getNextText","key","getLastText","editorDOM","querySelector","activeElement","blur","focus","moveFocusTo","text","length","moveAnchorTo","range","Range","fromJSON","anchorKey","anchorOffset","focusKey","focusOffset","isFocused","isBackward","onEditingDone","extraCSSRules","Object","assign","extraCSSRulesOpts","state","allowValidation","current","equals","toolbarOpts","error","runSerializationOnMarkup","ref","rootRef","React","Component","PropTypes","any","func","isRequired","string","bool","object","shape","names","arrayOf","rules"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Editor, { DEFAULT_PLUGINS, ALL_PLUGINS } from './editor';\nimport { extraCSSRulesOpts, htmlToValue, valueToHtml, reduceMultipleBrs } from './serialization';\nimport { parseDegrees } from './parse-html';\nimport constants from './constants';\nimport debug from 'debug';\nimport { Range } from 'slate';\n\nconst log = debug('@pie-lib:editable-html');\n\n/**\n * Wrapper around the editor that exposes a `markup` and `onChange(markup:string)` api.\n * Because of the mismatch between the markup and the `Value` we need to convert the incoming markup to a value and\n * compare it. TODO: This is an interim fix, we'll need to strip back `Editor` and look how best to maintain the\n * `markup` api whilst avoiding the serialization mismatch. We should be making better use of schemas w/ normalize.\n */\nexport default class EditableHtml extends React.Component {\n static propTypes = {\n error: PropTypes.any,\n onChange: PropTypes.func.isRequired,\n onDone: PropTypes.func,\n markup: PropTypes.string.isRequired,\n allowValidation: PropTypes.bool,\n toolbarOpts: PropTypes.object,\n extraCSSRules: PropTypes.shape({\n names: PropTypes.arrayOf(PropTypes.string),\n rules: PropTypes.string,\n }),\n };\n\n static defaultProps = {\n onDone: () => {},\n allowValidation: false,\n };\n\n constructor(props) {\n super(props);\n\n if (props.extraCSSRules) {\n Object.assign(extraCSSRulesOpts, this.props.extraCSSRules);\n }\n\n const v = htmlToValue(props.markup);\n this.state = {\n value: v,\n };\n }\n\n // eslint-disable-next-line react/no-deprecated\n componentWillReceiveProps(props) {\n if (!props.allowValidation && props.markup === this.props.markup) {\n return;\n }\n\n const v = htmlToValue(props.markup);\n const current = htmlToValue(this.props.markup);\n\n if (v.equals && !v.equals(current)) {\n this.setState({ value: v });\n }\n }\n\n runSerializationOnMarkup = () => {\n if (!this.props.markup) {\n return;\n }\n\n const v = htmlToValue(reduceMultipleBrs(this.props.markup));\n\n this.setState({ value: v });\n };\n\n onChange = (value, done) => {\n const html = valueToHtml(value);\n const htmlParsed = parseDegrees(html);\n\n if (htmlParsed !== this.props.markup && this.props.onChange) {\n this.props.onChange(htmlParsed);\n }\n\n if (done && this.props.onDone) {\n this.props.onDone(htmlParsed);\n }\n };\n\n focus = (position, node, select = false) => {\n if (this.editorRef) {\n this.editorRef.change((c) => {\n const lastText = node ? c.value.document.getNextText(node.key) : c.value.document.getLastText();\n const editorDOM = document.querySelector(`[data-key=\"${this.editorRef.value.document.key}\"]`);\n\n if (editorDOM !== document.activeElement) {\n document.activeElement.blur();\n }\n\n c.focus();\n\n if (position === 'end' && lastText) {\n c.moveFocusTo(lastText.key, lastText.text?.length).moveAnchorTo(lastText.key, lastText.text?.length);\n if (select) {\n const range = Range.fromJSON({\n anchorKey: lastText.key,\n anchorOffset: 0,\n focusKey: lastText.key,\n focusOffset: lastText.text?.length,\n isFocused: true,\n isBackward: false,\n });\n c.select(range);\n }\n }\n\n if (position === 'beginning' && lastText) {\n c.moveFocusTo(lastText.key, 0).moveAnchorTo(lastText.key, 0);\n }\n editorDOM.focus();\n });\n }\n };\n\n finishEditing = () => {\n if (this.editorRef) {\n this.editorRef.props.onEditingDone();\n }\n };\n\n render() {\n const { value } = this.state;\n const { toolbarOpts, error } = this.props;\n\n if (toolbarOpts) {\n toolbarOpts.error = error;\n }\n\n const props = {\n ...this.props,\n markup: null,\n value,\n onChange: this.onChange,\n focus: this.focus,\n runSerializationOnMarkup: this.runSerializationOnMarkup,\n };\n\n return (\n <Editor\n onRef={(ref) => {\n if (ref) {\n this.rootRef = ref;\n }\n }}\n editorRef={(ref) => ref && (this.editorRef = ref)}\n {...props}\n />\n );\n }\n}\n\n/**\n * Export lower level Editor and serialization functions.\n */\nexport { htmlToValue, valueToHtml, Editor, DEFAULT_PLUGINS, ALL_PLUGINS, constants };\n"],"file":"index.js"}
@@ -81,6 +81,9 @@ var BlankContent = /*#__PURE__*/function (_React$Component) {
81
81
  (0, _classCallCheck2["default"])(this, BlankContent);
82
82
  _this = _super.call(this, props);
83
83
  _this.handleClick = _this.handleClick.bind((0, _assertThisInitialized2["default"])(_this));
84
+ _this.state = {
85
+ hoveredElementSize: null
86
+ };
84
87
  return _this;
85
88
  }
86
89
 
@@ -103,12 +106,38 @@ var BlankContent = /*#__PURE__*/function (_React$Component) {
103
106
  this.elementRef.className = this.elementRef.contains(event.target) ? classes.selected : '';
104
107
  }
105
108
  }
109
+ }, {
110
+ key: "getSnapshotBeforeUpdate",
111
+ value: function getSnapshotBeforeUpdate(prevProps) {
112
+ if (!prevProps.isOver && this.props.isOver && this.elementRef) {
113
+ var node = this.elementRef;
114
+ return {
115
+ width: node.offsetWidth,
116
+ height: node.offsetHeight
117
+ };
118
+ }
119
+
120
+ return null;
121
+ }
106
122
  }, {
107
123
  key: "componentDidUpdate",
108
- value: function componentDidUpdate() {
109
- if (this.elementRef) {
124
+ value: function componentDidUpdate(prevProps, prevState, snapshot) {
125
+ if (this.elementRef && typeof _mathRendering.renderMath === 'function') {
110
126
  (0, _mathRendering.renderMath)(this.elementRef);
111
127
  }
128
+
129
+ if (snapshot && (!this.state.hoveredElementSize || this.state.hoveredElementSize.width !== snapshot.width || this.state.hoveredElementSize.height !== snapshot.height)) {
130
+ this.setState({
131
+ hoveredElementSize: snapshot
132
+ });
133
+ return;
134
+ }
135
+
136
+ if (prevProps.isOver && !this.props.isOver && this.state.hoveredElementSize) {
137
+ this.setState({
138
+ hoveredElementSize: null
139
+ });
140
+ }
112
141
  }
113
142
  }, {
114
143
  key: "render",
@@ -122,9 +151,11 @@ var BlankContent = /*#__PURE__*/function (_React$Component) {
122
151
  dragItem = _this$props.dragItem,
123
152
  isOver = _this$props.isOver,
124
153
  value = _this$props.value;
154
+ var hoveredElementSize = this.state.hoveredElementSize;
125
155
  var label = dragItem && isOver ? dragItem.value.value : value.value || "\xA0";
126
156
  var finalLabel = isDragging ? "\xA0" : label;
127
157
  var hasGrip = finalLabel !== "\xA0";
158
+ var isPreview = dragItem && isOver;
128
159
  return /*#__PURE__*/_react["default"].createElement("div", {
129
160
  ref: function ref(_ref) {
130
161
  return _this2.elementRef = _ref;
@@ -133,13 +164,15 @@ var BlankContent = /*#__PURE__*/function (_React$Component) {
133
164
  display: 'inline-flex',
134
165
  minWidth: '178px',
135
166
  minHeight: '36px',
136
- background: '#FFF',
137
- border: '1px solid #C0C3CF',
167
+ background: isPreview ? "".concat(_renderUi.color.defaults.BORDER_LIGHT) : "".concat(_renderUi.color.defaults.WHITE),
168
+ border: isPreview ? "1px solid ".concat(_renderUi.color.defaults.BORDER_DARK) : "1px solid ".concat(_renderUi.color.defaults.BORDER_LIGHT),
138
169
  boxSizing: 'border-box',
139
170
  borderRadius: '3px',
140
171
  overflow: 'hidden',
141
172
  position: 'relative',
142
- padding: '8px 8px 8px 35px'
173
+ padding: '8px 8px 8px 35px',
174
+ width: hoveredElementSize ? hoveredElementSize.width : undefined,
175
+ height: hoveredElementSize ? hoveredElementSize.height : undefined
143
176
  },
144
177
  "data-key": n.key,
145
178
  contentEditable: false
@@ -212,7 +245,9 @@ exports.tileTarget = tileTarget;
212
245
  var DropTile = (0, _drag.DropTarget)('drag-in-the-blank-choice', tileTarget, function (connect, monitor) {
213
246
  return {
214
247
  connectDropTarget: connect.dropTarget(),
215
- isOver: monitor.isOver(),
248
+ isOver: monitor.isOver({
249
+ shallow: true
250
+ }),
216
251
  dragItem: monitor.getItem()
217
252
  };
218
253
  })(connectedBlankContent);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/plugins/respArea/drag-in-the-blank/choice.jsx"],"names":["useStyles","theme","content","border","palette","primary","main","fontSize","chip","minWidth","correct","color","incorrect","error","selected","primaryDark","BlankContent","props","handleClick","bind","document","addEventListener","removeEventListener","event","classes","elementRef","className","contains","target","n","children","isDragging","dragItem","isOver","value","label","finalLabel","hasGrip","ref","display","minHeight","background","boxSizing","borderRadius","overflow","position","padding","key","top","left","__html","React","Component","PropTypes","object","func","bool","StyledBlankContent","connectedBlankContent","connectDropTarget","connectDragSource","dragContent","dragEl","over","tileTarget","drop","monitor","draggedItem","getItem","shouldDrop","index","onChange","dropped","canDrop","instanceId","DropTile","connect","dropTarget","tileSource","canDrag","disabled","beginDrag","id","targetId","fromChoice","endDrag","dropResult","getDropResult","duplicates","removeResponse","dragSource"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport isUndefined from 'lodash/isUndefined';\nimport { DragSource, DropTarget } from '@pie-lib/drag';\nimport { color } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { withStyles } from '@material-ui/core/styles';\nimport classnames from 'classnames';\n\nimport { GripIcon } from '../icons';\n\nconst useStyles = withStyles((theme) => ({\n content: {\n border: `solid 0px ${theme.palette.primary.main}`,\n '& mjx-frac': {\n fontSize: '120% !important',\n },\n },\n chip: {\n minWidth: '90px',\n },\n correct: {\n border: `solid 1px ${color.correct()}`,\n },\n incorrect: {\n border: `solid 1px ${theme.palette.error.main}`,\n },\n selected: {\n border: `2px solid ${color.primaryDark()} !important`,\n },\n}));\n\nexport class BlankContent extends React.Component {\n static propTypes = {\n n: PropTypes.object,\n children: PropTypes.func,\n isDragging: PropTypes.bool,\n isOver: PropTypes.bool,\n dragItem: PropTypes.object,\n value: PropTypes.object,\n classes: PropTypes.object,\n };\n\n constructor(props) {\n super(props);\n\n this.handleClick = this.handleClick.bind(this);\n }\n\n componentDidMount() {\n document.addEventListener('click', this.handleClick);\n }\n\n componentWillUnmount() {\n document.removeEventListener('click', this.handleClick);\n }\n\n handleClick(event) {\n const { classes } = this.props;\n\n if (this.elementRef) {\n this.elementRef.className = this.elementRef.contains(event.target) ? classes.selected : '';\n }\n }\n\n componentDidUpdate() {\n if (this.elementRef) {\n renderMath(this.elementRef);\n }\n }\n\n render() {\n const { n, children, isDragging, dragItem, isOver, value } = this.props;\n\n const label = dragItem && isOver ? dragItem.value.value : value.value || '\\u00A0';\n const finalLabel = isDragging ? '\\u00A0' : label;\n const hasGrip = finalLabel !== '\\u00A0';\n\n return (\n <div\n ref={(ref) => (this.elementRef = ref)}\n style={{\n display: 'inline-flex',\n minWidth: '178px',\n minHeight: '36px',\n background: '#FFF',\n border: '1px solid #C0C3CF',\n boxSizing: 'border-box',\n borderRadius: '3px',\n overflow: 'hidden',\n position: 'relative',\n padding: '8px 8px 8px 35px',\n }}\n data-key={n.key}\n contentEditable={false}\n >\n {hasGrip && (\n <GripIcon\n style={{\n position: 'absolute',\n top: '6px',\n left: '15px',\n color: '#9B9B9B',\n }}\n contentEditable={false}\n />\n )}\n <span\n dangerouslySetInnerHTML={{\n __html: finalLabel,\n }}\n />\n {children}\n </div>\n );\n }\n}\n\nconst StyledBlankContent = useStyles(BlankContent);\n\nconst connectedBlankContent = useStyles(({ connectDropTarget, connectDragSource, ...props }) => {\n const { classes, isOver, value } = props;\n const dragContent = <StyledBlankContent {...props} />;\n const dragEl = !value ? dragContent : connectDragSource(<span>{dragContent}</span>);\n const content = <span className={classnames(classes.content, isOver && classes.over)}>{dragEl}</span>;\n\n return connectDropTarget ? connectDropTarget(content) : content;\n});\n\nexport const tileTarget = {\n drop(props, monitor) {\n const draggedItem = monitor.getItem();\n const shouldDrop =\n isUndefined(draggedItem.value.index) ||\n isUndefined(props.value.index) ||\n draggedItem.value.index !== props.value.index;\n\n if (shouldDrop) {\n props.onChange(draggedItem.value);\n }\n\n return {\n dropped: shouldDrop,\n };\n },\n canDrop(props, monitor) {\n const draggedItem = monitor.getItem();\n\n return draggedItem.instanceId === props.instanceId;\n },\n};\n\nconst DropTile = DropTarget('drag-in-the-blank-choice', tileTarget, (connect, monitor) => ({\n connectDropTarget: connect.dropTarget(),\n isOver: monitor.isOver(),\n dragItem: monitor.getItem(),\n}))(connectedBlankContent);\n\nexport const tileSource = {\n canDrag(props) {\n return !props.disabled && !!props.value;\n },\n beginDrag(props) {\n return {\n id: props.targetId,\n value: props.value,\n instanceId: props.instanceId,\n fromChoice: true,\n };\n },\n endDrag(props, monitor) {\n // this will be null if it did not drop\n const dropResult = monitor.getDropResult();\n\n if (!dropResult || (dropResult.dropped && !props.duplicates)) {\n const draggedItem = monitor.getItem();\n\n if (draggedItem.fromChoice) {\n props.removeResponse(draggedItem.value);\n }\n }\n },\n};\n\nexport default DragSource('drag-in-the-blank-choice', tileSource, (connect, monitor) => ({\n connectDragSource: connect.dragSource(),\n isDragging: monitor.isDragging(),\n}))(DropTile);\n"],"file":"choice.js"}
1
+ {"version":3,"sources":["../../../../src/plugins/respArea/drag-in-the-blank/choice.jsx"],"names":["useStyles","theme","content","border","palette","primary","main","fontSize","chip","minWidth","correct","color","incorrect","error","selected","primaryDark","BlankContent","props","handleClick","bind","state","hoveredElementSize","document","addEventListener","removeEventListener","event","classes","elementRef","className","contains","target","prevProps","isOver","node","width","offsetWidth","height","offsetHeight","prevState","snapshot","renderMath","setState","n","children","isDragging","dragItem","value","label","finalLabel","hasGrip","isPreview","ref","display","minHeight","background","defaults","BORDER_LIGHT","WHITE","BORDER_DARK","boxSizing","borderRadius","overflow","position","padding","undefined","key","top","left","__html","React","Component","PropTypes","object","func","bool","StyledBlankContent","connectedBlankContent","connectDropTarget","connectDragSource","dragContent","dragEl","over","tileTarget","drop","monitor","draggedItem","getItem","shouldDrop","index","onChange","dropped","canDrop","instanceId","DropTile","connect","dropTarget","shallow","tileSource","canDrag","disabled","beginDrag","id","targetId","fromChoice","endDrag","dropResult","getDropResult","duplicates","removeResponse","dragSource"],"mappings":"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","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport isUndefined from 'lodash/isUndefined';\nimport { DragSource, DropTarget } from '@pie-lib/drag';\nimport { color } from '@pie-lib/render-ui';\nimport { renderMath } from '@pie-lib/math-rendering';\nimport { withStyles } from '@material-ui/core/styles';\nimport classnames from 'classnames';\n\nimport { GripIcon } from '../icons';\n\nconst useStyles = withStyles((theme) => ({\n content: {\n border: `solid 0px ${theme.palette.primary.main}`,\n '& mjx-frac': {\n fontSize: '120% !important',\n },\n },\n chip: {\n minWidth: '90px',\n },\n correct: {\n border: `solid 1px ${color.correct()}`,\n },\n incorrect: {\n border: `solid 1px ${theme.palette.error.main}`,\n },\n selected: {\n border: `2px solid ${color.primaryDark()} !important`,\n },\n}));\n\nexport class BlankContent extends React.Component {\n static propTypes = {\n n: PropTypes.object,\n children: PropTypes.func,\n isDragging: PropTypes.bool,\n isOver: PropTypes.bool,\n dragItem: PropTypes.object,\n value: PropTypes.object,\n classes: PropTypes.object,\n };\n\n constructor(props) {\n super(props);\n\n this.handleClick = this.handleClick.bind(this);\n this.state = { hoveredElementSize: null };\n }\n\n componentDidMount() {\n document.addEventListener('click', this.handleClick);\n }\n\n componentWillUnmount() {\n document.removeEventListener('click', this.handleClick);\n }\n\n handleClick(event) {\n const { classes } = this.props;\n\n if (this.elementRef) {\n this.elementRef.className = this.elementRef.contains(event.target) ? classes.selected : '';\n }\n }\n\n getSnapshotBeforeUpdate(prevProps) {\n if (!prevProps.isOver && this.props.isOver && this.elementRef) {\n const node = this.elementRef;\n return { width: node.offsetWidth, height: node.offsetHeight };\n }\n return null;\n }\n\n componentDidUpdate(prevProps, prevState, snapshot) {\n if (this.elementRef && typeof renderMath === 'function') {\n renderMath(this.elementRef);\n }\n\n if (\n snapshot &&\n (!this.state.hoveredElementSize ||\n this.state.hoveredElementSize.width !== snapshot.width ||\n this.state.hoveredElementSize.height !== snapshot.height)\n ) {\n this.setState({ hoveredElementSize: snapshot });\n return;\n }\n\n if (prevProps.isOver && !this.props.isOver && this.state.hoveredElementSize) {\n this.setState({ hoveredElementSize: null });\n }\n }\n\n render() {\n const { n, children, isDragging, dragItem, isOver, value } = this.props;\n const { hoveredElementSize } = this.state;\n\n const label = dragItem && isOver ? dragItem.value.value : value.value || '\\u00A0';\n const finalLabel = isDragging ? '\\u00A0' : label;\n const hasGrip = finalLabel !== '\\u00A0';\n const isPreview = dragItem && isOver;\n\n return (\n <div\n ref={(ref) => (this.elementRef = ref)}\n style={{\n display: 'inline-flex',\n minWidth: '178px',\n minHeight: '36px',\n background: isPreview ? `${color.defaults.BORDER_LIGHT}` : `${color.defaults.WHITE}`,\n border: isPreview ? `1px solid ${color.defaults.BORDER_DARK}` : `1px solid ${color.defaults.BORDER_LIGHT}`,\n boxSizing: 'border-box',\n borderRadius: '3px',\n overflow: 'hidden',\n position: 'relative',\n padding: '8px 8px 8px 35px',\n width: hoveredElementSize ? hoveredElementSize.width : undefined,\n height: hoveredElementSize ? hoveredElementSize.height : undefined,\n }}\n data-key={n.key}\n contentEditable={false}\n >\n {hasGrip && (\n <GripIcon\n style={{\n position: 'absolute',\n top: '6px',\n left: '15px',\n color: '#9B9B9B',\n }}\n contentEditable={false}\n />\n )}\n <span\n dangerouslySetInnerHTML={{\n __html: finalLabel,\n }}\n />\n {children}\n </div>\n );\n }\n}\n\nconst StyledBlankContent = useStyles(BlankContent);\n\nconst connectedBlankContent = useStyles(({ connectDropTarget, connectDragSource, ...props }) => {\n const { classes, isOver, value } = props;\n const dragContent = <StyledBlankContent {...props} />;\n const dragEl = !value ? dragContent : connectDragSource(<span>{dragContent}</span>);\n const content = <span className={classnames(classes.content, isOver && classes.over)}>{dragEl}</span>;\n\n return connectDropTarget ? connectDropTarget(content) : content;\n});\n\nexport const tileTarget = {\n drop(props, monitor) {\n const draggedItem = monitor.getItem();\n const shouldDrop =\n isUndefined(draggedItem.value.index) ||\n isUndefined(props.value.index) ||\n draggedItem.value.index !== props.value.index;\n\n if (shouldDrop) {\n props.onChange(draggedItem.value);\n }\n\n return {\n dropped: shouldDrop,\n };\n },\n canDrop(props, monitor) {\n const draggedItem = monitor.getItem();\n\n return draggedItem.instanceId === props.instanceId;\n },\n};\n\nconst DropTile = DropTarget('drag-in-the-blank-choice', tileTarget, (connect, monitor) => ({\n connectDropTarget: connect.dropTarget(),\n isOver: monitor.isOver({ shallow: true }),\n dragItem: monitor.getItem(),\n}))(connectedBlankContent);\n\nexport const tileSource = {\n canDrag(props) {\n return !props.disabled && !!props.value;\n },\n beginDrag(props) {\n return {\n id: props.targetId,\n value: props.value,\n instanceId: props.instanceId,\n fromChoice: true,\n };\n },\n endDrag(props, monitor) {\n // this will be null if it did not drop\n const dropResult = monitor.getDropResult();\n\n if (!dropResult || (dropResult.dropped && !props.duplicates)) {\n const draggedItem = monitor.getItem();\n\n if (draggedItem.fromChoice) {\n props.removeResponse(draggedItem.value);\n }\n }\n },\n};\n\nexport default DragSource('drag-in-the-blank-choice', tileSource, (connect, monitor) => ({\n connectDragSource: connect.dragSource(),\n isDragging: monitor.isDragging(),\n}))(DropTile);\n"],"file":"choice.js"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/editable-html",
3
- "version": "11.10.0",
3
+ "version": "11.11.0",
4
4
  "description": "",
5
5
  "license": "ISC",
6
6
  "main": "lib/index.js",
@@ -10,11 +10,11 @@
10
10
  "@material-ui/core": "^3.8.3",
11
11
  "@material-ui/icons": "^3.0.2",
12
12
  "@material-ui/styles": "^3.0.0-alpha.10",
13
- "@pie-lib/drag": "^2.11.0",
14
- "@pie-lib/math-input": "^6.20.0",
15
- "@pie-lib/math-rendering": "^3.11.0",
16
- "@pie-lib/math-toolbar": "^1.20.0",
17
- "@pie-lib/render-ui": "^4.24.0",
13
+ "@pie-lib/drag": "^2.12.0",
14
+ "@pie-lib/math-input": "^6.21.0",
15
+ "@pie-lib/math-rendering": "^3.12.0",
16
+ "@pie-lib/math-toolbar": "^1.21.0",
17
+ "@pie-lib/render-ui": "^4.25.0",
18
18
  "change-case": "^3.0.2",
19
19
  "classnames": "^2.2.6",
20
20
  "debug": "^4.1.1",
@@ -48,6 +48,6 @@
48
48
  "publishConfig": {
49
49
  "access": "public"
50
50
  },
51
- "gitHead": "ba75c393e47a34ace71e2ee5c3a2ddd3b87423ec",
51
+ "gitHead": "21bbb8481af78b1fa3efb9275e4afb4bc9af0354",
52
52
  "scripts": {}
53
53
  }
package/src/editor.jsx CHANGED
@@ -4,6 +4,7 @@ import SlateTypes from 'slate-prop-types';
4
4
  import { Value, Block, Inline } from 'slate';
5
5
  import Plain from 'slate-plain-serializer';
6
6
  import PropTypes from 'prop-types';
7
+ import debounce from 'lodash/debounce';
7
8
  import isEqual from 'lodash/isEqual';
8
9
  import classNames from 'classnames';
9
10
  import debug from 'debug';
@@ -184,11 +185,11 @@ export class Editor extends React.Component {
184
185
  this.handleToolbarFocus = this.handleToolbarFocus.bind(this);
185
186
  this.handleToolbarBlur = this.handleToolbarBlur.bind(this);
186
187
 
187
- this.onResize = () => {
188
+ this.onResize = debounce(() => {
188
189
  if (!this.state.isHtmlMode && props.onChange) {
189
190
  props.onChange(this.state.value, true);
190
191
  }
191
- };
192
+ }, 50);
192
193
 
193
194
  this.handlePlugins(this.props);
194
195
  }
package/src/index.jsx CHANGED
@@ -75,7 +75,7 @@ export default class EditableHtml extends React.Component {
75
75
  const html = valueToHtml(value);
76
76
  const htmlParsed = parseDegrees(html);
77
77
 
78
- if (html !== this.props.markup && this.props.onChange) {
78
+ if (htmlParsed !== this.props.markup && this.props.onChange) {
79
79
  this.props.onChange(htmlParsed);
80
80
  }
81
81
 
@@ -45,6 +45,7 @@ export class BlankContent extends React.Component {
45
45
  super(props);
46
46
 
47
47
  this.handleClick = this.handleClick.bind(this);
48
+ this.state = { hoveredElementSize: null };
48
49
  }
49
50
 
50
51
  componentDidMount() {
@@ -63,18 +64,42 @@ export class BlankContent extends React.Component {
63
64
  }
64
65
  }
65
66
 
66
- componentDidUpdate() {
67
- if (this.elementRef) {
67
+ getSnapshotBeforeUpdate(prevProps) {
68
+ if (!prevProps.isOver && this.props.isOver && this.elementRef) {
69
+ const node = this.elementRef;
70
+ return { width: node.offsetWidth, height: node.offsetHeight };
71
+ }
72
+ return null;
73
+ }
74
+
75
+ componentDidUpdate(prevProps, prevState, snapshot) {
76
+ if (this.elementRef && typeof renderMath === 'function') {
68
77
  renderMath(this.elementRef);
69
78
  }
79
+
80
+ if (
81
+ snapshot &&
82
+ (!this.state.hoveredElementSize ||
83
+ this.state.hoveredElementSize.width !== snapshot.width ||
84
+ this.state.hoveredElementSize.height !== snapshot.height)
85
+ ) {
86
+ this.setState({ hoveredElementSize: snapshot });
87
+ return;
88
+ }
89
+
90
+ if (prevProps.isOver && !this.props.isOver && this.state.hoveredElementSize) {
91
+ this.setState({ hoveredElementSize: null });
92
+ }
70
93
  }
71
94
 
72
95
  render() {
73
96
  const { n, children, isDragging, dragItem, isOver, value } = this.props;
97
+ const { hoveredElementSize } = this.state;
74
98
 
75
99
  const label = dragItem && isOver ? dragItem.value.value : value.value || '\u00A0';
76
100
  const finalLabel = isDragging ? '\u00A0' : label;
77
101
  const hasGrip = finalLabel !== '\u00A0';
102
+ const isPreview = dragItem && isOver;
78
103
 
79
104
  return (
80
105
  <div
@@ -83,13 +108,15 @@ export class BlankContent extends React.Component {
83
108
  display: 'inline-flex',
84
109
  minWidth: '178px',
85
110
  minHeight: '36px',
86
- background: '#FFF',
87
- border: '1px solid #C0C3CF',
111
+ background: isPreview ? `${color.defaults.BORDER_LIGHT}` : `${color.defaults.WHITE}`,
112
+ border: isPreview ? `1px solid ${color.defaults.BORDER_DARK}` : `1px solid ${color.defaults.BORDER_LIGHT}`,
88
113
  boxSizing: 'border-box',
89
114
  borderRadius: '3px',
90
115
  overflow: 'hidden',
91
116
  position: 'relative',
92
117
  padding: '8px 8px 8px 35px',
118
+ width: hoveredElementSize ? hoveredElementSize.width : undefined,
119
+ height: hoveredElementSize ? hoveredElementSize.height : undefined,
93
120
  }}
94
121
  data-key={n.key}
95
122
  contentEditable={false}
@@ -152,7 +179,7 @@ export const tileTarget = {
152
179
 
153
180
  const DropTile = DropTarget('drag-in-the-blank-choice', tileTarget, (connect, monitor) => ({
154
181
  connectDropTarget: connect.dropTarget(),
155
- isOver: monitor.isOver(),
182
+ isOver: monitor.isOver({ shallow: true }),
156
183
  dragItem: monitor.getItem(),
157
184
  }))(connectedBlankContent);
158
185