@pie-lib/editable-html-tip-tap 1.0.2 → 1.0.4

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.
Files changed (165) hide show
  1. package/lib/components/CharacterPicker.js +221 -0
  2. package/lib/components/CharacterPicker.js.map +1 -0
  3. package/lib/components/EditableHtml.js +323 -0
  4. package/lib/components/EditableHtml.js.map +1 -0
  5. package/lib/components/MenuBar.js +694 -0
  6. package/lib/components/MenuBar.js.map +1 -0
  7. package/lib/components/TiptapContainer.js +90 -0
  8. package/lib/components/TiptapContainer.js.map +1 -0
  9. package/lib/components/buttons/done-button.js +53 -0
  10. package/lib/components/characters/characterUtils.js +112 -0
  11. package/lib/components/characters/characterUtils.js.map +1 -0
  12. package/lib/components/characters/custom-popper.js +73 -0
  13. package/lib/components/characters/custom-popper.js.map +1 -0
  14. package/lib/components/common/done-button.js +53 -0
  15. package/lib/components/common/done-button.js.map +1 -0
  16. package/lib/components/common/toolbar-buttons.js +194 -0
  17. package/lib/components/icons/CssIcon.js +37 -0
  18. package/lib/components/icons/CssIcon.js.map +1 -0
  19. package/lib/components/icons/RespArea.js +95 -0
  20. package/lib/components/icons/RespArea.js.map +1 -0
  21. package/lib/components/icons/TableIcons.js +69 -0
  22. package/lib/components/icons/TableIcons.js.map +1 -0
  23. package/lib/components/icons/TextAlign.js +194 -0
  24. package/lib/components/icons/TextAlign.js.map +1 -0
  25. package/lib/components/icons/index.js +194 -0
  26. package/lib/components/image/AltDialog.js +129 -0
  27. package/lib/components/image/ImageToolbar.js +177 -0
  28. package/lib/components/image/ImageToolbar.js.map +1 -0
  29. package/lib/components/image/InsertImageHandler.js +115 -0
  30. package/lib/components/image/InsertImageHandler.js.map +1 -0
  31. package/lib/components/image/alt-dialog.js +2 -0
  32. package/lib/components/media/MediaDialog.js +709 -0
  33. package/lib/components/media/MediaDialog.js.map +1 -0
  34. package/lib/components/media/MediaToolbar.js +101 -0
  35. package/lib/components/media/MediaToolbar.js.map +1 -0
  36. package/lib/components/media/MediaWrapper.js +93 -0
  37. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +94 -0
  38. package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js.map +1 -0
  39. package/lib/components/respArea/DragInTheBlank/choice.js +289 -0
  40. package/lib/components/respArea/DragInTheBlank/choice.js.map +1 -0
  41. package/lib/components/respArea/DragInTheBlank.js +94 -0
  42. package/lib/components/respArea/ExplicitConstructedResponse.js +120 -0
  43. package/lib/components/respArea/ExplicitConstructedResponse.js.map +1 -0
  44. package/lib/components/respArea/InlineDropdown.js +126 -0
  45. package/lib/components/respArea/InlineDropdown.js.map +1 -0
  46. package/lib/components/respArea/ToolbarIcon.js +105 -0
  47. package/lib/components/respArea/ToolbarIcon.js.map +1 -0
  48. package/lib/components/respArea/choice.js +2 -0
  49. package/lib/constants.js.map +1 -0
  50. package/lib/extensions/component.js +5 -5
  51. package/lib/extensions/component.js.map +1 -0
  52. package/lib/extensions/css.js.map +1 -0
  53. package/lib/extensions/custom-toolbar-wrapper.js +2 -4
  54. package/lib/extensions/custom-toolbar-wrapper.js.map +1 -0
  55. package/lib/extensions/extended-table.js +30 -0
  56. package/lib/extensions/extended-table.js.map +1 -0
  57. package/lib/extensions/image.js +2 -8
  58. package/lib/extensions/image.js.map +1 -0
  59. package/lib/extensions/index.js +52 -0
  60. package/lib/extensions/index.js.map +1 -0
  61. package/lib/extensions/math.js.map +1 -0
  62. package/lib/extensions/media.js +7 -7
  63. package/lib/extensions/media.js.map +1 -0
  64. package/lib/extensions/responseArea.js +7 -7
  65. package/lib/extensions/responseArea.js.map +1 -0
  66. package/lib/index.js +16 -1481
  67. package/lib/index.js.map +1 -0
  68. package/lib/plugins/index.js +8 -80
  69. package/lib/styles/editorContainerStyles.js +200 -0
  70. package/lib/styles/editorContainerStyles.js.map +1 -0
  71. package/lib/theme.js.map +1 -0
  72. package/lib/utils/size.js +34 -0
  73. package/lib/utils/size.js.map +1 -0
  74. package/package.json +1 -1
  75. package/src/components/CharacterPicker.jsx +185 -0
  76. package/src/components/EditableHtml.jsx +306 -0
  77. package/src/components/MenuBar.jsx +630 -0
  78. package/src/components/TiptapContainer.jsx +96 -0
  79. package/src/components/characters/characterUtils.js +127 -0
  80. package/src/{plugins/image/image-toolbar.jsx → components/image/ImageToolbar.jsx} +2 -2
  81. package/src/{plugins/image/insert-image-handler.js → components/image/InsertImageHandler.js} +0 -1
  82. package/src/{plugins/media/media-dialog.js → components/media/MediaDialog.js} +2 -2
  83. package/src/{plugins/respArea/drag-in-the-blank → components/respArea/DragInTheBlank}/choice.jsx +1 -1
  84. package/src/{plugins/respArea/inline-dropdown/index.jsx → components/respArea/InlineDropdown.jsx} +1 -1
  85. package/src/components/respArea/ToolbarIcon.jsx +68 -0
  86. package/src/extensions/component.jsx +2 -2
  87. package/src/extensions/custom-toolbar-wrapper.jsx +6 -7
  88. package/src/extensions/extended-table.js +27 -0
  89. package/src/extensions/image.js +2 -2
  90. package/src/extensions/index.js +76 -0
  91. package/src/extensions/media.js +12 -7
  92. package/src/extensions/responseArea.js +7 -7
  93. package/src/index.jsx +3 -1440
  94. package/src/styles/editorContainerStyles.js +203 -0
  95. package/src/utils/size.js +32 -0
  96. package/src/__tests__/editor.test.jsx +0 -363
  97. package/src/__tests__/serialization.test.js +0 -291
  98. package/src/block-tags.js +0 -17
  99. package/src/editor.jsx +0 -1197
  100. package/src/extensions/characters.js +0 -46
  101. package/src/old-index.jsx +0 -162
  102. package/src/parse-html.js +0 -8
  103. package/src/plugins/README.md +0 -27
  104. package/src/plugins/characters/index.jsx +0 -284
  105. package/src/plugins/characters/utils.js +0 -447
  106. package/src/plugins/css/index.jsx +0 -340
  107. package/src/plugins/customPlugin/index.jsx +0 -85
  108. package/src/plugins/html/icons/index.jsx +0 -19
  109. package/src/plugins/html/index.jsx +0 -72
  110. package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +0 -51
  111. package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +0 -27
  112. package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +0 -44
  113. package/src/plugins/image/__tests__/component.test.jsx +0 -41
  114. package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +0 -42
  115. package/src/plugins/image/__tests__/image-toolbar.test.jsx +0 -11
  116. package/src/plugins/image/__tests__/index.test.js +0 -95
  117. package/src/plugins/image/__tests__/insert-image-handler.test.js +0 -113
  118. package/src/plugins/image/__tests__/mock-change.js +0 -15
  119. package/src/plugins/image/component.jsx +0 -343
  120. package/src/plugins/image/index.jsx +0 -227
  121. package/src/plugins/index.jsx +0 -377
  122. package/src/plugins/list/__tests__/index.test.js +0 -54
  123. package/src/plugins/list/index.jsx +0 -305
  124. package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +0 -48
  125. package/src/plugins/math/__tests__/index.test.jsx +0 -245
  126. package/src/plugins/math/index.jsx +0 -379
  127. package/src/plugins/media/__tests__/index.test.js +0 -75
  128. package/src/plugins/media/index.jsx +0 -325
  129. package/src/plugins/rendering/index.js +0 -31
  130. package/src/plugins/respArea/index.jsx +0 -299
  131. package/src/plugins/respArea/math-templated/index.jsx +0 -104
  132. package/src/plugins/respArea/utils.jsx +0 -90
  133. package/src/plugins/table/CustomTablePlugin.js +0 -113
  134. package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +0 -44
  135. package/src/plugins/table/__tests__/index.test.jsx +0 -401
  136. package/src/plugins/table/__tests__/table-toolbar.test.jsx +0 -42
  137. package/src/plugins/table/index.jsx +0 -427
  138. package/src/plugins/table/table-toolbar.jsx +0 -136
  139. package/src/plugins/textAlign/index.jsx +0 -23
  140. package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +0 -923
  141. package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +0 -20
  142. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +0 -36
  143. package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +0 -46
  144. package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +0 -94
  145. package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +0 -37
  146. package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +0 -51
  147. package/src/plugins/toolbar/__tests__/toolbar.test.jsx +0 -106
  148. package/src/plugins/toolbar/default-toolbar.jsx +0 -206
  149. package/src/plugins/toolbar/editor-and-toolbar.jsx +0 -257
  150. package/src/plugins/toolbar/index.jsx +0 -23
  151. package/src/plugins/toolbar/toolbar.jsx +0 -338
  152. package/src/plugins/utils.js +0 -31
  153. package/src/serialization.jsx +0 -621
  154. /package/src/{plugins → components}/characters/custom-popper.js +0 -0
  155. /package/src/{plugins/toolbar → components/common}/done-button.jsx +0 -0
  156. /package/src/{plugins/toolbar → components/common}/toolbar-buttons.jsx +0 -0
  157. /package/src/{plugins/css/icons/index.jsx → components/icons/CssIcon.jsx} +0 -0
  158. /package/src/{plugins/respArea/icons/index.jsx → components/icons/RespArea.jsx} +0 -0
  159. /package/src/{plugins/table/icons/index.jsx → components/icons/TableIcons.jsx} +0 -0
  160. /package/src/{plugins/textAlign/icons/index.jsx → components/icons/TextAlign.jsx} +0 -0
  161. /package/src/{plugins/image/alt-dialog.jsx → components/image/AltDialog.jsx} +0 -0
  162. /package/src/{plugins/media/media-toolbar.jsx → components/media/MediaToolbar.jsx} +0 -0
  163. /package/src/{plugins/media/media-wrapper.jsx → components/media/MediaWrapper.jsx} +0 -0
  164. /package/src/{plugins/respArea/drag-in-the-blank/index.jsx → components/respArea/DragInTheBlank/DragInTheBlank.jsx} +0 -0
  165. /package/src/{plugins/respArea/explicit-constructed-response/index.jsx → components/respArea/ExplicitConstructedResponse.jsx} +0 -0
