@pie-lib/editable-html-tip-tap 1.0.0 → 1.0.2
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/lib/extensions/component.js +10 -2
- package/lib/index.js +430 -146
- package/lib/plugins/index.js +3 -3
- package/package.json +2 -2
- package/src/extensions/component.jsx +11 -3
- package/src/index.jsx +384 -404
- package/src/plugins/index.jsx +1 -1
package/lib/index.js
CHANGED
|
@@ -64,6 +64,8 @@ var _constants = require("./constants");
|
|
|
64
64
|
|
|
65
65
|
var _doneButton = require("./plugins/toolbar/done-button");
|
|
66
66
|
|
|
67
|
+
var _index = require("./plugins/index");
|
|
68
|
+
|
|
67
69
|
var _FormatBold = _interopRequireDefault(require("@material-ui/icons/FormatBold"));
|
|
68
70
|
|
|
69
71
|
var _FormatItalic = _interopRequireDefault(require("@material-ui/icons/FormatItalic"));
|
|
@@ -114,6 +116,10 @@ var _media = require("./extensions/media");
|
|
|
114
116
|
|
|
115
117
|
var _css = require("./extensions/css");
|
|
116
118
|
|
|
119
|
+
var _icons4 = require("./plugins/table/icons");
|
|
120
|
+
|
|
121
|
+
var _BorderAll = _interopRequireDefault(require("@material-ui/icons/BorderAll"));
|
|
122
|
+
|
|
117
123
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
118
124
|
|
|
119
125
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
@@ -338,10 +344,19 @@ var HeadingIcon = function HeadingIcon() {
|
|
|
338
344
|
};
|
|
339
345
|
|
|
340
346
|
var ExtendedTable = _extensionTable.Table.extend({
|
|
347
|
+
addAttributes: function addAttributes() {
|
|
348
|
+
return {
|
|
349
|
+
border: {
|
|
350
|
+
"default": '1'
|
|
351
|
+
}
|
|
352
|
+
};
|
|
353
|
+
},
|
|
341
354
|
renderHTML: function renderHTML(props) {
|
|
342
355
|
var originalTable = this.parent(props);
|
|
343
|
-
|
|
344
|
-
originalTable[1].
|
|
356
|
+
var border = props.HTMLAttributes.border;
|
|
357
|
+
var previousStyle = "".concat(originalTable[1].style).concat(originalTable[1].style.match(/.*; */) ? '' : ';');
|
|
358
|
+
originalTable[1].style = "".concat(previousStyle, "\n width: 100%;\n color: var(--pie-text, black);\n table-layout: fixed;\n border-collapse: collapse;\n background-color: var(--pie-background, rgba(255, 255, 255))");
|
|
359
|
+
originalTable[1].border = border ? border : '1';
|
|
345
360
|
return originalTable;
|
|
346
361
|
}
|
|
347
362
|
});
|
|
@@ -423,6 +438,23 @@ var styles = function styles(theme) {
|
|
|
423
438
|
border: 'none',
|
|
424
439
|
borderTop: '1px solid var(--gray-2)',
|
|
425
440
|
margin: '2rem 0'
|
|
441
|
+
},
|
|
442
|
+
'& table': {
|
|
443
|
+
tableLayout: 'fixed',
|
|
444
|
+
width: '100%',
|
|
445
|
+
borderCollapse: 'collapse',
|
|
446
|
+
color: _renderUi.color.text(),
|
|
447
|
+
backgroundColor: _renderUi.color.background()
|
|
448
|
+
},
|
|
449
|
+
'& table:not([border="1"]) tr': {
|
|
450
|
+
borderTop: '1px solid #dfe2e5'
|
|
451
|
+
},
|
|
452
|
+
'& td, th': {
|
|
453
|
+
padding: '.6em 1em',
|
|
454
|
+
textAlign: 'center'
|
|
455
|
+
},
|
|
456
|
+
'& table:not([border="1"]) td, th': {
|
|
457
|
+
border: '1px solid #dfe2e5'
|
|
426
458
|
}
|
|
427
459
|
},
|
|
428
460
|
children: {
|
|
@@ -579,6 +611,7 @@ function TiptapContainer(props) {
|
|
|
579
611
|
children = props.children,
|
|
580
612
|
disableUnderline = props.disableUnderline,
|
|
581
613
|
disableScrollbar = props.disableScrollbar,
|
|
614
|
+
activePlugins = props.activePlugins,
|
|
582
615
|
toolbarOpts = props.toolbarOpts,
|
|
583
616
|
responseAreaProps = props.responseAreaProps,
|
|
584
617
|
autoFocus = props.autoFocus,
|
|
@@ -621,6 +654,7 @@ function TiptapContainer(props) {
|
|
|
621
654
|
editor: editor,
|
|
622
655
|
responseAreaProps: responseAreaProps,
|
|
623
656
|
toolbarOpts: toolbarOpts,
|
|
657
|
+
activePlugins: activePlugins,
|
|
624
658
|
onChange: props.onChange
|
|
625
659
|
}));
|
|
626
660
|
}
|
|
@@ -632,6 +666,7 @@ function MenuBar(_ref3) {
|
|
|
632
666
|
|
|
633
667
|
var editor = _ref3.editor,
|
|
634
668
|
classes = _ref3.classes,
|
|
669
|
+
activePlugins = _ref3.activePlugins,
|
|
635
670
|
toolOpts = _ref3.toolbarOpts,
|
|
636
671
|
responseAreaProps = _ref3.responseAreaProps,
|
|
637
672
|
onChange = _ref3.onChange;
|
|
@@ -646,7 +681,7 @@ function MenuBar(_ref3) {
|
|
|
646
681
|
var editorState = (0, _react2.useEditorState)({
|
|
647
682
|
editor: editor,
|
|
648
683
|
selector: function selector(ctx) {
|
|
649
|
-
var _ctx$editor, _ctx$editor2, _ctx$editor3, _ctx$editor4, _ctx$editor5, _ctx$editor$isActive, _ctx$editor$can$chain, _ctx$editor$isActive2, _ctx$editor$can$chain2, _ctx$editor$isActive3, _ctx$editor$can$chain3, _ctx$editor$isActive4, _ctx$editor$can$chain4, _ctx$editor$isActive5, _ctx$editor$can$chain5, _ctx$editor$can$chain6, _ctx$editor$isActive6, _ctx$editor$isActive7, _ctx$editor$isActive8, _ctx$editor$isActive9, _ctx$editor$isActive10, _ctx$editor$isActive11, _ctx$editor$isActive12, _ctx$editor$isActive13, _ctx$editor$isActive14, _ctx$editor$isActive15, _ctx$editor$isActive16, _ctx$editor$isActive17, _ctx$editor$isActive18, _ctx$editor$isActive19, _ctx$editor$can$chain7, _ctx$editor$can$chain8;
|
|
684
|
+
var _ctx$editor, _ctx$editor2, _ctx$editor3, _ctx$editor4, _ctx$editor5, _ctx$editor$isActive, _ctx$editor$can$chain, _ctx$editor$isActive2, _ref5, _ctx$editor$getAttrib, _ctx$editor$can$chain2, _ctx$editor$isActive3, _ctx$editor$can$chain3, _ctx$editor$isActive4, _ctx$editor$can$chain4, _ctx$editor$isActive5, _ctx$editor$can$chain5, _ctx$editor$can$chain6, _ctx$editor$isActive6, _ctx$editor$isActive7, _ctx$editor$isActive8, _ctx$editor$isActive9, _ctx$editor$isActive10, _ctx$editor$isActive11, _ctx$editor$isActive12, _ctx$editor$isActive13, _ctx$editor$isActive14, _ctx$editor$isActive15, _ctx$editor$isActive16, _ctx$editor$isActive17, _ctx$editor$isActive18, _ctx$editor$isActive19, _ctx$editor$can$chain7, _ctx$editor$can$chain8;
|
|
650
685
|
|
|
651
686
|
var _ref4 = ((_ctx$editor = ctx.editor) === null || _ctx$editor === void 0 ? void 0 : _ctx$editor.state) || {},
|
|
652
687
|
selection = _ref4.selection;
|
|
@@ -657,14 +692,15 @@ function MenuBar(_ref3) {
|
|
|
657
692
|
currentNode = selection.node; // the selected node
|
|
658
693
|
}
|
|
659
694
|
|
|
660
|
-
var
|
|
695
|
+
var hideDefaultToolbar = ((_ctx$editor2 = ctx.editor) === null || _ctx$editor2 === void 0 ? void 0 : _ctx$editor2.isActive('math')) || ((_ctx$editor3 = ctx.editor) === null || _ctx$editor3 === void 0 ? void 0 : _ctx$editor3.isActive('explicit_constructed_response')) || ((_ctx$editor4 = ctx.editor) === null || _ctx$editor4 === void 0 ? void 0 : _ctx$editor4.isActive('imageUploadNode'));
|
|
661
696
|
return {
|
|
662
697
|
currentNode: currentNode,
|
|
663
|
-
|
|
698
|
+
hideDefaultToolbar: hideDefaultToolbar,
|
|
664
699
|
isFocused: (_ctx$editor5 = ctx.editor) === null || _ctx$editor5 === void 0 ? void 0 : _ctx$editor5.isFocused,
|
|
665
700
|
isBold: (_ctx$editor$isActive = ctx.editor.isActive('bold')) !== null && _ctx$editor$isActive !== void 0 ? _ctx$editor$isActive : false,
|
|
666
701
|
canBold: (_ctx$editor$can$chain = ctx.editor.can().chain().toggleBold().run()) !== null && _ctx$editor$can$chain !== void 0 ? _ctx$editor$can$chain : false,
|
|
667
702
|
isTable: (_ctx$editor$isActive2 = ctx.editor.isActive('table')) !== null && _ctx$editor$isActive2 !== void 0 ? _ctx$editor$isActive2 : false,
|
|
703
|
+
tableHasBorder: (_ref5 = ((_ctx$editor$getAttrib = ctx.editor.getAttributes('table')) === null || _ctx$editor$getAttrib === void 0 ? void 0 : _ctx$editor$getAttrib.border) === '1') !== null && _ref5 !== void 0 ? _ref5 : false,
|
|
668
704
|
canTable: (_ctx$editor$can$chain2 = ctx.editor.can().chain().insertTable().run()) !== null && _ctx$editor$can$chain2 !== void 0 ? _ctx$editor$can$chain2 : false,
|
|
669
705
|
isItalic: (_ctx$editor$isActive3 = ctx.editor.isActive('italic')) !== null && _ctx$editor$isActive3 !== void 0 ? _ctx$editor$isActive3 : false,
|
|
670
706
|
canItalic: (_ctx$editor$can$chain3 = ctx.editor.can().chain().toggleItalic().run()) !== null && _ctx$editor$can$chain3 !== void 0 ? _ctx$editor$can$chain3 : false,
|
|
@@ -715,143 +751,365 @@ function MenuBar(_ref3) {
|
|
|
715
751
|
e.preventDefault();
|
|
716
752
|
};
|
|
717
753
|
|
|
754
|
+
var toolbarButtons = (0, _react.useMemo)(function () {
|
|
755
|
+
return [{
|
|
756
|
+
icon: /*#__PURE__*/_react["default"].createElement(_GridOn["default"], null),
|
|
757
|
+
onClick: function onClick(editor) {
|
|
758
|
+
return editor.chain().focus().insertTable({
|
|
759
|
+
rows: 2,
|
|
760
|
+
cols: 2,
|
|
761
|
+
withHeaderRow: false
|
|
762
|
+
}).run();
|
|
763
|
+
},
|
|
764
|
+
hidden: function hidden(state) {
|
|
765
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('table')) || state.isTable;
|
|
766
|
+
},
|
|
767
|
+
isActive: function isActive(state) {
|
|
768
|
+
return state.isTable;
|
|
769
|
+
},
|
|
770
|
+
isDisabled: function isDisabled(state) {
|
|
771
|
+
return !state.canTable;
|
|
772
|
+
}
|
|
773
|
+
}, {
|
|
774
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons4.AddRow, null),
|
|
775
|
+
onClick: function onClick(editor) {
|
|
776
|
+
return editor.chain().focus().addRowAfter().run();
|
|
777
|
+
},
|
|
778
|
+
hidden: function hidden(state) {
|
|
779
|
+
return !state.isTable;
|
|
780
|
+
},
|
|
781
|
+
isActive: function isActive(state) {
|
|
782
|
+
return state.isTable;
|
|
783
|
+
},
|
|
784
|
+
isDisabled: function isDisabled(state) {
|
|
785
|
+
return !state.canTable;
|
|
786
|
+
}
|
|
787
|
+
}, {
|
|
788
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons4.RemoveRow, null),
|
|
789
|
+
onClick: function onClick(editor) {
|
|
790
|
+
return editor.chain().focus().deleteRow().run();
|
|
791
|
+
},
|
|
792
|
+
hidden: function hidden(state) {
|
|
793
|
+
return !state.isTable;
|
|
794
|
+
},
|
|
795
|
+
isActive: function isActive(state) {
|
|
796
|
+
return state.isTable;
|
|
797
|
+
},
|
|
798
|
+
isDisabled: function isDisabled(state) {
|
|
799
|
+
return !state.canTable;
|
|
800
|
+
}
|
|
801
|
+
}, {
|
|
802
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons4.AddColumn, null),
|
|
803
|
+
onClick: function onClick(editor) {
|
|
804
|
+
return editor.chain().focus().addColumnAfter().run();
|
|
805
|
+
},
|
|
806
|
+
hidden: function hidden(state) {
|
|
807
|
+
return !state.isTable;
|
|
808
|
+
},
|
|
809
|
+
isActive: function isActive(state) {
|
|
810
|
+
return state.isTable;
|
|
811
|
+
},
|
|
812
|
+
isDisabled: function isDisabled(state) {
|
|
813
|
+
return !state.canTable;
|
|
814
|
+
}
|
|
815
|
+
}, {
|
|
816
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons4.RemoveColumn, null),
|
|
817
|
+
onClick: function onClick(editor) {
|
|
818
|
+
return editor.chain().focus().deleteColumn().run();
|
|
819
|
+
},
|
|
820
|
+
hidden: function hidden(state) {
|
|
821
|
+
return !state.isTable;
|
|
822
|
+
},
|
|
823
|
+
isActive: function isActive(state) {
|
|
824
|
+
return state.isTable;
|
|
825
|
+
},
|
|
826
|
+
isDisabled: function isDisabled(state) {
|
|
827
|
+
return !state.canTable;
|
|
828
|
+
}
|
|
829
|
+
}, {
|
|
830
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons4.RemoveTable, null),
|
|
831
|
+
onClick: function onClick(editor) {
|
|
832
|
+
return editor.chain().focus().deleteTable().run();
|
|
833
|
+
},
|
|
834
|
+
hidden: function hidden(state) {
|
|
835
|
+
return !state.isTable;
|
|
836
|
+
},
|
|
837
|
+
isActive: function isActive(state) {
|
|
838
|
+
return state.isTable;
|
|
839
|
+
},
|
|
840
|
+
isDisabled: function isDisabled(state) {
|
|
841
|
+
return !state.canTable;
|
|
842
|
+
}
|
|
843
|
+
}, {
|
|
844
|
+
icon: /*#__PURE__*/_react["default"].createElement(_BorderAll["default"], null),
|
|
845
|
+
onClick: function onClick(editor) {
|
|
846
|
+
var tableAttrs = editor.getAttributes('table');
|
|
847
|
+
|
|
848
|
+
var update = _objectSpread(_objectSpread({}, tableAttrs), {}, {
|
|
849
|
+
border: tableAttrs.border !== '0' ? '0' : '1'
|
|
850
|
+
});
|
|
851
|
+
|
|
852
|
+
editor.commands.updateAttributes('table', update);
|
|
853
|
+
},
|
|
854
|
+
hidden: function hidden(state) {
|
|
855
|
+
return !state.isTable;
|
|
856
|
+
},
|
|
857
|
+
isActive: function isActive(state) {
|
|
858
|
+
return state.tableHasBorder;
|
|
859
|
+
},
|
|
860
|
+
isDisabled: function isDisabled(state) {
|
|
861
|
+
return !state.canTable;
|
|
862
|
+
}
|
|
863
|
+
}, {
|
|
864
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatBold["default"], null),
|
|
865
|
+
onClick: function onClick(editor) {
|
|
866
|
+
return editor.chain().focus().toggleBold().run();
|
|
867
|
+
},
|
|
868
|
+
hidden: function hidden(state) {
|
|
869
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('bold')) || state.isTable;
|
|
870
|
+
},
|
|
871
|
+
isActive: function isActive(state) {
|
|
872
|
+
return state.isBold;
|
|
873
|
+
},
|
|
874
|
+
isDisabled: function isDisabled(state) {
|
|
875
|
+
return !state.canBold;
|
|
876
|
+
}
|
|
877
|
+
}, {
|
|
878
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatItalic["default"], null),
|
|
879
|
+
onClick: function onClick(editor) {
|
|
880
|
+
return editor.chain().focus().toggleItalic().run();
|
|
881
|
+
},
|
|
882
|
+
hidden: function hidden(state) {
|
|
883
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('italic')) || state.isTable;
|
|
884
|
+
},
|
|
885
|
+
isActive: function isActive(state) {
|
|
886
|
+
return state.isItalic;
|
|
887
|
+
},
|
|
888
|
+
isDisabled: function isDisabled(state) {
|
|
889
|
+
return !state.canItalic;
|
|
890
|
+
}
|
|
891
|
+
}, {
|
|
892
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatStrikethrough["default"], null),
|
|
893
|
+
onClick: function onClick(editor) {
|
|
894
|
+
return editor.chain().focus().toggleStrike().run();
|
|
895
|
+
},
|
|
896
|
+
hidden: function hidden(state) {
|
|
897
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('strikethrough')) || state.isTable;
|
|
898
|
+
},
|
|
899
|
+
isActive: function isActive(state) {
|
|
900
|
+
return state.isStrike;
|
|
901
|
+
},
|
|
902
|
+
isDisabled: function isDisabled(state) {
|
|
903
|
+
return !state.canStrike;
|
|
904
|
+
}
|
|
905
|
+
}, {
|
|
906
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Code["default"], null),
|
|
907
|
+
onClick: function onClick(editor) {
|
|
908
|
+
return editor.chain().focus().toggleCode().run();
|
|
909
|
+
},
|
|
910
|
+
hidden: function hidden(state) {
|
|
911
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('code')) || state.isTable;
|
|
912
|
+
},
|
|
913
|
+
isActive: function isActive(state) {
|
|
914
|
+
return state.isCode;
|
|
915
|
+
},
|
|
916
|
+
isDisabled: function isDisabled(state) {
|
|
917
|
+
return !state.canCode;
|
|
918
|
+
}
|
|
919
|
+
}, {
|
|
920
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatUnderlined["default"], null),
|
|
921
|
+
onClick: function onClick(editor) {
|
|
922
|
+
return editor.chain().focus().toggleUnderline().run();
|
|
923
|
+
},
|
|
924
|
+
hidden: function hidden(state) {
|
|
925
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('underline')) || state.isTable;
|
|
926
|
+
},
|
|
927
|
+
isActive: function isActive(state) {
|
|
928
|
+
return state.isUnderline;
|
|
929
|
+
}
|
|
930
|
+
}, {
|
|
931
|
+
icon: /*#__PURE__*/_react["default"].createElement(SubscriptIcon, null),
|
|
932
|
+
onClick: function onClick(editor) {
|
|
933
|
+
return editor.chain().focus().toggleSubscript().run();
|
|
934
|
+
},
|
|
935
|
+
hidden: function hidden(state) {
|
|
936
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('subscript')) || state.isTable;
|
|
937
|
+
},
|
|
938
|
+
isActive: function isActive(state) {
|
|
939
|
+
return state.isSubScript;
|
|
940
|
+
}
|
|
941
|
+
}, {
|
|
942
|
+
icon: /*#__PURE__*/_react["default"].createElement(SuperscriptIcon, null),
|
|
943
|
+
onClick: function onClick(editor) {
|
|
944
|
+
return editor.chain().focus().toggleSuperscript().run();
|
|
945
|
+
},
|
|
946
|
+
hidden: function hidden(state) {
|
|
947
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('superscript')) || state.isTable;
|
|
948
|
+
},
|
|
949
|
+
isActive: function isActive(state) {
|
|
950
|
+
return state.isSuperScript;
|
|
951
|
+
}
|
|
952
|
+
}, {
|
|
953
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Image["default"], null),
|
|
954
|
+
hidden: function hidden(state) {
|
|
955
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('image')) || state.isTable;
|
|
956
|
+
},
|
|
957
|
+
onClick: function onClick(editor) {
|
|
958
|
+
return editor.chain().focus().setImageUploadNode().run();
|
|
959
|
+
}
|
|
960
|
+
}, {
|
|
961
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Theaters["default"], null),
|
|
962
|
+
hidden: function hidden(state) {
|
|
963
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('video')) || state.isTable;
|
|
964
|
+
},
|
|
965
|
+
onClick: function onClick(editor) {
|
|
966
|
+
return editor.chain().focus().insertMedia({
|
|
967
|
+
tag: 'video'
|
|
968
|
+
}).run();
|
|
969
|
+
}
|
|
970
|
+
}, {
|
|
971
|
+
icon: /*#__PURE__*/_react["default"].createElement(_VolumeUp["default"], null),
|
|
972
|
+
hidden: function hidden(state) {
|
|
973
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('audio')) || state.isTable;
|
|
974
|
+
},
|
|
975
|
+
onClick: function onClick(editor) {
|
|
976
|
+
return editor.chain().focus().insertMedia({
|
|
977
|
+
tag: 'audio'
|
|
978
|
+
}).run();
|
|
979
|
+
}
|
|
980
|
+
}, {
|
|
981
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons3["default"], null),
|
|
982
|
+
hidden: function hidden(state) {
|
|
983
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('css')) || state.isTable;
|
|
984
|
+
},
|
|
985
|
+
onClick: function onClick(editor) {
|
|
986
|
+
return editor.commands.openCSSClassDialog();
|
|
987
|
+
}
|
|
988
|
+
}, {
|
|
989
|
+
icon: /*#__PURE__*/_react["default"].createElement(HeadingIcon, null),
|
|
990
|
+
hidden: function hidden(state) {
|
|
991
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('h3')) || state.isTable;
|
|
992
|
+
},
|
|
993
|
+
onClick: function onClick(editor) {
|
|
994
|
+
return editor.chain().focus().toggleHeading({
|
|
995
|
+
level: 3
|
|
996
|
+
}).run();
|
|
997
|
+
},
|
|
998
|
+
isActive: function isActive(state) {
|
|
999
|
+
return state.isHeading3;
|
|
1000
|
+
}
|
|
1001
|
+
}, {
|
|
1002
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Functions["default"], null),
|
|
1003
|
+
hidden: function hidden() {
|
|
1004
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('math'));
|
|
1005
|
+
},
|
|
1006
|
+
onClick: function onClick(editor) {
|
|
1007
|
+
return editor.chain().focus().insertMath('').run();
|
|
1008
|
+
}
|
|
1009
|
+
}, {
|
|
1010
|
+
icon: /*#__PURE__*/_react["default"].createElement(CharacterIcon, {
|
|
1011
|
+
letter: "\xF1"
|
|
1012
|
+
}),
|
|
1013
|
+
hidden: function hidden(state) {
|
|
1014
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('languageCharacters')) || state.isTable;
|
|
1015
|
+
},
|
|
1016
|
+
onClick: function onClick() {
|
|
1017
|
+
return setShowPicker(_utils.spanishConfig);
|
|
1018
|
+
}
|
|
1019
|
+
}, {
|
|
1020
|
+
icon: /*#__PURE__*/_react["default"].createElement(CharacterIcon, {
|
|
1021
|
+
letter: "\u20AC"
|
|
1022
|
+
}),
|
|
1023
|
+
hidden: function hidden(state) {
|
|
1024
|
+
return (activePlugins === null || activePlugins === void 0 ? void 0 : activePlugins.filter(function (p) {
|
|
1025
|
+
return p === 'languageCharacters';
|
|
1026
|
+
}).length) !== 2 || state.isTable;
|
|
1027
|
+
},
|
|
1028
|
+
onClick: function onClick() {
|
|
1029
|
+
return setShowPicker(_utils.specialConfig);
|
|
1030
|
+
}
|
|
1031
|
+
}, {
|
|
1032
|
+
icon: /*#__PURE__*/_react["default"].createElement(_icons2["default"], {
|
|
1033
|
+
editor: editor
|
|
1034
|
+
}),
|
|
1035
|
+
hidden: function hidden(state) {
|
|
1036
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('text-align')) || state.isTable;
|
|
1037
|
+
},
|
|
1038
|
+
onClick: function onClick() {}
|
|
1039
|
+
}, {
|
|
1040
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatListBulleted["default"], null),
|
|
1041
|
+
hidden: function hidden(state) {
|
|
1042
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('bulleted-list')) || state.isTable;
|
|
1043
|
+
},
|
|
1044
|
+
onClick: function onClick(editor) {
|
|
1045
|
+
return editor.chain().focus().toggleBulletList().run();
|
|
1046
|
+
},
|
|
1047
|
+
isActive: function isActive(state) {
|
|
1048
|
+
return state.isBulletList;
|
|
1049
|
+
}
|
|
1050
|
+
}, {
|
|
1051
|
+
icon: /*#__PURE__*/_react["default"].createElement(_FormatListNumbered["default"], null),
|
|
1052
|
+
hidden: function hidden(state) {
|
|
1053
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('numbered-list')) || state.isTable;
|
|
1054
|
+
},
|
|
1055
|
+
onClick: function onClick(editor) {
|
|
1056
|
+
return editor.chain().focus().toggleOrderedList().run();
|
|
1057
|
+
},
|
|
1058
|
+
isActive: function isActive(state) {
|
|
1059
|
+
return state.isOrderedList;
|
|
1060
|
+
}
|
|
1061
|
+
}, {
|
|
1062
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Undo["default"], null),
|
|
1063
|
+
hidden: function hidden(state) {
|
|
1064
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('undo')) || state.isTable;
|
|
1065
|
+
},
|
|
1066
|
+
onClick: function onClick(editor) {
|
|
1067
|
+
return editor.chain().focus().undo().run();
|
|
1068
|
+
},
|
|
1069
|
+
isDisabled: function isDisabled(state) {
|
|
1070
|
+
return !state.canUndo;
|
|
1071
|
+
}
|
|
1072
|
+
}, {
|
|
1073
|
+
icon: /*#__PURE__*/_react["default"].createElement(_Redo["default"], null),
|
|
1074
|
+
hidden: function hidden(state) {
|
|
1075
|
+
return !(activePlugins !== null && activePlugins !== void 0 && activePlugins.includes('redo')) || state.isTable;
|
|
1076
|
+
},
|
|
1077
|
+
onClick: function onClick(editor) {
|
|
1078
|
+
return editor.chain().focus().redo().run();
|
|
1079
|
+
},
|
|
1080
|
+
isDisabled: function isDisabled(state) {
|
|
1081
|
+
return !state.canRedo;
|
|
1082
|
+
}
|
|
1083
|
+
}];
|
|
1084
|
+
}, [activePlugins, editor, _utils.spanishConfig, _utils.specialConfig, setShowPicker]);
|
|
718
1085
|
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
719
1086
|
className: names,
|
|
720
1087
|
style: _objectSpread({}, customStyles),
|
|
721
1088
|
onMouseDown: handleMouseDown
|
|
722
|
-
}, !editorState.
|
|
1089
|
+
}, !editorState.hideDefaultToolbar && /*#__PURE__*/_react["default"].createElement("div", {
|
|
723
1090
|
className: classes.defaultToolbar,
|
|
724
1091
|
tabIndex: "1"
|
|
725
1092
|
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
726
1093
|
className: classes.buttonsContainer
|
|
727
|
-
},
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
},
|
|
745
|
-
|
|
746
|
-
active: editorState.isItalic,
|
|
747
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isItalic))
|
|
748
|
-
}, /*#__PURE__*/_react["default"].createElement(_FormatItalic["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
749
|
-
onClick: function onClick() {
|
|
750
|
-
return editor.chain().focus().toggleStrike().run();
|
|
751
|
-
},
|
|
752
|
-
disabled: !editorState.canStrike,
|
|
753
|
-
active: editorState.isStrike,
|
|
754
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isStrike))
|
|
755
|
-
}, /*#__PURE__*/_react["default"].createElement(_FormatStrikethrough["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
756
|
-
onClick: function onClick() {
|
|
757
|
-
return editor.chain().focus().toggleCode().run();
|
|
758
|
-
},
|
|
759
|
-
disabled: !editorState.canCode,
|
|
760
|
-
active: editorState.isCode,
|
|
761
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isCode))
|
|
762
|
-
}, /*#__PURE__*/_react["default"].createElement(_Code["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
763
|
-
onClick: function onClick() {
|
|
764
|
-
return editor.chain().focus().toggleUnderline().run();
|
|
765
|
-
},
|
|
766
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isUnderline))
|
|
767
|
-
}, /*#__PURE__*/_react["default"].createElement(_FormatUnderlined["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
768
|
-
onClick: function onClick() {
|
|
769
|
-
return editor.chain().focus().toggleSubscript().run();
|
|
770
|
-
},
|
|
771
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isSubScript))
|
|
772
|
-
}, /*#__PURE__*/_react["default"].createElement(SubscriptIcon, null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
773
|
-
onClick: function onClick() {
|
|
774
|
-
return editor.chain().focus().toggleSuperscript().run();
|
|
775
|
-
},
|
|
776
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isSuperScript))
|
|
777
|
-
}, /*#__PURE__*/_react["default"].createElement(SuperscriptIcon, null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
778
|
-
onClick: function onClick() {
|
|
779
|
-
return editor.chain().focus().setImageUploadNode().run();
|
|
780
|
-
},
|
|
781
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isSuperScript))
|
|
782
|
-
}, /*#__PURE__*/_react["default"].createElement(_Image["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
783
|
-
onClick: function onClick() {
|
|
784
|
-
return editor.chain().focus().insertMedia({
|
|
785
|
-
tag: 'video'
|
|
786
|
-
}).run();
|
|
787
|
-
},
|
|
788
|
-
className: (0, _classnames["default"])(classes.button)
|
|
789
|
-
}, /*#__PURE__*/_react["default"].createElement(_Theaters["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
790
|
-
onClick: function onClick() {
|
|
791
|
-
return editor.chain().focus().insertMedia({
|
|
792
|
-
tag: 'audio'
|
|
793
|
-
}).run();
|
|
794
|
-
},
|
|
795
|
-
className: (0, _classnames["default"])(classes.button)
|
|
796
|
-
}, /*#__PURE__*/_react["default"].createElement(_VolumeUp["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
797
|
-
onClick: function onClick() {
|
|
798
|
-
return editor.commands.openCSSClassDialog();
|
|
799
|
-
},
|
|
800
|
-
className: (0, _classnames["default"])(classes.button)
|
|
801
|
-
}, /*#__PURE__*/_react["default"].createElement(_icons3["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
802
|
-
onClick: function onClick() {
|
|
803
|
-
return editor.chain().focus().toggleHeading({
|
|
804
|
-
level: 3
|
|
805
|
-
}).run();
|
|
806
|
-
},
|
|
807
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isHeading3))
|
|
808
|
-
}, /*#__PURE__*/_react["default"].createElement(HeadingIcon, null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
809
|
-
onClick: function onClick() {
|
|
810
|
-
return editor.chain().focus().insertMath('').run();
|
|
811
|
-
},
|
|
812
|
-
className: classes.button
|
|
813
|
-
}, /*#__PURE__*/_react["default"].createElement(_Functions["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
814
|
-
onClick: function onClick() {
|
|
815
|
-
return setShowPicker(_utils.spanishConfig);
|
|
816
|
-
},
|
|
817
|
-
className: classes.button
|
|
818
|
-
}, /*#__PURE__*/_react["default"].createElement(CharacterIcon, {
|
|
819
|
-
letter: "\xF1"
|
|
820
|
-
})), /*#__PURE__*/_react["default"].createElement("button", {
|
|
821
|
-
onClick: function onClick() {
|
|
822
|
-
return setShowPicker(_utils.specialConfig);
|
|
823
|
-
},
|
|
824
|
-
className: classes.button
|
|
825
|
-
}, /*#__PURE__*/_react["default"].createElement(CharacterIcon, {
|
|
826
|
-
letter: "\u20AC"
|
|
827
|
-
})), /*#__PURE__*/_react["default"].createElement("button", {
|
|
828
|
-
onClick: function onClick() {},
|
|
829
|
-
className: classes.button
|
|
830
|
-
}, /*#__PURE__*/_react["default"].createElement(_icons2["default"], {
|
|
831
|
-
editor: editor
|
|
832
|
-
})), /*#__PURE__*/_react["default"].createElement("button", {
|
|
833
|
-
onClick: function onClick() {
|
|
834
|
-
return editor.chain().focus().toggleBulletList().run();
|
|
835
|
-
},
|
|
836
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isBulletList))
|
|
837
|
-
}, /*#__PURE__*/_react["default"].createElement(_FormatListBulleted["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
838
|
-
onClick: function onClick() {
|
|
839
|
-
return editor.chain().focus().toggleOrderedList().run();
|
|
840
|
-
},
|
|
841
|
-
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, editorState.isOrderedList))
|
|
842
|
-
}, /*#__PURE__*/_react["default"].createElement(_FormatListNumbered["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
843
|
-
onClick: function onClick() {
|
|
844
|
-
return editor.chain().focus().undo().run();
|
|
845
|
-
},
|
|
846
|
-
disabled: !editorState.canUndo,
|
|
847
|
-
className: classes.button
|
|
848
|
-
}, /*#__PURE__*/_react["default"].createElement(_Undo["default"], null)), /*#__PURE__*/_react["default"].createElement("button", {
|
|
849
|
-
onClick: function onClick() {
|
|
850
|
-
return editor.chain().focus().redo().run();
|
|
851
|
-
},
|
|
852
|
-
disabled: !editorState.canRedo,
|
|
853
|
-
className: classes.button
|
|
854
|
-
}, /*#__PURE__*/_react["default"].createElement(_Redo["default"], null))), /*#__PURE__*/_react["default"].createElement("button", {
|
|
1094
|
+
}, toolbarButtons.filter(function (btn) {
|
|
1095
|
+
var _btn$hidden;
|
|
1096
|
+
|
|
1097
|
+
return !((_btn$hidden = btn.hidden) !== null && _btn$hidden !== void 0 && _btn$hidden.call(btn, editorState));
|
|
1098
|
+
}).map(function (btn, index) {
|
|
1099
|
+
var _btn$isDisabled, _btn$isActive;
|
|
1100
|
+
|
|
1101
|
+
var disabled = (_btn$isDisabled = btn.isDisabled) === null || _btn$isDisabled === void 0 ? void 0 : _btn$isDisabled.call(btn, editorState);
|
|
1102
|
+
var active = (_btn$isActive = btn.isActive) === null || _btn$isActive === void 0 ? void 0 : _btn$isActive.call(btn, editorState);
|
|
1103
|
+
return /*#__PURE__*/_react["default"].createElement("button", {
|
|
1104
|
+
key: index,
|
|
1105
|
+
disabled: disabled,
|
|
1106
|
+
onClick: function onClick(e) {
|
|
1107
|
+
e.preventDefault();
|
|
1108
|
+
btn.onClick(editor);
|
|
1109
|
+
},
|
|
1110
|
+
className: (0, _classnames["default"])(classes.button, (0, _defineProperty2["default"])({}, classes.active, active))
|
|
1111
|
+
}, btn.icon);
|
|
1112
|
+
})), (activePlugins === null || activePlugins === void 0 ? void 0 : activePlugins.includes('responseArea')) && /*#__PURE__*/_react["default"].createElement("button", {
|
|
855
1113
|
onClick: function onClick() {
|
|
856
1114
|
editor.chain().focus().insertResponseArea(responseAreaProps.type).run();
|
|
857
1115
|
},
|
|
@@ -996,6 +1254,26 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
996
1254
|
|
|
997
1255
|
var toolbarOptsToUse = _objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts);
|
|
998
1256
|
|
|
1257
|
+
var activePluginsToUse = (0, _react.useMemo)(function () {
|
|
1258
|
+
var _ref6 = props.pluginProps || {},
|
|
1259
|
+
customPlugins = _ref6.customPlugins;
|
|
1260
|
+
|
|
1261
|
+
customPlugins = customPlugins || [];
|
|
1262
|
+
return (0, _index.buildPlugins)(props.activePlugins, customPlugins, {
|
|
1263
|
+
math: {},
|
|
1264
|
+
textAlign: {},
|
|
1265
|
+
html: {},
|
|
1266
|
+
extraCSSRules: props.extraCSSRules || {},
|
|
1267
|
+
image: {},
|
|
1268
|
+
toolbar: {},
|
|
1269
|
+
table: {},
|
|
1270
|
+
responseArea: {},
|
|
1271
|
+
languageCharacters: props.languageCharactersProps,
|
|
1272
|
+
keyPadCharacterRef: {},
|
|
1273
|
+
setKeypadInteraction: {},
|
|
1274
|
+
media: {}
|
|
1275
|
+
});
|
|
1276
|
+
}, [props]);
|
|
999
1277
|
var extensions = [_extensionTextStyle.TextStyleKit, _starterKit["default"], ExtendedTable, _extensionTableRow.TableRow, _extensionTableHeader.TableHeader, _extensionTableCell.TableCell, _responseArea.ResponseAreaExtension, _responseArea.ExplicitConstructedResponseNode.configure(props.responseAreaProps), _responseArea.DragInTheBlankNode.configure(props.responseAreaProps), _responseArea.InlineDropdownNode.configure(props.responseAreaProps), _math.MathNode.configure({
|
|
1000
1278
|
toolbarOpts: toolbarOptsToUse
|
|
1001
1279
|
}), _extensionSubscript["default"], _extensionSuperscript["default"], _extensionTextAlign["default"].configure({
|
|
@@ -1005,6 +1283,11 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
1005
1283
|
toolbarOpts: toolbarOptsToUse,
|
|
1006
1284
|
imageHandling: {
|
|
1007
1285
|
disableImageAlignmentButtons: props.disableImageAlignmentButtons,
|
|
1286
|
+
onDone: function onDone() {
|
|
1287
|
+
var _props$onDone;
|
|
1288
|
+
|
|
1289
|
+
return (_props$onDone = props.onDone) === null || _props$onDone === void 0 ? void 0 : _props$onDone.call(props, editor.getHTML());
|
|
1290
|
+
},
|
|
1008
1291
|
onDelete: props.imageSupport && props.imageSupport["delete"] && function (node, done) {
|
|
1009
1292
|
var src = node.attrs.src;
|
|
1010
1293
|
props.imageSupport["delete"](src, function (e) {
|
|
@@ -1072,24 +1355,24 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
1072
1355
|
extensions: extensions,
|
|
1073
1356
|
immediatelyRender: false,
|
|
1074
1357
|
content: props.markup,
|
|
1075
|
-
onUpdate: function onUpdate(
|
|
1358
|
+
onUpdate: function onUpdate(_ref7) {
|
|
1076
1359
|
var _props$onChange;
|
|
1077
1360
|
|
|
1078
|
-
var editor =
|
|
1079
|
-
transaction =
|
|
1361
|
+
var editor = _ref7.editor,
|
|
1362
|
+
transaction = _ref7.transaction;
|
|
1080
1363
|
return transaction.isDone && ((_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, editor.getHTML()));
|
|
1081
1364
|
},
|
|
1082
|
-
onBlur: function onBlur(
|
|
1083
|
-
var editor =
|
|
1365
|
+
onBlur: function onBlur(_ref8) {
|
|
1366
|
+
var editor = _ref8.editor;
|
|
1084
1367
|
|
|
1085
1368
|
if (toolbarOptsToUse.doneOn === 'blur') {
|
|
1086
1369
|
var _props$onChange2;
|
|
1087
1370
|
|
|
1088
1371
|
(_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 ? void 0 : _props$onChange2.call(props, editor.getHTML());
|
|
1089
1372
|
} else {
|
|
1090
|
-
var _props$
|
|
1373
|
+
var _props$onDone2;
|
|
1091
1374
|
|
|
1092
|
-
(_props$
|
|
1375
|
+
(_props$onDone2 = props.onDone) === null || _props$onDone2 === void 0 ? void 0 : _props$onDone2.call(props, editor.getHTML());
|
|
1093
1376
|
}
|
|
1094
1377
|
}
|
|
1095
1378
|
});
|
|
@@ -1124,10 +1407,10 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
1124
1407
|
'--red-light': '#ffebe5',
|
|
1125
1408
|
'--shadow': "0px 12px 33px 0px rgba(0, 0, 0, .06),\n 0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)"
|
|
1126
1409
|
};
|
|
1127
|
-
Object.entries(cssVariables).forEach(function (
|
|
1128
|
-
var
|
|
1129
|
-
key =
|
|
1130
|
-
value =
|
|
1410
|
+
Object.entries(cssVariables).forEach(function (_ref9) {
|
|
1411
|
+
var _ref10 = (0, _slicedToArray2["default"])(_ref9, 2),
|
|
1412
|
+
key = _ref10[0],
|
|
1413
|
+
value = _ref10[1];
|
|
1131
1414
|
|
|
1132
1415
|
document.documentElement.style.setProperty(key, value);
|
|
1133
1416
|
});
|
|
@@ -1183,6 +1466,7 @@ var EditableHtml = function EditableHtml(props) {
|
|
|
1183
1466
|
};
|
|
1184
1467
|
}, [props]);
|
|
1185
1468
|
return /*#__PURE__*/_react["default"].createElement(EditorContainer, (0, _extends2["default"])({}, _objectSpread(_objectSpread({}, props), {}, {
|
|
1469
|
+
activePlugins: activePluginsToUse,
|
|
1186
1470
|
toolbarOpts: toolbarOptsToUse
|
|
1187
1471
|
}), {
|
|
1188
1472
|
editorState: editorState,
|
|
@@ -1210,4 +1494,4 @@ var StyledEditor = (0, _styles.withStyles)({
|
|
|
1210
1494
|
})(EditableHtml);
|
|
1211
1495
|
var _default = StyledEditor;
|
|
1212
1496
|
exports["default"] = _default;
|
|
1213
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.jsx"],"names":["CharacterIcon","letter","fontSize","lineHeight","propTypes","PropTypes","string","CharacterPicker","editor","opts","onClose","characters","length","containerRef","top","left","position","setPosition","popover","setPopover","configToUse","language","spanishConfig","specialConfig","layoutForCharacters","reduce","obj","arr","columns","rows","closePopOver","bodyRect","document","body","getBoundingClientRect","from","state","selection","start","view","coordsAtPos","Math","abs","handleClickOutside","e","current","contains","target","dom","addEventListener","removeEventListener","renderPopOver","event","el","anchorEl","currentTarget","handleChange","val","chain","focus","insertContent","run","ReactDOM","createPortal","maxWidth","keyPadCharacterRef","setKeypadInteraction","n","map","k","name","write","label","category","extraClass","extraProps","style","border","hasPreview","actions","onMouseEnter","ev","onMouseLeave","description","unicode","SuperscriptIcon","SubscriptIcon","HeadingIcon","width","height","ExtendedTable","Table","extend","renderHTML","props","originalTable","parent","styles","theme","root","padding","borderRadius","cursor","wordBreak","overflow","maxHeight","marginTop","margin","marginBottom","textWrap","backgroundColor","color","background","fontFamily","borderLeft","paddingLeft","borderTop","children","editorHolder","text","right","bottom","content","transition","pointerEvents","transform","primary","palette","common","black","disabledUnderline","display","disabledScrollbar","scrollbarWidth","readOnly","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","editorInFocus","error","main","noBorder","noPadding","toolbarOnTop","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","valueToSize","v","calcRegex","endsWith","undefined","match","value","parseInt","isNaN","TiptapContainer","editorState","classes","disableUnderline","disableScrollbar","toolbarOpts","responseAreaProps","autoFocus","minWidth","minHeight","holderNames","isFocused","Promise","resolve","then","commands","sizeStyle","className","onChange","EditorContainer","MenuBar","toolOpts","showPicker","setShowPicker","selector","ctx","currentNode","NodeSelection","node","customToolbarActive","isActive","isBold","canBold","can","toggleBold","isTable","canTable","insertTable","isItalic","canItalic","toggleItalic","isStrike","canStrike","toggleStrike","isCode","canCode","toggleCode","canClearMarks","unsetAllMarks","isUnderline","isSubScript","isSuperScript","isParagraph","isHeading1","level","isHeading2","isHeading3","isHeading4","isHeading5","isHeading6","isBulletList","isOrderedList","isCodeBlock","isBlockquote","canUndo","undo","canRedo","redo","hasDoneButton","autoWidth","names","toolbar","PIE_TOOLBAR__CLASS","toolbarWithNoDone","toolbarTop","toolbarRight","alignment","focused","alwaysVisible","_toolbarOpened","fullWidth","hidden","isHidden","customStyles","handleMouseDown","preventDefault","defaultToolbar","buttonsContainer","button","active","toggleUnderline","toggleSubscript","toggleSuperscript","setImageUploadNode","insertMedia","tag","openCSSClassDialog","toggleHeading","insertMath","toggleBulletList","toggleOrderedList","insertResponseArea","type","getHTML","blur","ch","console","log","justifyContent","alignItems","outline","grey","disabled","opacity","zIndex","boxShadow","boxSizing","visibility","iconRoot","verticalAlign","shared","StyledMenuBar","index","defaultToolbarOpts","showDone","doneOn","EditableHtml","pendingImages","setPendingImages","scheduled","setScheduled","toolbarOptsToUse","extensions","TextStyleKit","StarterKit","TableRow","TableHeader","TableCell","ResponseAreaExtension","ExplicitConstructedResponseNode","configure","DragInTheBlankNode","InlineDropdownNode","MathNode","SubScript","SuperScript","TextAlign","types","alignments","Image","ImageUploadNode","imageHandling","disableImageAlignmentButtons","onDelete","imageSupport","done","src","attrs","newPendingImages","filter","img","key","newState","insertImageRequested","addedImage","getHandler","onFinish","result","cb","callback","handler","add","maxImageWidth","maxImageHeight","limit","Media","uploadSoundSupport","CSSMark","extraCSSRules","immediatelyRender","markup","onUpdate","transaction","isDone","onBlur","onDone","setContent","cssVariables","Object","entries","forEach","documentElement","setProperty","StyledEditor"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\nimport { createRoot } from 'react-dom/client';\nimport { NodeSelection } from 'prosemirror-state';\nimport { TextStyleKit } from '@tiptap/extension-text-style';\nimport { EditorContent, useEditor, useEditorState } from '@tiptap/react';\nimport StarterKit from '@tiptap/starter-kit';\nimport { Table } from '@tiptap/extension-table';\nimport { TableRow } from '@tiptap/extension-table-row';\nimport { TableCell } from '@tiptap/extension-table-cell';\nimport { TableHeader } from '@tiptap/extension-table-header';\nimport SuperScript from '@tiptap/extension-superscript';\nimport SubScript from '@tiptap/extension-subscript';\nimport TextAlign from '@tiptap/extension-text-align';\nimport Image from '@tiptap/extension-image';\n\nimport { withStyles } from '@material-ui/core/styles';\nimport {\n  ExplicitConstructedResponseNode,\n  DragInTheBlankNode,\n  InlineDropdownNode,\n  ResponseAreaExtension,\n} from './extensions/responseArea';\nimport { MathNode } from './extensions/math';\nimport classNames from 'classnames';\nimport { color } from '@pie-lib/render-ui';\nimport { primary } from './theme';\nimport { PIE_TOOLBAR__CLASS } from './constants';\nimport { DoneButton } from './plugins/toolbar/done-button';\nimport Bold from '@material-ui/icons/FormatBold';\nimport Italic from '@material-ui/icons/FormatItalic';\nimport Strikethrough from '@material-ui/icons/FormatStrikethrough';\nimport Code from '@material-ui/icons/Code';\nimport GridOn from '@material-ui/icons/GridOn';\nimport BulletedListIcon from '@material-ui/icons/FormatListBulleted';\nimport NumberedListIcon from '@material-ui/icons/FormatListNumbered';\nimport Underline from '@material-ui/icons/FormatUnderlined';\nimport Functions from '@material-ui/icons/Functions';\nimport ImageIcon from '@material-ui/icons/Image';\nimport { ToolbarIcon } from './plugins/respArea/icons';\nimport Redo from '@material-ui/icons/Redo';\nimport Undo from '@material-ui/icons/Undo';\nimport TheatersIcon from \"@material-ui/icons/Theaters\";\nimport VolumeUpIcon from \"@material-ui/icons/VolumeUp\";\nimport { characterIcons, spanishConfig, specialConfig } from './plugins/characters/utils';\nimport PropTypes from 'prop-types';\nimport { MathToolbar, PureToolbar } from '@pie-lib/math-toolbar';\nimport get from 'lodash/get';\nimport CustomPopper from './plugins/characters/custom-popper';\nimport TextAlignIcon from './plugins/textAlign/icons';\nimport CSSIcon from './plugins/css/icons';\n\nimport { ImageUploadNode } from './extensions/image';\nimport { Media } from './extensions/media';\nimport { CSSMark } from \"./extensions/css\";\n\nconst CharacterIcon = ({ letter }) => (\n  <div\n    style={{\n      fontSize: '24px',\n      lineHeight: '24px',\n    }}\n  >\n    {letter}\n  </div>\n);\n\nCharacterIcon.propTypes = {\n  letter: PropTypes.string,\n};\n\nexport function CharacterPicker({ editor, opts, onClose }) {\n  if (!opts?.characters?.length) {\n    return null;\n  }\n\n  const containerRef = useRef(null);\n  const [position, setPosition] = useState({ top: 0, left: 0 });\n  const [popover, setPopover] = useState(null);\n\n  let configToUse;\n\n  switch (true) {\n    case opts.language === 'spanish':\n      configToUse = spanishConfig;\n      break;\n    case opts.language === 'special':\n      configToUse = specialConfig;\n      break;\n    default:\n      configToUse = opts;\n  }\n\n  const layoutForCharacters = configToUse.characters.reduce(\n    (obj, arr) => {\n      if (arr.length >= obj.columns) {\n        obj.columns = arr.length;\n      }\n\n      return obj;\n    },\n    { rows: configToUse.characters.length, columns: 0 },\n  );\n\n  useEffect(() => {\n    return () => {\n      closePopOver();\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!editor) return;\n\n    // Calculate position relative to selection\n    const bodyRect = document.body.getBoundingClientRect();\n    const { from } = editor.state.selection;\n    const start = editor.view.coordsAtPos(from);\n    setPosition({\n      top: start.top + Math.abs(bodyRect.top) + 40, // shift above\n      left: start.left,\n    });\n\n    const handleClickOutside = (e) => {\n      if (containerRef.current && !containerRef.current.contains(e.target) && !editor.view.dom.contains(e.target)) {\n        onClose();\n      }\n    };\n\n    document.addEventListener('mousedown', handleClickOutside);\n    return () => document.removeEventListener('mousedown', handleClickOutside);\n  }, [editor]);\n\n  const renderPopOver = (event, el) => setPopover({ anchorEl: event.currentTarget, el });\n  const closePopOver = () => setPopover(null);\n\n  const handleChange = (val) => {\n    if (typeof val === 'string') {\n      editor\n        .chain()\n        .focus()\n        .insertContent(val)\n        .run();\n    }\n  };\n\n  return (\n    <React.Fragment>\n      {ReactDOM.createPortal(\n        <div\n          ref={containerRef}\n          className=\"insert-character-dialog\"\n          style={{\n            position: 'absolute',\n            top: `${position.top}px`,\n            left: `${position.left}px`,\n            maxWidth: '500px',\n          }}\n        >\n          <div>\n            <PureToolbar\n              keyPadCharacterRef={opts.keyPadCharacterRef}\n              setKeypadInteraction={opts.setKeypadInteraction}\n              autoFocus\n              noDecimal\n              hideInput\n              noLatexHandling\n              hideDoneButtonBackground\n              layoutForKeyPad={layoutForCharacters}\n              additionalKeys={configToUse.characters.reduce((arr, n) => {\n                arr = [\n                  ...arr,\n                  ...n.map((k) => ({\n                    name: get(k, 'name') || k,\n                    write: get(k, 'write') || k,\n                    label: get(k, 'label') || k,\n                    category: 'character',\n                    extraClass: 'character',\n                    extraProps: {\n                      ...(k.extraProps || {}),\n                      style: {\n                        ...(k.extraProps || {}).style,\n                        border: '1px solid #000',\n                      },\n                    },\n                    ...(configToUse.hasPreview\n                      ? {\n                          actions: { onMouseEnter: (ev) => renderPopOver(ev, k), onMouseLeave: closePopOver },\n                        }\n                      : {}),\n                  })),\n                ];\n\n                return arr;\n              }, [])}\n              keypadMode=\"language\"\n              onChange={handleChange}\n              onDone={onClose}\n            />\n          </div>\n        </div>,\n        document.body,\n      )}\n      {popover &&\n        ReactDOM.createPortal(\n          <CustomPopper onClose={closePopOver} anchorEl={popover.anchorEl}>\n            <div>{popover.el.label}</div>\n            <div style={{ fontSize: 20, lineHeight: '20px' }}>{popover.el.description}</div>\n            <div style={{ fontSize: 20, lineHeight: '20px' }}>{popover.el.unicode}</div>\n          </CustomPopper>,\n          document.body,\n        )}\n    </React.Fragment>\n  );\n}\n\nconst SuperscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,7h-2v1h3v1h-4V7c0-0.55,0.45-1,1-1h2V5h-3V4h3c0.55,0,1,0.45,1,1v1C23,6.55,22.55,7,22,7z M5.88,20h2.66l3.4-5.42h0.12 l3.4,5.42h2.66l-4.65-7.27L17.81,6h-2.68l-3.07,4.99h-0.12L8.85,6H6.19l4.32,6.73L5.88,20z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst SubscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,18h-2v1h3v1h-4v-2c0-0.55,0.45-1,1-1h2v-1h-3v-1h3c0.55,0,1,0.45,1,1v1C23,17.55,22.55,18,22,18z M5.88,18h2.66 l3.4-5.42h0.12l3.4,5.42h2.66l-4.65-7.27L17.81,4h-2.68l-3.07,4.99h-0.12L8.85,4H6.19l4.32,6.73L5.88,18z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst HeadingIcon = () => (\n  <svg\n    width=\"30\"\n    height=\"28\"\n    viewBox=\"0 0 30 28\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n    style={{ width: '20px', height: '18px' }}\n  >\n    <path\n      d=\"M27 4V24H29C29.5 24 30 24.5 30 25V27C30 27.5625 29.5 28 29 28H19C18.4375 28 18 27.5625 18 27V25C18 24.5 18.4375 24 19 24H21V16H9V24H11C11.5 24 12 24.5 12 25V27C12 27.5625 11.5 28 11 28H1C0.4375 28 0 27.5625 0 27V25C0 24.5 0.4375 24 1 24H3V4H1C0.4375 4 0 3.5625 0 3V1C0 0.5 0.4375 0 1 0H11C11.5 0 12 0.5 12 1V3C12 3.5625 11.5 4 11 4H9V12H21V4H19C18.4375 4 18 3.5625 18 3V1C18 0.5 18.4375 0 19 0H29C29.5 0 30 0.5 30 1V3C30 3.5625 29.5 4 29 4H27Z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst ExtendedTable = Table.extend({\n  renderHTML(props) {\n    const originalTable = this.parent(props);\n\n    originalTable[1].style = `${originalTable[1].style} width: 100%;\n    color: var(--pie-text, black);\n    table-layout: fixed;\n    border-collapse: collapse;\n    background-color: var(--pie-background, rgba(255, 255, 255))`;\n    originalTable[1].border = '1';\n\n    return originalTable;\n  },\n});\n\nconst styles = (theme) => ({\n  root: {\n    position: 'relative',\n    padding: '0px',\n    border: '1px solid #ccc',\n    borderRadius: '4px',\n    cursor: 'text',\n    '& [data-slate-editor=\"true\"]': {\n      wordBreak: 'break-word',\n      overflow: 'visible',\n      maxHeight: '500px',\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '5px',\n    },\n\n    '&:first-child': {\n      marginTop: 0,\n    },\n\n    '& ul, & ol': {\n      padding: '0 1rem',\n      margin: '1.25rem 1rem 1.25rem 0.4rem',\n    },\n\n    '& ul li p, & ol li p': {\n      marginTop: '0.25em',\n      marginBottom: '0.25em',\n    },\n\n    '& h1, & h2, & h3, & h4, & h5, & h6': {\n      lineHeight: 1.1,\n      marginTop: '2.5rem',\n      textWrap: 'pretty',\n    },\n\n    '& h1, & h2': {\n      marginTop: '3.5rem',\n      marginBottom: '1.5rem',\n    },\n\n    '& h1': {\n      fontSize: '1.4rem',\n    },\n\n    '& h2': {\n      fontSize: '1.2rem',\n    },\n\n    '& h3': {\n      fontSize: '1.1rem',\n    },\n\n    '& h4, & h5, & h6': {\n      fontSize: '1rem',\n    },\n\n    '& code': {\n      backgroundColor: 'var(--purple-light)',\n      borderRadius: '0.4rem',\n      color: 'var(--black)',\n      fontSize: '0.85rem',\n      padding: '0.25em 0.3em',\n    },\n\n    '& pre': {\n      background: 'var(--black)',\n      borderRadius: '0.5rem',\n      color: 'var(--white)',\n      fontFamily: \"'JetBrainsMono', monospace\",\n      margin: '1.5rem 0',\n      padding: '0.75rem 1rem',\n\n      '& code': {\n        background: 'none',\n        color: 'inherit',\n        fontSize: '0.8rem',\n        padding: 0,\n      },\n    },\n\n    '& blockquote': {\n      borderLeft: '3px solid var(--gray-3)',\n      margin: '1.5rem 0',\n      paddingLeft: '1rem',\n    },\n\n    '& hr': {\n      border: 'none',\n      borderTop: '1px solid var(--gray-2)',\n      margin: '2rem 0',\n    },\n  },\n  children: {\n    padding: '10px 16px',\n  },\n  editorHolder: {\n    position: 'relative',\n    padding: '0px',\n    // overflowY: 'auto',\n    overflow: 'visible',\n    color: color.text(),\n    backgroundColor: color.background(),\n    '&::before': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n      pointerEvents: 'none',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n    '&:focus': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: primary,\n        height: '2px',\n      },\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: theme.palette.common.black,\n        height: '2px',\n      },\n    },\n  },\n  disabledUnderline: {\n    '&::before': {\n      display: 'none',\n    },\n    '&::after': {\n      display: 'none',\n    },\n  },\n  disabledScrollbar: {\n    '&::-webkit-scrollbar': {\n      display: 'none',\n    },\n    scrollbarWidth: 'none',\n    '-ms-overflow-style': 'none',\n  },\n  readOnly: {\n    '&::before': {\n      background: 'transparent',\n      backgroundSize: '5px 1px',\n      backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n      backgroundRepeat: 'repeat-x',\n      backgroundPosition: 'left top',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0)',\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(0)',\n        backgroundColor: theme.palette.common.black,\n        height: '2px',\n      },\n    },\n  },\n  editorInFocus: {\n    '&::after': {\n      transform: 'scaleX(1)',\n      backgroundColor: primary,\n      height: '2px',\n    },\n    '&:hover': {\n      '&::after': {\n        backgroundColor: primary,\n      },\n    },\n  },\n  error: {\n    border: `2px solid ${theme.palette.error.main} !important`,\n  },\n  noBorder: {\n    border: 'none',\n  },\n  noPadding: {\n    padding: 0,\n  },\n  toolbarOnTop: {\n    marginTop: '45px',\n  },\n});\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => {},\n  onHandleAreaChange: () => {},\n};\n\nconst 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\nfunction TiptapContainer(props) {\n  const {\n    editor,\n    editorState,\n    classes,\n    children,\n    disableUnderline,\n    disableScrollbar,\n    toolbarOpts,\n    responseAreaProps,\n    autoFocus,\n    minWidth,\n    width,\n    maxWidth,\n    minHeight,\n    height,\n    maxHeight,\n  } = props;\n  const holderNames = classNames(classes.editorHolder, {\n    [classes.editorInFocus]: editorState.isFocused,\n    [classes.readOnly]: editorState.readOnly,\n    [classes.disabledUnderline]: disableUnderline,\n    [classes.disabledScrollbar]: disableScrollbar,\n  });\n\n  useEffect(() => {\n    if (editor && autoFocus) {\n      Promise.resolve().then(() => {\n        editor.commands.focus('end');\n      });\n    }\n  }, [editor, autoFocus]);\n\n  const sizeStyle = useMemo(() => {\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [minWidth, width, maxWidth, minHeight, height, maxHeight]);\n\n  return (\n    <div\n      className={classNames(\n        {\n          [classes.noBorder]: toolbarOpts && toolbarOpts.noBorder,\n          [classes.error]: toolbarOpts && toolbarOpts.error,\n        },\n        classes.root,\n        props.className,\n      )}\n      style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n    >\n      <div className={holderNames}>\n        <div\n          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts && toolbarOpts.noPadding,\n            },\n            classes.children,\n          )}\n        >\n          {children}\n        </div>\n      </div>\n\n      {/*{editorState.isFocused && <MenuBar editor={editor} />}*/}\n      {/*<Toolbar editor={editor} editorState={editorState} plugins={plugins} toolbarOpts={toolbarOpts} isFocused={editorState.isFocused} />*/}\n      {editor && (\n        <StyledMenuBar\n          editor={editor}\n          responseAreaProps={responseAreaProps}\n          toolbarOpts={toolbarOpts}\n          onChange={props.onChange}\n        />\n      )}\n    </div>\n  );\n}\n\nconst EditorContainer = withStyles(styles)(TiptapContainer);\n\nfunction MenuBar({ editor, classes, toolbarOpts: toolOpts, responseAreaProps, onChange }) {\n  const [showPicker, setShowPicker] = useState(false);\n  const toolbarOpts = toolOpts ?? {};\n  // Read the current editor's state, and re-render the component when it changes\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => {\n      const { selection } = ctx.editor?.state || {};\n\n      let currentNode;\n\n      if (selection instanceof NodeSelection) {\n        currentNode = selection.node; // the selected node\n      }\n\n      const customToolbarActive =\n        ctx.editor?.isActive('math') ||\n        ctx.editor?.isActive('explicit_constructed_response') ||\n        ctx.editor?.isActive('imageUploadNode');\n\n      return {\n        currentNode,\n        customToolbarActive,\n        isFocused: ctx.editor?.isFocused,\n        isBold: ctx.editor.isActive('bold') ?? false,\n        canBold:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleBold()\n            .run() ?? false,\n        isTable: ctx.editor.isActive('table') ?? false,\n        canTable:\n          ctx.editor\n            .can()\n            .chain()\n            .insertTable()\n            .run() ?? false,\n        isItalic: ctx.editor.isActive('italic') ?? false,\n        canItalic:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleItalic()\n            .run() ?? false,\n        isStrike: ctx.editor.isActive('strike') ?? false,\n        canStrike:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleStrike()\n            .run() ?? false,\n        isCode: ctx.editor.isActive('code') ?? false,\n        canCode:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleCode()\n            .run() ?? false,\n        canClearMarks:\n          ctx.editor\n            .can()\n            .chain()\n            .unsetAllMarks()\n            .run() ?? false,\n        isUnderline: ctx.editor.isActive('underline') ?? false,\n        isSubScript: ctx.editor.isActive('subscript') ?? false,\n        isSuperScript: ctx.editor.isActive('superscript') ?? false,\n        isParagraph: ctx.editor.isActive('paragraph') ?? false,\n        isHeading1: ctx.editor.isActive('heading', { level: 1 }) ?? false,\n        isHeading2: ctx.editor.isActive('heading', { level: 2 }) ?? false,\n        isHeading3: ctx.editor.isActive('heading', { level: 3 }) ?? false,\n        isHeading4: ctx.editor.isActive('heading', { level: 4 }) ?? false,\n        isHeading5: ctx.editor.isActive('heading', { level: 5 }) ?? false,\n        isHeading6: ctx.editor.isActive('heading', { level: 6 }) ?? false,\n        isBulletList: ctx.editor.isActive('bulletList') ?? false,\n        isOrderedList: ctx.editor.isActive('orderedList') ?? false,\n        isCodeBlock: ctx.editor.isActive('codeBlock') ?? false,\n        isBlockquote: ctx.editor.isActive('blockquote') ?? false,\n        canUndo:\n          ctx.editor\n            .can()\n            .chain()\n            .undo()\n            .run() ?? false,\n        canRedo:\n          ctx.editor\n            .can()\n            .chain()\n            .redo()\n            .run() ?? false,\n      };\n    },\n  });\n  const hasDoneButton = false;\n  const autoWidth = false;\n\n  const names = classNames(classes.toolbar, PIE_TOOLBAR__CLASS, {\n    [classes.toolbarWithNoDone]: !hasDoneButton,\n    [classes.toolbarTop]: toolbarOpts.position === 'top',\n    [classes.toolbarRight]: toolbarOpts.alignment === 'right',\n    [classes.focused]: toolbarOpts.alwaysVisible || (editorState.isFocused && !editor._toolbarOpened),\n    [classes.autoWidth]: autoWidth,\n    [classes.fullWidth]: !autoWidth,\n    [classes.hidden]: toolbarOpts.isHidden === true,\n  });\n  const customStyles = toolbarOpts.minWidth !== undefined ? { minWidth: toolbarOpts.minWidth } : {};\n  const handleMouseDown = (e) => {\n    e.preventDefault();\n  };\n\n  return (\n    <div className={names} style={{ ...customStyles }} onMouseDown={handleMouseDown}>\n      {!editorState.customToolbarActive && (\n        <div className={classes.defaultToolbar} tabIndex=\"1\">\n          <div className={classes.buttonsContainer}>\n            <button\n              onClick={(e) => {\n                e.preventDefault();\n                editor\n                  .chain()\n                  .focus()\n                  .insertTable()\n                  .run();\n              }}\n              disabled={!editorState.canTable}\n              className={classNames(classes.button, { [classes.active]: editorState.isTable })}\n            >\n              <GridOn />\n            </button>\n            <button\n              onClick={(e) => {\n                e.preventDefault();\n                editor\n                  .chain()\n                  .focus()\n                  .toggleBold()\n                  .run();\n              }}\n              disabled={!editorState.canBold}\n              className={classNames(classes.button, { [classes.active]: editorState.isBold })}\n            >\n              <Bold />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleItalic()\n                  .run()\n              }\n              disabled={!editorState.canItalic}\n              active={editorState.isItalic}\n              className={classNames(classes.button, { [classes.active]: editorState.isItalic })}\n            >\n              <Italic />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleStrike()\n                  .run()\n              }\n              disabled={!editorState.canStrike}\n              active={editorState.isStrike}\n              className={classNames(classes.button, { [classes.active]: editorState.isStrike })}\n            >\n              <Strikethrough />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleCode()\n                  .run()\n              }\n              disabled={!editorState.canCode}\n              active={editorState.isCode}\n              className={classNames(classes.button, { [classes.active]: editorState.isCode })}\n            >\n              <Code />\n            </button>\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .unsetAllMarks()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*>*/}\n            {/*  Clear marks*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .clearNodes()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*>*/}\n            {/*  Clear nodes*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .setParagraph()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isParagraph ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  Paragraph*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 1 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isHeading1 ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  H1*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 2 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isHeading2 ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  H2*/}\n            {/*</button>*/}\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleUnderline()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isUnderline })}\n            >\n              <Underline />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleSubscript()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isSubScript })}\n            >\n              <SubscriptIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleSuperscript()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isSuperScript })}\n            >\n              <SuperscriptIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .setImageUploadNode()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isSuperScript })}\n            >\n              <ImageIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .insertMedia({\n                    tag: 'video',\n                  })\n                  .run()\n              }\n              className={classNames(classes.button)}\n            >\n              <TheatersIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .insertMedia({\n                    tag: 'audio',\n                  })\n                  .run()\n              }\n              className={classNames(classes.button)}\n            >\n              <VolumeUpIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor.commands.openCSSClassDialog()\n              }\n              className={classNames(classes.button)}\n            >\n              <CSSIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleHeading({ level: 3 })\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isHeading3 })}\n            >\n              <HeadingIcon />\n            </button>\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 3 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={classNames(classes.button, { [classes.active]: editorState.isHeading3 })}*/}\n            {/*>*/}\n            {/*  <Image />*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 4 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isHeading4 ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  H4*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 5 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isHeading5 ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  H5*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleHeading({ level: 6 })*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={editorState.isHeading6 ? classes.isActive : ''}*/}\n            {/*>*/}\n            {/*  H6*/}\n            {/*</button>*/}\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .insertMath('')\n                  .run()\n              }\n              className={classes.button}\n            >\n              <Functions />\n            </button>\n            <button onClick={() => setShowPicker(spanishConfig)} className={classes.button}>\n              <CharacterIcon letter=\"ñ\" />\n            </button>\n            <button onClick={() => setShowPicker(specialConfig)} className={classes.button}>\n              <CharacterIcon letter=\"€\" />\n            </button>\n            <button onClick={() => {}} className={classes.button}>\n              <TextAlignIcon editor={editor} />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleBulletList()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isBulletList })}\n            >\n              <BulletedListIcon />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .toggleOrderedList()\n                  .run()\n              }\n              className={classNames(classes.button, { [classes.active]: editorState.isOrderedList })}\n            >\n              <NumberedListIcon />\n            </button>\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleCodeBlock()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={classNames(classes.button, { [classes.active]: editorState.isCodeBlock })}*/}\n            {/*>*/}\n            {/*  Code block*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .toggleBlockquote()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*  className={classNames(classes.button, { [classes.active]: editorState.isBlockquote })}*/}\n            {/*>*/}\n            {/*  Blockquote*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .setHorizontalRule()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*>*/}\n            {/*  Horizontal rule*/}\n            {/*</button>*/}\n            {/*<button*/}\n            {/*  onClick={() =>*/}\n            {/*    editor*/}\n            {/*      .chain()*/}\n            {/*      .focus()*/}\n            {/*      .setHardBreak()*/}\n            {/*      .run()*/}\n            {/*  }*/}\n            {/*>*/}\n            {/*  Hard break*/}\n            {/*</button>*/}\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .undo()\n                  .run()\n              }\n              disabled={!editorState.canUndo}\n              className={classes.button}\n            >\n              <Undo />\n            </button>\n            <button\n              onClick={() =>\n                editor\n                  .chain()\n                  .focus()\n                  .redo()\n                  .run()\n              }\n              disabled={!editorState.canRedo}\n              className={classes.button}\n            >\n              <Redo />\n            </button>\n          </div>\n          <button\n            onClick={() => {\n              editor\n                .chain()\n                .focus()\n                .insertResponseArea(responseAreaProps.type)\n                .run();\n            }}\n            className={classes.button}\n          >\n            <ToolbarIcon />\n          </button>\n\n          <DoneButton\n            onClick={() => {\n              onChange?.(editor.getHTML());\n              editor.commands.blur();\n            }}\n          />\n        </div>\n      )}\n      {showPicker && (\n        <CharacterPicker\n          editor={editor}\n          opts={{\n            ...showPicker,\n            renderPopOver: (ev, ch) => console.log('Show popover', ch),\n            closePopOver: () => console.log('Close popover'),\n          }}\n          onClose={() => setShowPicker(false)}\n        />\n      )}\n    </div>\n  );\n}\n\nconst style = (theme) => ({\n  defaultToolbar: {\n    display: 'flex',\n    width: '100%',\n    justifyContent: 'space-between',\n  },\n  buttonsContainer: {\n    alignItems: 'center',\n    display: 'flex',\n    width: '100%',\n  },\n  button: {\n    color: 'grey',\n    display: 'inline-flex',\n    padding: '2px',\n    background: 'none',\n    border: 'none',\n    cursor: 'pointer',\n    '&:hover': {\n      color: 'black',\n    },\n    '&:focus': {\n      outline: `2px solid ${theme.palette.grey[700]}`,\n    },\n  },\n  active: {\n    color: 'black',\n  },\n  disabled: {\n    opacity: 0.7,\n    cursor: 'not-allowed',\n    '& :hover': {\n      color: 'grey',\n    },\n  },\n  isActive: {\n    background: 'var(--purple)',\n    color: 'var(--white)',\n  },\n  toolbar: {\n    position: 'absolute',\n    zIndex: 20,\n    cursor: 'pointer',\n    justifyContent: 'space-between',\n    background: 'var(--editable-html-toolbar-bg, #efefef)',\n    minWidth: '280px',\n    margin: '5px 0 0 0',\n    padding: '2px',\n    boxShadow:\n      '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',\n    boxSizing: 'border-box',\n    display: 'flex',\n    opacity: 0,\n    pointerEvents: 'none',\n  },\n  toolbarWithNoDone: {\n    minWidth: '265px',\n  },\n  toolbarTop: {\n    top: '-45px',\n  },\n  toolbarRight: {\n    right: 0,\n  },\n  fullWidth: {\n    width: '100%',\n  },\n  hidden: {\n    visibility: 'hidden',\n  },\n  autoWidth: {\n    width: 'auto',\n  },\n  focused: {\n    opacity: 1,\n    pointerEvents: 'auto',\n  },\n  iconRoot: {\n    width: '28px',\n    height: '28px',\n    padding: '4px',\n    verticalAlign: 'top',\n  },\n  label: {\n    color: 'var(--editable-html-toolbar-check, #00bb00)',\n  },\n  shared: {\n    display: 'flex',\n  },\n});\nconst StyledMenuBar = withStyles(style, { index: 1000 })(MenuBar);\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nexport const EditableHtml = (props) => {\n  const [pendingImages, setPendingImages] = useState([]);\n  const [scheduled, setScheduled] = useState(false);\n  const { classes, toolbarOpts } = props;\n  const toolbarOptsToUse = {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n  };\n  const extensions = [\n    TextStyleKit,\n    StarterKit,\n    ExtendedTable,\n    TableRow,\n    TableHeader,\n    TableCell,\n    ResponseAreaExtension,\n    ExplicitConstructedResponseNode.configure(props.responseAreaProps),\n    DragInTheBlankNode.configure(props.responseAreaProps),\n    InlineDropdownNode.configure(props.responseAreaProps),\n    MathNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n    }),\n    SubScript,\n    SuperScript,\n    TextAlign.configure({\n      types: ['heading', 'paragraph'],\n      alignments: ['left', 'right', 'center'],\n    }),\n    Image,\n    ImageUploadNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n      imageHandling: {\n        disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((node, done) => {\n            const { src } = node.attrs;\n\n            props.imageSupport.delete(src, (e) => {\n              const newPendingImages = pendingImages.filter((img) => img.key !== node.key);\n              const newState = {\n                pendingImages: newPendingImages,\n                scheduled: scheduled && newPendingImages.length === 0 ? false : scheduled,\n              };\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              done();\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          ((addedImage, getHandler) => {\n            const onFinish = (result) => {\n              let cb;\n\n              if (scheduled && result) {\n                // finish editing only on success\n                cb = props.onChange;\n              }\n\n              const newPendingImages = 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              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              cb?.(editor.getHTML());\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);\n              props.imageSupport.add(handler);\n            };\n\n            setPendingImages([...pendingImages, addedImage]);\n            callback();\n          }),\n        maxImageWidth: props.maxImageWidth,\n        maxImageHeight: props.maxImageHeight,\n      },\n      limit: 3,\n    }),\n    Media.configure({\n      uploadSoundSupport: props.uploadSoundSupport,\n    }),\n    CSSMark.configure({\n      extraCSSRules: props.extraCSSRules\n    }),\n  ];\n  const editor = useEditor({\n    extensions,\n    immediatelyRender: false,\n    content: props.markup,\n    onUpdate: ({ editor, transaction }) => transaction.isDone && props.onChange?.(editor.getHTML()),\n    onBlur: ({ editor }) => {\n      if (toolbarOptsToUse.doneOn === 'blur') {\n        props.onChange?.(editor.getHTML());\n      } else {\n        props.onDone?.(editor.getHTML());\n      }\n    },\n  });\n\n  useEffect(() => {\n    if (!editor) {\n      return;\n    }\n\n    if (props.markup !== editor.getHTML()) {\n      editor.commands.setContent(props.markup, false); // false = don’t emit update\n    }\n  }, [props.markup, editor]);\n\n  useEffect(() => {\n    // Define your variables in a JS object\n    const cssVariables = {\n      '--white': '#fff',\n      '--black': '#2e2b29',\n      '--black-contrast': '#110f0e',\n      '--gray-1': 'rgba(61, 37, 20, .05)',\n      '--gray-2': 'rgba(61, 37, 20, .08)',\n      '--gray-3': 'rgba(61, 37, 20, .12)',\n      '--gray-4': 'rgba(53, 38, 28, .3)',\n      '--gray-5': 'rgba(28, 25, 23, .6)',\n      '--green': '#22c55e',\n      '--purple': '#6a00f5',\n      '--purple-contrast': '#5800cc',\n      '--purple-light': 'rgba(88, 5, 255, .05)',\n      '--yellow-contrast': '#facc15',\n      '--yellow': 'rgba(250, 204, 21, .4)',\n      '--yellow-light': '#fffae5',\n      '--red': '#ff5c33',\n      '--red-light': '#ffebe5',\n      '--shadow': `0px 12px 33px 0px rgba(0, 0, 0, .06),\n               0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)`,\n    };\n\n    Object.entries(cssVariables).forEach(([key, value]) => {\n      document.documentElement.style.setProperty(key, value);\n    });\n  }, []);\n\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => {\n      return {\n        isFocused: ctx.editor?.isFocused,\n      };\n    },\n  });\n\n  const 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  const sizeStyle = useMemo(() => {\n    const { minWidth, width, maxWidth, minHeight, height, maxHeight } = props;\n\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [props]);\n\n  return (\n    <EditorContainer {...{ ...props, toolbarOpts: toolbarOptsToUse }} editorState={editorState} editor={editor}>\n      {editor && (\n        <EditorContent\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight,\n          }}\n          className={classes.root}\n          editor={editor}\n        />\n      )}\n    </EditorContainer>\n  );\n};\n\nconst StyledEditor = withStyles({\n  root: {\n    outline: 'none !important',\n    '& .ProseMirror': {\n      outline: 'none !important',\n      position: 'initial',\n    },\n  },\n})(EditableHtml);\n\nexport default StyledEditor;\n"]}
|
|
1497
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.jsx"],"names":["CharacterIcon","letter","fontSize","lineHeight","propTypes","PropTypes","string","CharacterPicker","editor","opts","onClose","characters","length","containerRef","top","left","position","setPosition","popover","setPopover","configToUse","language","spanishConfig","specialConfig","layoutForCharacters","reduce","obj","arr","columns","rows","closePopOver","bodyRect","document","body","getBoundingClientRect","from","state","selection","start","view","coordsAtPos","Math","abs","handleClickOutside","e","current","contains","target","dom","addEventListener","removeEventListener","renderPopOver","event","el","anchorEl","currentTarget","handleChange","val","chain","focus","insertContent","run","ReactDOM","createPortal","maxWidth","keyPadCharacterRef","setKeypadInteraction","n","map","k","name","write","label","category","extraClass","extraProps","style","border","hasPreview","actions","onMouseEnter","ev","onMouseLeave","description","unicode","SuperscriptIcon","SubscriptIcon","HeadingIcon","width","height","ExtendedTable","Table","extend","addAttributes","renderHTML","props","originalTable","parent","HTMLAttributes","previousStyle","match","styles","theme","root","padding","borderRadius","cursor","wordBreak","overflow","maxHeight","marginTop","margin","marginBottom","textWrap","backgroundColor","color","background","fontFamily","borderLeft","paddingLeft","borderTop","tableLayout","borderCollapse","text","textAlign","children","editorHolder","right","bottom","content","transition","pointerEvents","transform","primary","palette","common","black","disabledUnderline","display","disabledScrollbar","scrollbarWidth","readOnly","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","editorInFocus","error","main","noBorder","noPadding","toolbarOnTop","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","valueToSize","v","calcRegex","endsWith","undefined","value","parseInt","isNaN","TiptapContainer","editorState","classes","disableUnderline","disableScrollbar","activePlugins","toolbarOpts","responseAreaProps","autoFocus","minWidth","minHeight","holderNames","isFocused","Promise","resolve","then","commands","sizeStyle","className","onChange","EditorContainer","MenuBar","toolOpts","showPicker","setShowPicker","selector","ctx","currentNode","NodeSelection","node","hideDefaultToolbar","isActive","isBold","canBold","can","toggleBold","isTable","tableHasBorder","getAttributes","canTable","insertTable","isItalic","canItalic","toggleItalic","isStrike","canStrike","toggleStrike","isCode","canCode","toggleCode","canClearMarks","unsetAllMarks","isUnderline","isSubScript","isSuperScript","isParagraph","isHeading1","level","isHeading2","isHeading3","isHeading4","isHeading5","isHeading6","isBulletList","isOrderedList","isCodeBlock","isBlockquote","canUndo","undo","canRedo","redo","hasDoneButton","autoWidth","names","toolbar","PIE_TOOLBAR__CLASS","toolbarWithNoDone","toolbarTop","toolbarRight","alignment","focused","alwaysVisible","_toolbarOpened","fullWidth","hidden","isHidden","customStyles","handleMouseDown","preventDefault","toolbarButtons","icon","onClick","cols","withHeaderRow","includes","isDisabled","addRowAfter","deleteRow","addColumnAfter","deleteColumn","deleteTable","tableAttrs","update","updateAttributes","toggleUnderline","toggleSubscript","toggleSuperscript","setImageUploadNode","insertMedia","tag","openCSSClassDialog","toggleHeading","insertMath","filter","p","toggleBulletList","toggleOrderedList","defaultToolbar","buttonsContainer","btn","index","disabled","active","button","insertResponseArea","type","getHTML","blur","ch","console","log","justifyContent","alignItems","outline","grey","opacity","zIndex","boxShadow","boxSizing","visibility","iconRoot","verticalAlign","shared","StyledMenuBar","defaultToolbarOpts","showDone","doneOn","EditableHtml","pendingImages","setPendingImages","scheduled","setScheduled","toolbarOptsToUse","activePluginsToUse","pluginProps","customPlugins","math","html","extraCSSRules","image","table","responseArea","languageCharacters","languageCharactersProps","media","extensions","TextStyleKit","StarterKit","TableRow","TableHeader","TableCell","ResponseAreaExtension","ExplicitConstructedResponseNode","configure","DragInTheBlankNode","InlineDropdownNode","MathNode","SubScript","SuperScript","TextAlign","types","alignments","Image","ImageUploadNode","imageHandling","disableImageAlignmentButtons","onDone","onDelete","imageSupport","done","src","attrs","newPendingImages","img","key","newState","insertImageRequested","addedImage","getHandler","onFinish","result","cb","callback","handler","add","maxImageWidth","maxImageHeight","limit","Media","uploadSoundSupport","CSSMark","immediatelyRender","markup","onUpdate","transaction","isDone","onBlur","setContent","cssVariables","Object","entries","forEach","documentElement","setProperty","StyledEditor"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\nimport { createRoot } from 'react-dom/client';\nimport { NodeSelection } from 'prosemirror-state';\nimport { TextStyleKit } from '@tiptap/extension-text-style';\nimport { EditorContent, useEditor, useEditorState } from '@tiptap/react';\nimport StarterKit from '@tiptap/starter-kit';\nimport { Table } from '@tiptap/extension-table';\nimport { TableRow } from '@tiptap/extension-table-row';\nimport { TableCell } from '@tiptap/extension-table-cell';\nimport { TableHeader } from '@tiptap/extension-table-header';\nimport SuperScript from '@tiptap/extension-superscript';\nimport SubScript from '@tiptap/extension-subscript';\nimport TextAlign from '@tiptap/extension-text-align';\nimport Image from '@tiptap/extension-image';\n\nimport { withStyles } from '@material-ui/core/styles';\nimport {\n  ExplicitConstructedResponseNode,\n  DragInTheBlankNode,\n  InlineDropdownNode,\n  ResponseAreaExtension,\n} from './extensions/responseArea';\nimport { MathNode } from './extensions/math';\nimport classNames from 'classnames';\nimport { color } from '@pie-lib/render-ui';\nimport { primary } from './theme';\nimport { PIE_TOOLBAR__CLASS } from './constants';\nimport { DoneButton } from './plugins/toolbar/done-button';\nimport { buildPlugins, DEFAULT_PLUGINS } from \"./plugins/index\";\nimport Bold from '@material-ui/icons/FormatBold';\nimport Italic from '@material-ui/icons/FormatItalic';\nimport Strikethrough from '@material-ui/icons/FormatStrikethrough';\nimport Code from '@material-ui/icons/Code';\nimport GridOn from '@material-ui/icons/GridOn';\nimport BulletedListIcon from '@material-ui/icons/FormatListBulleted';\nimport NumberedListIcon from '@material-ui/icons/FormatListNumbered';\nimport Underline from '@material-ui/icons/FormatUnderlined';\nimport Functions from '@material-ui/icons/Functions';\nimport ImageIcon from '@material-ui/icons/Image';\nimport { ToolbarIcon } from './plugins/respArea/icons';\nimport Redo from '@material-ui/icons/Redo';\nimport Undo from '@material-ui/icons/Undo';\nimport TheatersIcon from '@material-ui/icons/Theaters';\nimport VolumeUpIcon from '@material-ui/icons/VolumeUp';\nimport { characterIcons, spanishConfig, specialConfig } from './plugins/characters/utils';\nimport PropTypes from 'prop-types';\nimport { MathToolbar, PureToolbar } from '@pie-lib/math-toolbar';\nimport get from 'lodash/get';\nimport CustomPopper from './plugins/characters/custom-popper';\nimport TextAlignIcon from './plugins/textAlign/icons';\nimport CSSIcon from './plugins/css/icons';\n\nimport { ImageUploadNode } from './extensions/image';\nimport { Media } from './extensions/media';\nimport { CSSMark } from './extensions/css';\nimport { AddColumn, AddRow, RemoveColumn, RemoveRow, RemoveTable } from './plugins/table/icons';\nimport BorderAll from '@material-ui/icons/BorderAll';\n\nconst CharacterIcon = ({ letter }) => (\n  <div\n    style={{\n      fontSize: '24px',\n      lineHeight: '24px',\n    }}\n  >\n    {letter}\n  </div>\n);\n\nCharacterIcon.propTypes = {\n  letter: PropTypes.string,\n};\n\nexport function CharacterPicker({ editor, opts, onClose }) {\n  if (!opts?.characters?.length) {\n    return null;\n  }\n\n  const containerRef = useRef(null);\n  const [position, setPosition] = useState({ top: 0, left: 0 });\n  const [popover, setPopover] = useState(null);\n\n  let configToUse;\n\n  switch (true) {\n    case opts.language === 'spanish':\n      configToUse = spanishConfig;\n      break;\n    case opts.language === 'special':\n      configToUse = specialConfig;\n      break;\n    default:\n      configToUse = opts;\n  }\n\n  const layoutForCharacters = configToUse.characters.reduce(\n    (obj, arr) => {\n      if (arr.length >= obj.columns) {\n        obj.columns = arr.length;\n      }\n\n      return obj;\n    },\n    { rows: configToUse.characters.length, columns: 0 },\n  );\n\n  useEffect(() => {\n    return () => {\n      closePopOver();\n    };\n  }, []);\n\n  useEffect(() => {\n    if (!editor) return;\n\n    // Calculate position relative to selection\n    const bodyRect = document.body.getBoundingClientRect();\n    const { from } = editor.state.selection;\n    const start = editor.view.coordsAtPos(from);\n    setPosition({\n      top: start.top + Math.abs(bodyRect.top) + 40, // shift above\n      left: start.left,\n    });\n\n    const handleClickOutside = (e) => {\n      if (containerRef.current && !containerRef.current.contains(e.target) && !editor.view.dom.contains(e.target)) {\n        onClose();\n      }\n    };\n\n    document.addEventListener('mousedown', handleClickOutside);\n    return () => document.removeEventListener('mousedown', handleClickOutside);\n  }, [editor]);\n\n  const renderPopOver = (event, el) => setPopover({ anchorEl: event.currentTarget, el });\n  const closePopOver = () => setPopover(null);\n\n  const handleChange = (val) => {\n    if (typeof val === 'string') {\n      editor\n        .chain()\n        .focus()\n        .insertContent(val)\n        .run();\n    }\n  };\n\n  return (\n    <React.Fragment>\n      {ReactDOM.createPortal(\n        <div\n          ref={containerRef}\n          className=\"insert-character-dialog\"\n          style={{\n            position: 'absolute',\n            top: `${position.top}px`,\n            left: `${position.left}px`,\n            maxWidth: '500px',\n          }}\n        >\n          <div>\n            <PureToolbar\n              keyPadCharacterRef={opts.keyPadCharacterRef}\n              setKeypadInteraction={opts.setKeypadInteraction}\n              autoFocus\n              noDecimal\n              hideInput\n              noLatexHandling\n              hideDoneButtonBackground\n              layoutForKeyPad={layoutForCharacters}\n              additionalKeys={configToUse.characters.reduce((arr, n) => {\n                arr = [\n                  ...arr,\n                  ...n.map((k) => ({\n                    name: get(k, 'name') || k,\n                    write: get(k, 'write') || k,\n                    label: get(k, 'label') || k,\n                    category: 'character',\n                    extraClass: 'character',\n                    extraProps: {\n                      ...(k.extraProps || {}),\n                      style: {\n                        ...(k.extraProps || {}).style,\n                        border: '1px solid #000',\n                      },\n                    },\n                    ...(configToUse.hasPreview\n                      ? {\n                          actions: { onMouseEnter: (ev) => renderPopOver(ev, k), onMouseLeave: closePopOver },\n                        }\n                      : {}),\n                  })),\n                ];\n\n                return arr;\n              }, [])}\n              keypadMode=\"language\"\n              onChange={handleChange}\n              onDone={onClose}\n            />\n          </div>\n        </div>,\n        document.body,\n      )}\n      {popover &&\n        ReactDOM.createPortal(\n          <CustomPopper onClose={closePopOver} anchorEl={popover.anchorEl}>\n            <div>{popover.el.label}</div>\n            <div style={{ fontSize: 20, lineHeight: '20px' }}>{popover.el.description}</div>\n            <div style={{ fontSize: 20, lineHeight: '20px' }}>{popover.el.unicode}</div>\n          </CustomPopper>,\n          document.body,\n        )}\n    </React.Fragment>\n  );\n}\n\nconst SuperscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,7h-2v1h3v1h-4V7c0-0.55,0.45-1,1-1h2V5h-3V4h3c0.55,0,1,0.45,1,1v1C23,6.55,22.55,7,22,7z M5.88,20h2.66l3.4-5.42h0.12 l3.4,5.42h2.66l-4.65-7.27L17.81,6h-2.68l-3.07,4.99h-0.12L8.85,6H6.19l4.32,6.73L5.88,20z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst SubscriptIcon = () => (\n  <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"none\">\n    <path\n      d=\"M22,18h-2v1h3v1h-4v-2c0-0.55,0.45-1,1-1h2v-1h-3v-1h3c0.55,0,1,0.45,1,1v1C23,17.55,22.55,18,22,18z M5.88,18h2.66 l3.4-5.42h0.12l3.4,5.42h2.66l-4.65-7.27L17.81,4h-2.68l-3.07,4.99h-0.12L8.85,4H6.19l4.32,6.73L5.88,18z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst HeadingIcon = () => (\n  <svg\n    width=\"30\"\n    height=\"28\"\n    viewBox=\"0 0 30 28\"\n    fill=\"none\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n    style={{ width: '20px', height: '18px' }}\n  >\n    <path\n      d=\"M27 4V24H29C29.5 24 30 24.5 30 25V27C30 27.5625 29.5 28 29 28H19C18.4375 28 18 27.5625 18 27V25C18 24.5 18.4375 24 19 24H21V16H9V24H11C11.5 24 12 24.5 12 25V27C12 27.5625 11.5 28 11 28H1C0.4375 28 0 27.5625 0 27V25C0 24.5 0.4375 24 1 24H3V4H1C0.4375 4 0 3.5625 0 3V1C0 0.5 0.4375 0 1 0H11C11.5 0 12 0.5 12 1V3C12 3.5625 11.5 4 11 4H9V12H21V4H19C18.4375 4 18 3.5625 18 3V1C18 0.5 18.4375 0 19 0H29C29.5 0 30 0.5 30 1V3C30 3.5625 29.5 4 29 4H27Z\"\n      fill=\"currentColor\"\n    />\n  </svg>\n);\n\nconst ExtendedTable = Table.extend({\n  addAttributes() {\n    return {\n      border: { default: '1' },\n    };\n  },\n  renderHTML(props) {\n    const originalTable = this.parent(props);\n    const { border } = props.HTMLAttributes;\n\n    const previousStyle = `${originalTable[1].style}${originalTable[1].style.match(/.*; */) ? '' : ';'}`;\n\n    originalTable[1].style = `${previousStyle}\n    width: 100%;\n    color: var(--pie-text, black);\n    table-layout: fixed;\n    border-collapse: collapse;\n    background-color: var(--pie-background, rgba(255, 255, 255))`;\n    originalTable[1].border = border ? border : '1';\n\n    return originalTable;\n  },\n});\n\nconst styles = (theme) => ({\n  root: {\n    position: 'relative',\n    padding: '0px',\n    border: '1px solid #ccc',\n    borderRadius: '4px',\n    cursor: 'text',\n    '& [data-slate-editor=\"true\"]': {\n      wordBreak: 'break-word',\n      overflow: 'visible',\n      maxHeight: '500px',\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '5px',\n    },\n\n    '&:first-child': {\n      marginTop: 0,\n    },\n\n    '& ul, & ol': {\n      padding: '0 1rem',\n      margin: '1.25rem 1rem 1.25rem 0.4rem',\n    },\n\n    '& ul li p, & ol li p': {\n      marginTop: '0.25em',\n      marginBottom: '0.25em',\n    },\n\n    '& h1, & h2, & h3, & h4, & h5, & h6': {\n      lineHeight: 1.1,\n      marginTop: '2.5rem',\n      textWrap: 'pretty',\n    },\n\n    '& h1, & h2': {\n      marginTop: '3.5rem',\n      marginBottom: '1.5rem',\n    },\n\n    '& h1': {\n      fontSize: '1.4rem',\n    },\n\n    '& h2': {\n      fontSize: '1.2rem',\n    },\n\n    '& h3': {\n      fontSize: '1.1rem',\n    },\n\n    '& h4, & h5, & h6': {\n      fontSize: '1rem',\n    },\n\n    '& code': {\n      backgroundColor: 'var(--purple-light)',\n      borderRadius: '0.4rem',\n      color: 'var(--black)',\n      fontSize: '0.85rem',\n      padding: '0.25em 0.3em',\n    },\n\n    '& pre': {\n      background: 'var(--black)',\n      borderRadius: '0.5rem',\n      color: 'var(--white)',\n      fontFamily: \"'JetBrainsMono', monospace\",\n      margin: '1.5rem 0',\n      padding: '0.75rem 1rem',\n\n      '& code': {\n        background: 'none',\n        color: 'inherit',\n        fontSize: '0.8rem',\n        padding: 0,\n      },\n    },\n\n    '& blockquote': {\n      borderLeft: '3px solid var(--gray-3)',\n      margin: '1.5rem 0',\n      paddingLeft: '1rem',\n    },\n\n    '& hr': {\n      border: 'none',\n      borderTop: '1px solid var(--gray-2)',\n      margin: '2rem 0',\n    },\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    },\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  children: {\n    padding: '10px 16px',\n  },\n  editorHolder: {\n    position: 'relative',\n    padding: '0px',\n    // overflowY: 'auto',\n    overflow: 'visible',\n    color: color.text(),\n    backgroundColor: color.background(),\n    '&::before': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n      pointerEvents: 'none',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n    '&:focus': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: primary,\n        height: '2px',\n      },\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: theme.palette.common.black,\n        height: '2px',\n      },\n    },\n  },\n  disabledUnderline: {\n    '&::before': {\n      display: 'none',\n    },\n    '&::after': {\n      display: 'none',\n    },\n  },\n  disabledScrollbar: {\n    '&::-webkit-scrollbar': {\n      display: 'none',\n    },\n    scrollbarWidth: 'none',\n    '-ms-overflow-style': 'none',\n  },\n  readOnly: {\n    '&::before': {\n      background: 'transparent',\n      backgroundSize: '5px 1px',\n      backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n      backgroundRepeat: 'repeat-x',\n      backgroundPosition: 'left top',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0)',\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(0)',\n        backgroundColor: theme.palette.common.black,\n        height: '2px',\n      },\n    },\n  },\n  editorInFocus: {\n    '&::after': {\n      transform: 'scaleX(1)',\n      backgroundColor: primary,\n      height: '2px',\n    },\n    '&:hover': {\n      '&::after': {\n        backgroundColor: primary,\n      },\n    },\n  },\n  error: {\n    border: `2px solid ${theme.palette.error.main} !important`,\n  },\n  noBorder: {\n    border: 'none',\n  },\n  noPadding: {\n    padding: 0,\n  },\n  toolbarOnTop: {\n    marginTop: '45px',\n  },\n});\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => {},\n  onHandleAreaChange: () => {},\n};\n\nconst 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\nfunction TiptapContainer(props) {\n  const {\n    editor,\n    editorState,\n    classes,\n    children,\n    disableUnderline,\n    disableScrollbar,\n    activePlugins,\n    toolbarOpts,\n    responseAreaProps,\n    autoFocus,\n    minWidth,\n    width,\n    maxWidth,\n    minHeight,\n    height,\n    maxHeight,\n  } = props;\n  const holderNames = classNames(classes.editorHolder, {\n    [classes.editorInFocus]: editorState.isFocused,\n    [classes.readOnly]: editorState.readOnly,\n    [classes.disabledUnderline]: disableUnderline,\n    [classes.disabledScrollbar]: disableScrollbar,\n  });\n\n  useEffect(() => {\n    if (editor && autoFocus) {\n      Promise.resolve().then(() => {\n        editor.commands.focus('end');\n      });\n    }\n  }, [editor, autoFocus]);\n\n  const sizeStyle = useMemo(() => {\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [minWidth, width, maxWidth, minHeight, height, maxHeight]);\n\n  return (\n    <div\n      className={classNames(\n        {\n          [classes.noBorder]: toolbarOpts && toolbarOpts.noBorder,\n          [classes.error]: toolbarOpts && toolbarOpts.error,\n        },\n        classes.root,\n        props.className,\n      )}\n      style={{ width: sizeStyle.width, minWidth: sizeStyle.minWidth, maxWidth: sizeStyle.maxWidth }}\n    >\n      <div className={holderNames}>\n        <div\n          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts && toolbarOpts.noPadding,\n            },\n            classes.children,\n          )}\n        >\n          {children}\n        </div>\n      </div>\n\n      {/*{editorState.isFocused && <MenuBar editor={editor} />}*/}\n      {/*<Toolbar editor={editor} editorState={editorState} plugins={plugins} toolbarOpts={toolbarOpts} isFocused={editorState.isFocused} />*/}\n      {editor && (\n        <StyledMenuBar\n          editor={editor}\n          responseAreaProps={responseAreaProps}\n          toolbarOpts={toolbarOpts}\n          activePlugins={activePlugins}\n          onChange={props.onChange}\n        />\n      )}\n    </div>\n  );\n}\n\nconst EditorContainer = withStyles(styles)(TiptapContainer);\n\nfunction MenuBar({ editor, classes, activePlugins, toolbarOpts: toolOpts, responseAreaProps, onChange }) {\n  const [showPicker, setShowPicker] = useState(false);\n  const toolbarOpts = toolOpts ?? {};\n  // Read the current editor's state, and re-render the component when it changes\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => {\n      const { selection } = ctx.editor?.state || {};\n\n      let currentNode;\n\n      if (selection instanceof NodeSelection) {\n        currentNode = selection.node; // the selected node\n      }\n\n      const hideDefaultToolbar =\n        ctx.editor?.isActive('math') ||\n        ctx.editor?.isActive('explicit_constructed_response') ||\n        ctx.editor?.isActive('imageUploadNode');\n\n      return {\n        currentNode,\n        hideDefaultToolbar,\n        isFocused: ctx.editor?.isFocused,\n        isBold: ctx.editor.isActive('bold') ?? false,\n        canBold:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleBold()\n            .run() ?? false,\n        isTable: ctx.editor.isActive('table') ?? false,\n        tableHasBorder: ctx.editor.getAttributes('table')?.border === '1' ?? false,\n        canTable:\n          ctx.editor\n            .can()\n            .chain()\n            .insertTable()\n            .run() ?? false,\n        isItalic: ctx.editor.isActive('italic') ?? false,\n        canItalic:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleItalic()\n            .run() ?? false,\n        isStrike: ctx.editor.isActive('strike') ?? false,\n        canStrike:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleStrike()\n            .run() ?? false,\n        isCode: ctx.editor.isActive('code') ?? false,\n        canCode:\n          ctx.editor\n            .can()\n            .chain()\n            .toggleCode()\n            .run() ?? false,\n        canClearMarks:\n          ctx.editor\n            .can()\n            .chain()\n            .unsetAllMarks()\n            .run() ?? false,\n        isUnderline: ctx.editor.isActive('underline') ?? false,\n        isSubScript: ctx.editor.isActive('subscript') ?? false,\n        isSuperScript: ctx.editor.isActive('superscript') ?? false,\n        isParagraph: ctx.editor.isActive('paragraph') ?? false,\n        isHeading1: ctx.editor.isActive('heading', { level: 1 }) ?? false,\n        isHeading2: ctx.editor.isActive('heading', { level: 2 }) ?? false,\n        isHeading3: ctx.editor.isActive('heading', { level: 3 }) ?? false,\n        isHeading4: ctx.editor.isActive('heading', { level: 4 }) ?? false,\n        isHeading5: ctx.editor.isActive('heading', { level: 5 }) ?? false,\n        isHeading6: ctx.editor.isActive('heading', { level: 6 }) ?? false,\n        isBulletList: ctx.editor.isActive('bulletList') ?? false,\n        isOrderedList: ctx.editor.isActive('orderedList') ?? false,\n        isCodeBlock: ctx.editor.isActive('codeBlock') ?? false,\n        isBlockquote: ctx.editor.isActive('blockquote') ?? false,\n        canUndo:\n          ctx.editor\n            .can()\n            .chain()\n            .undo()\n            .run() ?? false,\n        canRedo:\n          ctx.editor\n            .can()\n            .chain()\n            .redo()\n            .run() ?? false,\n      };\n    },\n  });\n  const hasDoneButton = false;\n  const autoWidth = false;\n\n  const names = classNames(classes.toolbar, PIE_TOOLBAR__CLASS, {\n    [classes.toolbarWithNoDone]: !hasDoneButton,\n    [classes.toolbarTop]: toolbarOpts.position === 'top',\n    [classes.toolbarRight]: toolbarOpts.alignment === 'right',\n    [classes.focused]: toolbarOpts.alwaysVisible || (editorState.isFocused && !editor._toolbarOpened),\n    [classes.autoWidth]: autoWidth,\n    [classes.fullWidth]: !autoWidth,\n    [classes.hidden]: toolbarOpts.isHidden === true,\n  });\n  const customStyles = toolbarOpts.minWidth !== undefined ? { minWidth: toolbarOpts.minWidth } : {};\n  const handleMouseDown = (e) => {\n    e.preventDefault();\n  };\n  const toolbarButtons = useMemo(\n    () => [\n      {\n        icon: <GridOn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertTable({ rows: 2, cols: 2, withHeaderRow: false })\n            .run(),\n        hidden: (state) => !activePlugins?.includes('table') || state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <AddRow />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .addRowAfter()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveRow />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteRow()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <AddColumn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .addColumnAfter()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveColumn />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteColumn()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <RemoveTable />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .deleteTable()\n            .run(),\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.isTable,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <BorderAll />,\n        onClick: (editor) => {\n          const tableAttrs = editor.getAttributes('table');\n\n          const update = {\n            ...tableAttrs,\n            border: tableAttrs.border !== '0' ? '0' : '1',\n          };\n\n          editor.commands.updateAttributes('table', update);\n        },\n        hidden: (state) => !state.isTable,\n        isActive: (state) => state.tableHasBorder,\n        isDisabled: (state) => !state.canTable,\n      },\n      {\n        icon: <Bold />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleBold()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('bold') || state.isTable,\n        isActive: (state) => state.isBold,\n        isDisabled: (state) => !state.canBold,\n      },\n      {\n        icon: <Italic />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleItalic()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('italic') || state.isTable,\n        isActive: (state) => state.isItalic,\n        isDisabled: (state) => !state.canItalic,\n      },\n      {\n        icon: <Strikethrough />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleStrike()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('strikethrough') || state.isTable,\n        isActive: (state) => state.isStrike,\n        isDisabled: (state) => !state.canStrike,\n      },\n      {\n        icon: <Code />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleCode()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('code') || state.isTable,\n        isActive: (state) => state.isCode,\n        isDisabled: (state) => !state.canCode,\n      },\n      {\n        icon: <Underline />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleUnderline()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('underline') || state.isTable,\n        isActive: (state) => state.isUnderline,\n      },\n      {\n        icon: <SubscriptIcon />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleSubscript()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('subscript') || state.isTable,\n        isActive: (state) => state.isSubScript,\n      },\n      {\n        icon: <SuperscriptIcon />,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleSuperscript()\n            .run(),\n        hidden: (state) => !activePlugins?.includes('superscript') || state.isTable,\n        isActive: (state) => state.isSuperScript,\n      },\n      {\n        icon: <ImageIcon />,\n        hidden: (state) => !activePlugins?.includes('image') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .setImageUploadNode()\n            .run(),\n      },\n      {\n        icon: <TheatersIcon />,\n        hidden: (state) => !activePlugins?.includes('video') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMedia({ tag: 'video' })\n            .run(),\n      },\n      {\n        icon: <VolumeUpIcon />,\n        hidden: (state) => !activePlugins?.includes('audio') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMedia({ tag: 'audio' })\n            .run(),\n      },\n      {\n        icon: <CSSIcon />,\n        hidden: (state) => !activePlugins?.includes('css') || state.isTable,\n        onClick: (editor) => editor.commands.openCSSClassDialog(),\n      },\n      {\n        icon: <HeadingIcon />,\n        hidden: (state) => !activePlugins?.includes('h3') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleHeading({ level: 3 })\n            .run(),\n        isActive: (state) => state.isHeading3,\n      },\n      {\n        icon: <Functions />,\n        hidden: () => !activePlugins?.includes('math'),\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .insertMath('')\n            .run(),\n      },\n      {\n        icon: <CharacterIcon letter=\"ñ\" />,\n        hidden: (state) => !activePlugins?.includes('languageCharacters') || state.isTable,\n        onClick: () => setShowPicker(spanishConfig),\n      },\n      {\n        icon: <CharacterIcon letter=\"€\" />,\n        hidden: (state) => activePlugins?.filter(p => p === 'languageCharacters').length !== 2 || state.isTable,\n        onClick: () => setShowPicker(specialConfig),\n      },\n      {\n        icon: <TextAlignIcon editor={editor} />,\n        hidden: (state) => !activePlugins?.includes('text-align') || state.isTable,\n        onClick: () => {},\n      },\n      {\n        icon: <BulletedListIcon />,\n        hidden: (state) => !activePlugins?.includes('bulleted-list') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleBulletList()\n            .run(),\n        isActive: (state) => state.isBulletList,\n      },\n      {\n        icon: <NumberedListIcon />,\n        hidden: (state) => !activePlugins?.includes('numbered-list') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .toggleOrderedList()\n            .run(),\n        isActive: (state) => state.isOrderedList,\n      },\n      {\n        icon: <Undo />,\n        hidden: (state) => !activePlugins?.includes('undo') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .undo()\n            .run(),\n        isDisabled: (state) => !state.canUndo,\n      },\n      {\n        icon: <Redo />,\n        hidden: (state) => !activePlugins?.includes('redo') || state.isTable,\n        onClick: (editor) =>\n          editor\n            .chain()\n            .focus()\n            .redo()\n            .run(),\n        isDisabled: (state) => !state.canRedo,\n      },\n    ],\n    [activePlugins, editor, spanishConfig, specialConfig, setShowPicker],\n  );\n\n  return (\n    <div className={names} style={{ ...customStyles }} onMouseDown={handleMouseDown}>\n      {!editorState.hideDefaultToolbar && (\n        <div className={classes.defaultToolbar} tabIndex=\"1\">\n          <div className={classes.buttonsContainer}>\n            {toolbarButtons\n              .filter((btn) => !btn.hidden?.(editorState))\n              .map((btn, index) => {\n                const disabled = btn.isDisabled?.(editorState);\n                const active = btn.isActive?.(editorState);\n\n                return (\n                  <button\n                    key={index}\n                    disabled={disabled}\n                    onClick={(e) => {\n                      e.preventDefault();\n                      btn.onClick(editor);\n                    }}\n                    className={classNames(classes.button, { [classes.active]: active })}\n                  >\n                    {btn.icon}\n                  </button>\n                );\n              })}\n          </div>\n          {activePlugins?.includes('responseArea') && (\n            <button\n              onClick={() => {\n                editor\n                  .chain()\n                  .focus()\n                  .insertResponseArea(responseAreaProps.type)\n                  .run();\n              }}\n              className={classes.button}\n            >\n              <ToolbarIcon />\n            </button>\n          )}\n\n          <DoneButton\n            onClick={() => {\n              onChange?.(editor.getHTML());\n              editor.commands.blur();\n            }}\n          />\n        </div>\n      )}\n      {showPicker && (\n        <CharacterPicker\n          editor={editor}\n          opts={{\n            ...showPicker,\n            renderPopOver: (ev, ch) => console.log('Show popover', ch),\n            closePopOver: () => console.log('Close popover'),\n          }}\n          onClose={() => setShowPicker(false)}\n        />\n      )}\n    </div>\n  );\n}\n\nconst style = (theme) => ({\n  defaultToolbar: {\n    display: 'flex',\n    width: '100%',\n    justifyContent: 'space-between',\n  },\n  buttonsContainer: {\n    alignItems: 'center',\n    display: 'flex',\n    width: '100%',\n  },\n  button: {\n    color: 'grey',\n    display: 'inline-flex',\n    padding: '2px',\n    background: 'none',\n    border: 'none',\n    cursor: 'pointer',\n    '&:hover': {\n      color: 'black',\n    },\n    '&:focus': {\n      outline: `2px solid ${theme.palette.grey[700]}`,\n    },\n  },\n  active: {\n    color: 'black',\n  },\n  disabled: {\n    opacity: 0.7,\n    cursor: 'not-allowed',\n    '& :hover': {\n      color: 'grey',\n    },\n  },\n  isActive: {\n    background: 'var(--purple)',\n    color: 'var(--white)',\n  },\n  toolbar: {\n    position: 'absolute',\n    zIndex: 20,\n    cursor: 'pointer',\n    justifyContent: 'space-between',\n    background: 'var(--editable-html-toolbar-bg, #efefef)',\n    minWidth: '280px',\n    margin: '5px 0 0 0',\n    padding: '2px',\n    boxShadow:\n      '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',\n    boxSizing: 'border-box',\n    display: 'flex',\n    opacity: 0,\n    pointerEvents: 'none',\n  },\n  toolbarWithNoDone: {\n    minWidth: '265px',\n  },\n  toolbarTop: {\n    top: '-45px',\n  },\n  toolbarRight: {\n    right: 0,\n  },\n  fullWidth: {\n    width: '100%',\n  },\n  hidden: {\n    visibility: 'hidden',\n  },\n  autoWidth: {\n    width: 'auto',\n  },\n  focused: {\n    opacity: 1,\n    pointerEvents: 'auto',\n  },\n  iconRoot: {\n    width: '28px',\n    height: '28px',\n    padding: '4px',\n    verticalAlign: 'top',\n  },\n  label: {\n    color: 'var(--editable-html-toolbar-check, #00bb00)',\n  },\n  shared: {\n    display: 'flex',\n  },\n});\nconst StyledMenuBar = withStyles(style, { index: 1000 })(MenuBar);\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nexport const EditableHtml = (props) => {\n  const [pendingImages, setPendingImages] = useState([]);\n  const [scheduled, setScheduled] = useState(false);\n  const { classes, toolbarOpts } = props;\n  const toolbarOptsToUse = {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n  };\n  const activePluginsToUse = useMemo(() => {\n    let { customPlugins } = props.pluginProps || {};\n\n    customPlugins = customPlugins || [];\n\n    return buildPlugins(props.activePlugins, customPlugins, {\n      math: {},\n      textAlign: {},\n      html: {},\n      extraCSSRules: props.extraCSSRules || {},\n      image: {},\n      toolbar: {},\n      table: {},\n      responseArea: {},\n      languageCharacters: props.languageCharactersProps,\n      keyPadCharacterRef: {},\n      setKeypadInteraction: {},\n      media: {},\n    });\n  }, [props]);\n  const extensions = [\n    TextStyleKit,\n    StarterKit,\n    ExtendedTable,\n    TableRow,\n    TableHeader,\n    TableCell,\n    ResponseAreaExtension,\n    ExplicitConstructedResponseNode.configure(props.responseAreaProps),\n    DragInTheBlankNode.configure(props.responseAreaProps),\n    InlineDropdownNode.configure(props.responseAreaProps),\n    MathNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n    }),\n    SubScript,\n    SuperScript,\n    TextAlign.configure({\n      types: ['heading', 'paragraph'],\n      alignments: ['left', 'right', 'center'],\n    }),\n    Image,\n    ImageUploadNode.configure({\n      toolbarOpts: toolbarOptsToUse,\n      imageHandling: {\n        disableImageAlignmentButtons: props.disableImageAlignmentButtons,\n        onDone: () => props.onDone?.(editor.getHTML()),\n        onDelete:\n          props.imageSupport &&\n          props.imageSupport.delete &&\n          ((node, done) => {\n            const { src } = node.attrs;\n\n            props.imageSupport.delete(src, (e) => {\n              const newPendingImages = pendingImages.filter((img) => img.key !== node.key);\n              const newState = {\n                pendingImages: newPendingImages,\n                scheduled: scheduled && newPendingImages.length === 0 ? false : scheduled,\n              };\n\n              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              done();\n            });\n          }),\n        insertImageRequested:\n          props.imageSupport &&\n          ((addedImage, getHandler) => {\n            const onFinish = (result) => {\n              let cb;\n\n              if (scheduled && result) {\n                // finish editing only on success\n                cb = props.onChange;\n              }\n\n              const newPendingImages = 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              setPendingImages(newState.pendingImages);\n              setScheduled(newState.scheduled);\n              cb?.(editor.getHTML());\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);\n              props.imageSupport.add(handler);\n            };\n\n            setPendingImages([...pendingImages, addedImage]);\n            callback();\n          }),\n        maxImageWidth: props.maxImageWidth,\n        maxImageHeight: props.maxImageHeight,\n      },\n      limit: 3,\n    }),\n    Media.configure({\n      uploadSoundSupport: props.uploadSoundSupport,\n    }),\n    CSSMark.configure({\n      extraCSSRules: props.extraCSSRules,\n    }),\n  ];\n  const editor = useEditor({\n    extensions,\n    immediatelyRender: false,\n    content: props.markup,\n    onUpdate: ({ editor, transaction }) => transaction.isDone && props.onChange?.(editor.getHTML()),\n    onBlur: ({ editor }) => {\n      if (toolbarOptsToUse.doneOn === 'blur') {\n        props.onChange?.(editor.getHTML());\n      } else {\n        props.onDone?.(editor.getHTML());\n      }\n    },\n  });\n\n  useEffect(() => {\n    if (!editor) {\n      return;\n    }\n\n    if (props.markup !== editor.getHTML()) {\n      editor.commands.setContent(props.markup, false); // false = don’t emit update\n    }\n  }, [props.markup, editor]);\n\n  useEffect(() => {\n    // Define your variables in a JS object\n    const cssVariables = {\n      '--white': '#fff',\n      '--black': '#2e2b29',\n      '--black-contrast': '#110f0e',\n      '--gray-1': 'rgba(61, 37, 20, .05)',\n      '--gray-2': 'rgba(61, 37, 20, .08)',\n      '--gray-3': 'rgba(61, 37, 20, .12)',\n      '--gray-4': 'rgba(53, 38, 28, .3)',\n      '--gray-5': 'rgba(28, 25, 23, .6)',\n      '--green': '#22c55e',\n      '--purple': '#6a00f5',\n      '--purple-contrast': '#5800cc',\n      '--purple-light': 'rgba(88, 5, 255, .05)',\n      '--yellow-contrast': '#facc15',\n      '--yellow': 'rgba(250, 204, 21, .4)',\n      '--yellow-light': '#fffae5',\n      '--red': '#ff5c33',\n      '--red-light': '#ffebe5',\n      '--shadow': `0px 12px 33px 0px rgba(0, 0, 0, .06),\n               0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)`,\n    };\n\n    Object.entries(cssVariables).forEach(([key, value]) => {\n      document.documentElement.style.setProperty(key, value);\n    });\n  }, []);\n\n  const editorState = useEditorState({\n    editor,\n    selector: (ctx) => {\n      return {\n        isFocused: ctx.editor?.isFocused,\n      };\n    },\n  });\n\n  const 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  const sizeStyle = useMemo(() => {\n    const { minWidth, width, maxWidth, minHeight, height, maxHeight } = props;\n\n    return {\n      width: valueToSize(width),\n      minWidth: valueToSize(minWidth),\n      maxWidth: valueToSize(maxWidth),\n      height: valueToSize(height),\n      minHeight: valueToSize(minHeight),\n      maxHeight: valueToSize(maxHeight),\n    };\n  }, [props]);\n\n  return (\n    <EditorContainer\n      {...{ ...props, activePlugins: activePluginsToUse, toolbarOpts: toolbarOptsToUse }}\n      editorState={editorState}\n      editor={editor}\n    >\n      {editor && (\n        <EditorContent\n          style={{\n            minHeight: sizeStyle.minHeight,\n            height: sizeStyle.height,\n            maxHeight: sizeStyle.maxHeight,\n          }}\n          className={classes.root}\n          editor={editor}\n        />\n      )}\n    </EditorContainer>\n  );\n};\n\nconst StyledEditor = withStyles({\n  root: {\n    outline: 'none !important',\n    '& .ProseMirror': {\n      outline: 'none !important',\n      position: 'initial',\n    },\n  },\n})(EditableHtml);\n\nexport default StyledEditor;\n"]}
|