@pie-lib/editable-html-tip-tap 1.0.1 → 1.0.3
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/components/CharacterPicker.js +221 -0
- package/lib/components/EditableHtml.js +323 -0
- package/lib/components/MenuBar.js +693 -0
- package/lib/components/TiptapContainer.js +90 -0
- package/lib/components/buttons/done-button.js +53 -0
- package/lib/components/characters/characterUtils.js +112 -0
- package/lib/components/characters/custom-popper.js +73 -0
- package/lib/components/common/done-button.js +53 -0
- package/lib/components/icons/CssIcon.js +37 -0
- package/lib/components/icons/RespArea.js +95 -0
- package/lib/components/icons/TableIcons.js +69 -0
- package/lib/components/icons/TextAlign.js +194 -0
- package/lib/components/icons/index.js +194 -0
- package/lib/components/image/ImageToolbar.js +16 -0
- package/lib/components/image/InsertImageHandler.js +16 -0
- package/lib/components/media/MediaDialog.js +16 -0
- package/lib/components/media/MediaToolbar.js +16 -0
- package/lib/components/respArea/DragInTheBlank/DragInTheBlank.js +94 -0
- package/lib/components/respArea/DragInTheBlank/choice.js +289 -0
- package/lib/components/respArea/DragInTheBlank.js +94 -0
- package/lib/components/respArea/ExplicitConstructedResponse.js +120 -0
- package/lib/components/respArea/InlineDropdown.js +126 -0
- package/lib/components/respArea/ToolbarIcon.js +105 -0
- package/lib/components/respArea/choice.js +2 -0
- package/lib/extensions/component.js +5 -5
- package/lib/extensions/custom-toolbar-wrapper.js +2 -4
- package/lib/extensions/extended-table.js +30 -0
- package/lib/extensions/index.js +52 -0
- package/lib/extensions/media.js +5 -5
- package/lib/extensions/responseArea.js +7 -7
- package/lib/index.js +16 -1454
- package/lib/plugins/index.js +10 -82
- package/lib/styles/editorContainerStyles.js +200 -0
- package/lib/utils/size.js +34 -0
- package/package.json +1 -1
- package/src/components/CharacterPicker.jsx +185 -0
- package/src/components/EditableHtml.jsx +306 -0
- package/src/components/MenuBar.jsx +630 -0
- package/src/components/TiptapContainer.jsx +96 -0
- package/src/components/characters/characterUtils.js +127 -0
- package/src/components/image/ImageToolbar.jsx +1 -0
- package/src/components/image/InsertImageHandler.js +1 -0
- package/src/components/media/MediaDialog.js +1 -0
- package/src/components/media/MediaToolbar.jsx +1 -0
- package/src/{plugins/respArea/drag-in-the-blank → components/respArea/DragInTheBlank}/choice.jsx +1 -1
- package/src/{plugins/respArea/inline-dropdown/index.jsx → components/respArea/InlineDropdown.jsx} +1 -1
- package/src/components/respArea/ToolbarIcon.jsx +68 -0
- package/src/extensions/component.jsx +2 -2
- package/src/extensions/custom-toolbar-wrapper.jsx +6 -7
- package/src/extensions/extended-table.js +27 -0
- package/src/extensions/index.js +76 -0
- package/src/extensions/media.js +10 -4
- package/src/extensions/responseArea.js +7 -7
- package/src/index.jsx +3 -1409
- package/src/styles/editorContainerStyles.js +203 -0
- package/src/utils/size.js +32 -0
- package/src/__tests__/editor.test.jsx +0 -363
- package/src/__tests__/serialization.test.js +0 -291
- package/src/block-tags.js +0 -17
- package/src/editor.jsx +0 -1197
- package/src/extensions/characters.js +0 -46
- package/src/old-index.jsx +0 -162
- package/src/parse-html.js +0 -8
- package/src/plugins/README.md +0 -27
- package/src/plugins/characters/index.jsx +0 -284
- package/src/plugins/characters/utils.js +0 -447
- package/src/plugins/css/index.jsx +0 -340
- package/src/plugins/customPlugin/index.jsx +0 -85
- package/src/plugins/html/icons/index.jsx +0 -19
- package/src/plugins/html/index.jsx +0 -72
- package/src/plugins/image/__tests__/__snapshots__/component.test.jsx.snap +0 -51
- package/src/plugins/image/__tests__/__snapshots__/image-toolbar-logic.test.jsx.snap +0 -27
- package/src/plugins/image/__tests__/__snapshots__/image-toolbar.test.jsx.snap +0 -44
- package/src/plugins/image/__tests__/component.test.jsx +0 -41
- package/src/plugins/image/__tests__/image-toolbar-logic.test.jsx +0 -42
- package/src/plugins/image/__tests__/image-toolbar.test.jsx +0 -11
- package/src/plugins/image/__tests__/index.test.js +0 -95
- package/src/plugins/image/__tests__/insert-image-handler.test.js +0 -113
- package/src/plugins/image/__tests__/mock-change.js +0 -15
- package/src/plugins/image/alt-dialog.jsx +0 -82
- package/src/plugins/image/component.jsx +0 -343
- package/src/plugins/image/image-toolbar.jsx +0 -100
- package/src/plugins/image/index.jsx +0 -227
- package/src/plugins/image/insert-image-handler.js +0 -79
- package/src/plugins/index.jsx +0 -377
- package/src/plugins/list/__tests__/index.test.js +0 -54
- package/src/plugins/list/index.jsx +0 -305
- package/src/plugins/math/__tests__/__snapshots__/index.test.jsx.snap +0 -48
- package/src/plugins/math/__tests__/index.test.jsx +0 -245
- package/src/plugins/math/index.jsx +0 -379
- package/src/plugins/media/__tests__/index.test.js +0 -75
- package/src/plugins/media/index.jsx +0 -325
- package/src/plugins/media/media-dialog.js +0 -624
- package/src/plugins/media/media-toolbar.jsx +0 -56
- package/src/plugins/media/media-wrapper.jsx +0 -43
- package/src/plugins/rendering/index.js +0 -31
- package/src/plugins/respArea/index.jsx +0 -299
- package/src/plugins/respArea/math-templated/index.jsx +0 -104
- package/src/plugins/respArea/utils.jsx +0 -90
- package/src/plugins/table/CustomTablePlugin.js +0 -113
- package/src/plugins/table/__tests__/__snapshots__/table-toolbar.test.jsx.snap +0 -44
- package/src/plugins/table/__tests__/index.test.jsx +0 -401
- package/src/plugins/table/__tests__/table-toolbar.test.jsx +0 -42
- package/src/plugins/table/index.jsx +0 -427
- package/src/plugins/table/table-toolbar.jsx +0 -136
- package/src/plugins/textAlign/index.jsx +0 -23
- package/src/plugins/toolbar/__tests__/__snapshots__/default-toolbar.test.jsx.snap +0 -923
- package/src/plugins/toolbar/__tests__/__snapshots__/editor-and-toolbar.test.jsx.snap +0 -20
- package/src/plugins/toolbar/__tests__/__snapshots__/toolbar-buttons.test.jsx.snap +0 -36
- package/src/plugins/toolbar/__tests__/__snapshots__/toolbar.test.jsx.snap +0 -46
- package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +0 -94
- package/src/plugins/toolbar/__tests__/editor-and-toolbar.test.jsx +0 -37
- package/src/plugins/toolbar/__tests__/toolbar-buttons.test.jsx +0 -51
- package/src/plugins/toolbar/__tests__/toolbar.test.jsx +0 -106
- package/src/plugins/toolbar/default-toolbar.jsx +0 -206
- package/src/plugins/toolbar/editor-and-toolbar.jsx +0 -257
- package/src/plugins/toolbar/index.jsx +0 -23
- package/src/plugins/toolbar/toolbar-buttons.jsx +0 -138
- package/src/plugins/toolbar/toolbar.jsx +0 -338
- package/src/plugins/utils.js +0 -31
- package/src/serialization.jsx +0 -621
- /package/src/{plugins → components}/characters/custom-popper.js +0 -0
- /package/src/{plugins/toolbar → components/common}/done-button.jsx +0 -0
- /package/src/{plugins/css/icons/index.jsx → components/icons/CssIcon.jsx} +0 -0
- /package/src/{plugins/respArea/icons/index.jsx → components/icons/RespArea.jsx} +0 -0
- /package/src/{plugins/table/icons/index.jsx → components/icons/TableIcons.jsx} +0 -0
- /package/src/{plugins/textAlign/icons/index.jsx → components/icons/TextAlign.jsx} +0 -0
- /package/src/{plugins/respArea/drag-in-the-blank/index.jsx → components/respArea/DragInTheBlank/DragInTheBlank.jsx} +0 -0
- /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,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"]}
|