@@ -0,0 +1,221 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.CharacterIcon = void 0;
11
+ exports.CharacterPicker = CharacterPicker;
12
+
13
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
14
+
15
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
16
+
17
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
18
+
19
+ var _react = _interopRequireWildcard(require("react"));
20
+
21
+ var _reactDom = _interopRequireDefault(require("react-dom"));
22
+
23
+ var _propTypes = _interopRequireDefault(require("prop-types"));
24
+
25
+ var _get = _interopRequireDefault(require("lodash/get"));
26
+
27
+ var _mathToolbar = require("@pie-lib/math-toolbar");
28
+
29
+ var _customPopper = _interopRequireDefault(require("./characters/custom-popper"));
30
+
31
+ var _characterUtils = require("./characters/characterUtils");
32
+
33
+ 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); }
34
+
35
+ 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; }
36
+
37
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
38
+
39
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
40
+
41
+ var CharacterIcon = function CharacterIcon(_ref) {
42
+ var letter = _ref.letter;
43
+ return /*#__PURE__*/_react["default"].createElement("div", {
44
+ style: {
45
+ fontSize: '24px',
46
+ lineHeight: '24px'
47
+ }
48
+ }, letter);
49
+ };
50
+
51
+ exports.CharacterIcon = CharacterIcon;
52
+ CharacterIcon.propTypes = {
53
+ letter: _propTypes["default"].string
54
+ };
55
+
56
+ function CharacterPicker(_ref2) {
57
+ var _opts$characters;
58
+
59
+ var editor = _ref2.editor,
60
+ opts = _ref2.opts,
61
+ onClose = _ref2.onClose;
62
+
63
+ if (!(opts !== null && opts !== void 0 && (_opts$characters = opts.characters) !== null && _opts$characters !== void 0 && _opts$characters.length)) {
64
+ return null;
65
+ }
66
+
67
+ var containerRef = (0, _react.useRef)(null);
68
+
69
+ var _useState = (0, _react.useState)({
70
+ top: 0,
71
+ left: 0
72
+ }),
73
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
74
+ position = _useState2[0],
75
+ setPosition = _useState2[1];
76
+
77
+ var _useState3 = (0, _react.useState)(null),
78
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
79
+ popover = _useState4[0],
80
+ setPopover = _useState4[1];
81
+
82
+ var configToUse = (0, _react.useMemo)(function () {
83
+ if (!opts) return _characterUtils.spanishConfig;
84
+
85
+ switch (true) {
86
+ case opts.language === 'spanish':
87
+ return _characterUtils.spanishConfig;
88
+
89
+ case opts.language === 'special':
90
+ return _characterUtils.specialConfig;
91
+
92
+ default:
93
+ return opts;
94
+ }
95
+ }, [opts]);
96
+ var layoutForCharacters = (0, _react.useMemo)(function () {
97
+ return configToUse.characters.reduce(function (obj, arr) {
98
+ if (arr.length >= obj.columns) {
99
+ obj.columns = arr.length;
100
+ }
101
+
102
+ return obj;
103
+ }, {
104
+ rows: configToUse.characters.length,
105
+ columns: 0
106
+ });
107
+ }, [configToUse]);
108
+
109
+ var closePopOver = function closePopOver() {
110
+ return setPopover(null);
111
+ };
112
+
113
+ (0, _react.useEffect)(function () {
114
+ return function () {
115
+ closePopOver();
116
+ };
117
+ }, []);
118
+ (0, _react.useEffect)(function () {
119
+ if (!editor) return; // Calculate position relative to selection
120
+
121
+ var bodyRect = document.body.getBoundingClientRect();
122
+ var from = editor.state.selection.from;
123
+ var start = editor.view.coordsAtPos(from);
124
+ setPosition({
125
+ top: start.top + Math.abs(bodyRect.top) + 40,
126
+ // shift above
127
+ left: start.left
128
+ });
129
+
130
+ var handleClickOutside = function handleClickOutside(e) {
131
+ if (containerRef.current && !containerRef.current.contains(e.target) && !editor.view.dom.contains(e.target)) {
132
+ onClose();
133
+ }
134
+ };
135
+
136
+ document.addEventListener('mousedown', handleClickOutside);
137
+ return function () {
138
+ return document.removeEventListener('mousedown', handleClickOutside);
139
+ };
140
+ }, [editor, onClose]);
141
+
142
+ var renderPopOver = function renderPopOver(event, el) {
143
+ return setPopover({
144
+ anchorEl: event.currentTarget,
145
+ el: el
146
+ });
147
+ };
148
+
149
+ var handleChange = function handleChange(val) {
150
+ if (typeof val === 'string') {
151
+ editor.chain().focus().insertContent(val).run();
152
+ }
153
+ };
154
+
155
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_reactDom["default"].createPortal( /*#__PURE__*/_react["default"].createElement("div", {
156
+ ref: containerRef,
157
+ className: "insert-character-dialog",
158
+ style: {
159
+ position: 'absolute',
160
+ top: "".concat(position.top, "px"),
161
+ left: "".concat(position.left, "px"),
162
+ maxWidth: '500px'
163
+ }
164
+ }, /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_mathToolbar.PureToolbar, {
165
+ keyPadCharacterRef: opts.keyPadCharacterRef,
166
+ setKeypadInteraction: opts.setKeypadInteraction,
167
+ autoFocus: true,
168
+ noDecimal: true,
169
+ hideInput: true,
170
+ noLatexHandling: true,
171
+ hideDoneButtonBackground: true,
172
+ layoutForKeyPad: layoutForCharacters,
173
+ additionalKeys: configToUse.characters.reduce(function (arr, n) {
174
+ arr = [].concat((0, _toConsumableArray2["default"])(arr), (0, _toConsumableArray2["default"])(n.map(function (k) {
175
+ return _objectSpread({
176
+ name: (0, _get["default"])(k, 'name') || k,
177
+ write: (0, _get["default"])(k, 'write') || k,
178
+ label: (0, _get["default"])(k, 'label') || k,
179
+ category: 'character',
180
+ extraClass: 'character',
181
+ extraProps: _objectSpread(_objectSpread({}, k.extraProps || {}), {}, {
182
+ style: _objectSpread(_objectSpread({}, (k.extraProps || {}).style), {}, {
183
+ border: '1px solid #000'
184
+ })
185
+ })
186
+ }, configToUse.hasPreview ? {
187
+ actions: {
188
+ onMouseEnter: function onMouseEnter(ev) {
189
+ return renderPopOver(ev, k);
190
+ },
191
+ onMouseLeave: closePopOver
192
+ }
193
+ } : {});
194
+ })));
195
+ return arr;
196
+ }, []),
197
+ keypadMode: "language",
198
+ onChange: handleChange,
199
+ onDone: onClose
200
+ }))), document.body), popover && /*#__PURE__*/_reactDom["default"].createPortal( /*#__PURE__*/_react["default"].createElement(_customPopper["default"], {
201
+ onClose: closePopOver,
202
+ anchorEl: popover.anchorEl
203
+ }, /*#__PURE__*/_react["default"].createElement("div", null, popover.el.label), /*#__PURE__*/_react["default"].createElement("div", {
204
+ style: {
205
+ fontSize: 20,
206
+ lineHeight: '20px'
207
+ }
208
+ }, popover.el.description), /*#__PURE__*/_react["default"].createElement("div", {
209
+ style: {
210
+ fontSize: 20,
211
+ lineHeight: '20px'
212
+ }
213
+ }, popover.el.unicode)), document.body));
214
+ }
215
+
216
+ CharacterPicker.propTypes = {
217
+ editor: _propTypes["default"].object,
218
+ opts: _propTypes["default"].object,
219
+ onClose: _propTypes["default"].func.isRequired
220
+ };
221
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/CharacterPicker.jsx"],"names":["CharacterIcon","letter","fontSize","lineHeight","propTypes","PropTypes","string","CharacterPicker","editor","opts","onClose","characters","length","containerRef","top","left","position","setPosition","popover","setPopover","configToUse","spanishConfig","language","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","object","func","isRequired"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport get from 'lodash/get';\n\nimport { PureToolbar } from '@pie-lib/math-toolbar';\n\nimport CustomPopper from './characters/custom-popper';\nimport { spanishConfig, specialConfig } from './characters/characterUtils';\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  const configToUse = useMemo(() => {\n    if (!opts) return spanishConfig;\n\n    switch (true) {\n      case opts.language === 'spanish':\n        return spanishConfig;\n      case opts.language === 'special':\n        return specialConfig;\n      default:\n        return opts;\n    }\n  }, [opts]);\n\n  const layoutForCharacters = useMemo(\n    () =>\n      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    [configToUse],\n  );\n\n  const closePopOver = () => setPopover(null);\n\n  useEffect(\n    () => () => {\n      closePopOver();\n    },\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, onClose]);\n\n  const renderPopOver = (event, el) => setPopover({ anchorEl: event.currentTarget, el });\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    <>\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: {\n                            onMouseEnter: (ev) => renderPopOver(ev, k),\n                            onMouseLeave: closePopOver,\n                          },\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    </>\n  );\n}\n\nCharacterPicker.propTypes = {\n  editor: PropTypes.object,\n  opts: PropTypes.object,\n  onClose: PropTypes.func.isRequired,\n};\n\nexport { CharacterIcon };\n"]}
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/components/CharacterPicker.jsx"],"names":["CharacterIcon","letter","fontSize","lineHeight","propTypes","PropTypes","string","CharacterPicker","editor","opts","onClose","characters","length","containerRef","top","left","position","setPosition","popover","setPopover","configToUse","spanishConfig","language","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","object","func","isRequired"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport get from 'lodash/get';\n\nimport { PureToolbar } from '@pie-lib/math-toolbar';\n\nimport CustomPopper from './characters/custom-popper';\nimport { spanishConfig, specialConfig } from './characters/characterUtils';\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 const configToUse = useMemo(() => {\n if (!opts) return spanishConfig;\n\n switch (true) {\n case opts.language === 'spanish':\n return spanishConfig;\n case opts.language === 'special':\n return specialConfig;\n default:\n return opts;\n }\n }, [opts]);\n\n const layoutForCharacters = useMemo(\n () =>\n 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 [configToUse],\n );\n\n const closePopOver = () => setPopover(null);\n\n useEffect(\n () => () => {\n closePopOver();\n },\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, onClose]);\n\n const renderPopOver = (event, el) => setPopover({ anchorEl: event.currentTarget, el });\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 <>\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: {\n onMouseEnter: (ev) => renderPopOver(ev, k),\n onMouseLeave: closePopOver,\n },\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 </>\n );\n}\n\nCharacterPicker.propTypes = {\n editor: PropTypes.object,\n opts: PropTypes.object,\n onClose: PropTypes.func.isRequired,\n};\n\nexport { CharacterIcon };\n"],"file":"CharacterPicker.js"}
@@ -0,0 +1,323 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = exports.EditableHtml = void 0;
11
+
12
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+
14
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
15
+
16
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
17
+
18
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
+
20
+ var _react = _interopRequireWildcard(require("react"));
21
+
22
+ var _react2 = require("@tiptap/react");
23
+
24
+ var _starterKit = _interopRequireDefault(require("@tiptap/starter-kit"));
25
+
26
+ var _extensionTextStyle = require("@tiptap/extension-text-style");
27
+
28
+ var _extensionSuperscript = _interopRequireDefault(require("@tiptap/extension-superscript"));
29
+
30
+ var _extensionSubscript = _interopRequireDefault(require("@tiptap/extension-subscript"));
31
+
32
+ var _extensionTextAlign = _interopRequireDefault(require("@tiptap/extension-text-align"));
33
+
34
+ var _extensionImage = _interopRequireDefault(require("@tiptap/extension-image"));
35
+
36
+ var _styles = require("@material-ui/core/styles");
37
+
38
+ var _extendedTable = _interopRequireDefault(require("../extensions/extended-table"));
39
+
40
+ var _extensionTableRow = require("@tiptap/extension-table-row");
41
+
42
+ var _extensionTableCell = require("@tiptap/extension-table-cell");
43
+
44
+ var _extensionTableHeader = require("@tiptap/extension-table-header");
45
+
46
+ var _responseArea = require("../extensions/responseArea");
47
+
48
+ var _math = require("../extensions/math");
49
+
50
+ var _image = require("../extensions/image");
51
+
52
+ var _media = require("../extensions/media");
53
+
54
+ var _css = require("../extensions/css");
55
+
56
+ var _TiptapContainer = _interopRequireDefault(require("./TiptapContainer"));
57
+
58
+ var _size = require("../utils/size");
59
+
60
+ var _extensions = require("../extensions");
61
+
62
+ 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); }
63
+
64
+ 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; }
65
+
66
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
67
+
68
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
69
+
70
+ var defaultToolbarOpts = {
71
+ position: 'bottom',
72
+ alignment: 'left',
73
+ alwaysVisible: false,
74
+ showDone: true,
75
+ doneOn: 'blur'
76
+ };
77
+ var defaultResponseAreaProps = {
78
+ options: {},
79
+ respAreaToolbar: function respAreaToolbar() {},
80
+ onHandleAreaChange: function onHandleAreaChange() {}
81
+ };
82
+ var DEFAULT_ACTIVE_PLUGINS = ['bold', 'italic', 'underline', 'strikethrough', 'code', 'bulleted-list', 'numbered-list', 'image', 'math', 'languageCharacters', 'text-align', 'table', 'video', 'audio', 'responseArea', 'superscript', 'subscript', 'css', 'h3', 'undo', 'redo'];
83
+ var cssVariables = {
84
+ '--white': '#fff',
85
+ '--black': '#2e2b29',
86
+ '--black-contrast': '#110f0e',
87
+ '--gray-1': 'rgba(61, 37, 20, .05)',
88
+ '--gray-2': 'rgba(61, 37, 20, .08)',
89
+ '--gray-3': 'rgba(61, 37, 20, .12)',
90
+ '--gray-4': 'rgba(53, 38, 28, .3)',
91
+ '--gray-5': 'rgba(28, 25, 23, .6)',
92
+ '--green': '#22c55e',
93
+ '--purple': '#6a00f5',
94
+ '--purple-contrast': '#5800cc',
95
+ '--purple-light': 'rgba(88, 5, 255, .05)',
96
+ '--yellow-contrast': '#facc15',
97
+ '--yellow': 'rgba(250, 204, 21, .4)',
98
+ '--yellow-light': '#fffae5',
99
+ '--red': '#ff5c33',
100
+ '--red-light': '#ffebe5',
101
+ '--shadow': "0px 12px 33px 0px rgba(0, 0, 0, .06),\n 0px 3.618px 9.949px 0px rgba(0, 0, 0, .04)"
102
+ };
103
+
104
+ var EditableHtml = function EditableHtml(props) {
105
+ var _useState = (0, _react.useState)([]),
106
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
107
+ pendingImages = _useState2[0],
108
+ setPendingImages = _useState2[1];
109
+
110
+ var _useState3 = (0, _react.useState)(false),
111
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
112
+ scheduled = _useState4[0],
113
+ setScheduled = _useState4[1];
114
+
115
+ var classes = props.classes,
116
+ toolbarOpts = props.toolbarOpts;
117
+
118
+ var toolbarOptsToUse = _objectSpread(_objectSpread({}, defaultToolbarOpts), toolbarOpts);
119
+
120
+ var activePluginsToUse = (0, _react.useMemo)(function () {
121
+ var _props$responseAreaPr;
122
+
123
+ var _ref = props.pluginProps || {},
124
+ customPlugins = _ref.customPlugins;
125
+
126
+ customPlugins = customPlugins || [];
127
+ return (0, _extensions.buildExtensions)(props.activePlugins, customPlugins, {
128
+ math: {},
129
+ textAlign: {},
130
+ html: {},
131
+ extraCSSRules: props.extraCSSRules || {},
132
+ image: {},
133
+ toolbar: {},
134
+ table: {},
135
+ responseArea: {
136
+ type: (_props$responseAreaPr = props.responseAreaProps) === null || _props$responseAreaPr === void 0 ? void 0 : _props$responseAreaPr.type
137
+ },
138
+ languageCharacters: props.languageCharactersProps,
139
+ keyPadCharacterRef: {},
140
+ setKeypadInteraction: {},
141
+ media: {}
142
+ });
143
+ }, [props]);
144
+ var extensions = [_extensionTextStyle.TextStyleKit, _starterKit["default"], _extendedTable["default"], _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({
145
+ toolbarOpts: toolbarOptsToUse
146
+ }), _extensionSubscript["default"], _extensionSuperscript["default"], _extensionTextAlign["default"].configure({
147
+ types: ['heading', 'paragraph'],
148
+ alignments: ['left', 'right', 'center']
149
+ }), _extensionImage["default"], _image.ImageUploadNode.configure({
150
+ toolbarOpts: toolbarOptsToUse,
151
+ imageHandling: {
152
+ disableImageAlignmentButtons: props.disableImageAlignmentButtons,
153
+ onDone: function onDone() {
154
+ var _props$onDone;
155
+
156
+ return (_props$onDone = props.onDone) === null || _props$onDone === void 0 ? void 0 : _props$onDone.call(props, editor.getHTML());
157
+ },
158
+ onDelete: props.imageSupport && props.imageSupport["delete"] && function (node, done) {
159
+ var src = node.attrs.src;
160
+ props.imageSupport["delete"](src, function (e) {
161
+ var newPendingImages = pendingImages.filter(function (img) {
162
+ return img.key !== node.key;
163
+ });
164
+ var newState = {
165
+ pendingImages: newPendingImages,
166
+ scheduled: scheduled && newPendingImages.length === 0 ? false : scheduled
167
+ };
168
+ setPendingImages(newState.pendingImages);
169
+ setScheduled(newState.scheduled);
170
+ done();
171
+ });
172
+ },
173
+ insertImageRequested: props.imageSupport && function (addedImage, getHandler) {
174
+ var onFinish = function onFinish(result) {
175
+ var _cb;
176
+
177
+ var cb;
178
+
179
+ if (scheduled && result) {
180
+ // finish editing only on success
181
+ cb = props.onChange;
182
+ }
183
+
184
+ var newPendingImages = pendingImages.filter(function (img) {
185
+ return img.key !== addedImage.key;
186
+ });
187
+ var newState = {
188
+ pendingImages: newPendingImages
189
+ };
190
+
191
+ if (newPendingImages.length === 0) {
192
+ newState.scheduled = false;
193
+ }
194
+
195
+ setPendingImages(newState.pendingImages);
196
+ setScheduled(newState.scheduled);
197
+ (_cb = cb) === null || _cb === void 0 ? void 0 : _cb(editor.getHTML());
198
+ };
199
+
200
+ var callback = function callback() {
201
+ /**
202
+ * The handler is the object through which the outer context
203
+ * communicates file upload events like: fileChosen, cancel, progress
204
+ */
205
+ var handler = getHandler(onFinish);
206
+ props.imageSupport.add(handler);
207
+ };
208
+
209
+ setPendingImages([].concat((0, _toConsumableArray2["default"])(pendingImages), [addedImage]));
210
+ callback();
211
+ },
212
+ maxImageWidth: props.maxImageWidth,
213
+ maxImageHeight: props.maxImageHeight
214
+ },
215
+ limit: 3
216
+ }), _media.Media.configure({
217
+ uploadSoundSupport: props.uploadSoundSupport
218
+ }), _css.CSSMark.configure({
219
+ extraCSSRules: props.extraCSSRules
220
+ })];
221
+ var editor = (0, _react2.useEditor)({
222
+ extensions: extensions,
223
+ immediatelyRender: false,
224
+ editable: !props.disabled,
225
+ content: props.markup,
226
+ onUpdate: function onUpdate(_ref2) {
227
+ var _props$onChange;
228
+
229
+ var editor = _ref2.editor,
230
+ transaction = _ref2.transaction;
231
+ return transaction.isDone && ((_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, editor.getHTML()));
232
+ },
233
+ onBlur: function onBlur(_ref3) {
234
+ var editor = _ref3.editor;
235
+
236
+ if (toolbarOptsToUse.doneOn === 'blur') {
237
+ var _props$onChange2;
238
+
239
+ (_props$onChange2 = props.onChange) === null || _props$onChange2 === void 0 ? void 0 : _props$onChange2.call(props, editor.getHTML());
240
+ } else {
241
+ var _props$onDone2;
242
+
243
+ (_props$onDone2 = props.onDone) === null || _props$onDone2 === void 0 ? void 0 : _props$onDone2.call(props, editor.getHTML());
244
+ }
245
+ }
246
+ });
247
+ (0, _react.useEffect)(function () {
248
+ editor === null || editor === void 0 ? void 0 : editor.setEditable(!props.disabled);
249
+ }, [props.disabled, editor]);
250
+ (0, _react.useEffect)(function () {
251
+ if (!editor) {
252
+ return;
253
+ }
254
+
255
+ if (props.markup !== editor.getHTML()) {
256
+ editor.commands.setContent(props.markup, false); // false = don’t emit update
257
+ }
258
+ }, [props.markup, editor]);
259
+ (0, _react.useEffect)(function () {
260
+ Object.entries(cssVariables).forEach(function (_ref4) {
261
+ var _ref5 = (0, _slicedToArray2["default"])(_ref4, 2),
262
+ key = _ref5[0],
263
+ value = _ref5[1];
264
+
265
+ document.documentElement.style.setProperty(key, value);
266
+ });
267
+ }, []);
268
+ var editorState = (0, _react2.useEditorState)({
269
+ editor: editor,
270
+ selector: function selector(ctx) {
271
+ var _ctx$editor;
272
+
273
+ return {
274
+ isFocused: (_ctx$editor = ctx.editor) === null || _ctx$editor === void 0 ? void 0 : _ctx$editor.isFocused
275
+ };
276
+ }
277
+ });
278
+ var sizeStyle = (0, _react.useMemo)(function () {
279
+ var minWidth = props.minWidth,
280
+ width = props.width,
281
+ maxWidth = props.maxWidth,
282
+ minHeight = props.minHeight,
283
+ height = props.height,
284
+ maxHeight = props.maxHeight;
285
+ return {
286
+ width: (0, _size.valueToSize)(width),
287
+ minWidth: (0, _size.valueToSize)(minWidth),
288
+ maxWidth: (0, _size.valueToSize)(maxWidth),
289
+ height: (0, _size.valueToSize)(height),
290
+ minHeight: (0, _size.valueToSize)(minHeight),
291
+ maxHeight: (0, _size.valueToSize)(maxHeight)
292
+ };
293
+ }, [props]);
294
+ return /*#__PURE__*/_react["default"].createElement(_TiptapContainer["default"], (0, _extends2["default"])({}, _objectSpread(_objectSpread({}, props), {}, {
295
+ activePlugins: activePluginsToUse,
296
+ toolbarOpts: toolbarOptsToUse
297
+ }), {
298
+ editorState: editorState,
299
+ editor: editor
300
+ }), editor && /*#__PURE__*/_react["default"].createElement(_react2.EditorContent, {
301
+ style: {
302
+ minHeight: sizeStyle.minHeight,
303
+ height: sizeStyle.height,
304
+ maxHeight: sizeStyle.maxHeight
305
+ },
306
+ className: classes.root,
307
+ editor: editor
308
+ }));
309
+ };
310
+
311
+ exports.EditableHtml = EditableHtml;
312
+ var StyledEditor = (0, _styles.withStyles)({
313
+ root: {
314
+ outline: 'none !important',
315
+ '& .ProseMirror': {
316
+ outline: 'none !important',
317
+ position: 'initial'
318
+ }
319
+ }
320
+ })(EditableHtml);
321
+ var _default = StyledEditor;
322
+ exports["default"] = _default;
323
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/EditableHtml.jsx"],"names":["defaultToolbarOpts","position","alignment","alwaysVisible","showDone","doneOn","defaultResponseAreaProps","options","respAreaToolbar","onHandleAreaChange","DEFAULT_ACTIVE_PLUGINS","cssVariables","EditableHtml","props","pendingImages","setPendingImages","scheduled","setScheduled","classes","toolbarOpts","toolbarOptsToUse","activePluginsToUse","pluginProps","customPlugins","activePlugins","math","textAlign","html","extraCSSRules","image","toolbar","table","responseArea","type","responseAreaProps","languageCharacters","languageCharactersProps","keyPadCharacterRef","setKeypadInteraction","media","extensions","TextStyleKit","StarterKit","ExtendedTable","TableRow","TableHeader","TableCell","ResponseAreaExtension","ExplicitConstructedResponseNode","configure","DragInTheBlankNode","InlineDropdownNode","MathNode","SubScript","SuperScript","TextAlign","types","alignments","Image","ImageUploadNode","imageHandling","disableImageAlignmentButtons","onDone","editor","getHTML","onDelete","imageSupport","node","done","src","attrs","e","newPendingImages","filter","img","key","newState","length","insertImageRequested","addedImage","getHandler","onFinish","result","cb","onChange","callback","handler","add","maxImageWidth","maxImageHeight","limit","Media","uploadSoundSupport","CSSMark","immediatelyRender","editable","disabled","content","markup","onUpdate","transaction","isDone","onBlur","setEditable","commands","setContent","Object","entries","forEach","value","document","documentElement","style","setProperty","editorState","selector","ctx","isFocused","sizeStyle","minWidth","width","maxWidth","minHeight","height","maxHeight","root","StyledEditor","outline"],"mappings":"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","sourcesContent":["import React, { useEffect, useMemo, useState } from 'react';\nimport { EditorContent, useEditor, useEditorState } from '@tiptap/react';\nimport StarterKit from '@tiptap/starter-kit';\nimport { TextStyleKit } from '@tiptap/extension-text-style';\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';\nimport { withStyles } from '@material-ui/core/styles';\n\nimport ExtendedTable from '../extensions/extended-table';\nimport { TableRow } from '@tiptap/extension-table-row';\nimport { TableCell } from '@tiptap/extension-table-cell';\nimport { TableHeader } from '@tiptap/extension-table-header';\nimport {\n  ExplicitConstructedResponseNode,\n  DragInTheBlankNode,\n  InlineDropdownNode,\n  ResponseAreaExtension,\n} from '../extensions/responseArea';\nimport { MathNode } from '../extensions/math';\nimport { ImageUploadNode } from '../extensions/image';\nimport { Media } from '../extensions/media';\nimport { CSSMark } from '../extensions/css';\n\nimport EditorContainer from './TiptapContainer';\nimport { valueToSize } from '../utils/size';\nimport { buildExtensions } from '../extensions';\n\nconst defaultToolbarOpts = {\n  position: 'bottom',\n  alignment: 'left',\n  alwaysVisible: false,\n  showDone: true,\n  doneOn: 'blur',\n};\n\nconst defaultResponseAreaProps = {\n  options: {},\n  respAreaToolbar: () => {},\n  onHandleAreaChange: () => {},\n};\n\nconst DEFAULT_ACTIVE_PLUGINS = [\n  'bold',\n  'italic',\n  'underline',\n  'strikethrough',\n  'code',\n  'bulleted-list',\n  'numbered-list',\n  'image',\n  'math',\n  'languageCharacters',\n  'text-align',\n  'table',\n  'video',\n  'audio',\n  'responseArea',\n  'superscript',\n  'subscript',\n  'css',\n  'h3',\n  'undo',\n  'redo',\n];\n\nconst 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\nexport const EditableHtml = (props) => {\n  const [pendingImages, setPendingImages] = useState([]);\n  const [scheduled, setScheduled] = useState(false);\n  const { classes, toolbarOpts } = props;\n\n  const toolbarOptsToUse = {\n    ...defaultToolbarOpts,\n    ...toolbarOpts,\n  };\n\n  const activePluginsToUse = useMemo(() => {\n    let { customPlugins } = props.pluginProps || {};\n\n    customPlugins = customPlugins || [];\n\n    return buildExtensions(props.activePlugins, customPlugins, {\n      math: {},\n      textAlign: {},\n      html: {},\n      extraCSSRules: props.extraCSSRules || {},\n      image: {},\n      toolbar: {},\n      table: {},\n      responseArea: {\n        type: props.responseAreaProps?.type,\n      },\n      languageCharacters: props.languageCharactersProps,\n      keyPadCharacterRef: {},\n      setKeypadInteraction: {},\n      media: {},\n    });\n  }, [props]);\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        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\n  const editor = useEditor({\n    extensions,\n    immediatelyRender: false,\n    editable: !props.disabled,\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    editor?.setEditable(!props.disabled);\n  }, [props.disabled, editor]);\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    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      isFocused: ctx.editor?.isFocused,\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      {...{\n        ...props,\n        activePlugins: activePluginsToUse,\n        toolbarOpts: toolbarOptsToUse,\n      }}\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"]}