@pie-lib/editable-html-tip-tap 1.0.11 → 1.0.12
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 +11 -3
- package/lib/components/TiptapContainer.js +3 -4
- package/lib/components/characters/characterUtils.js +272 -3
- package/lib/components/respArea/ExplicitConstructedResponse.js +12 -3
- package/lib/components/respArea/InlineDropdown.js +12 -3
- package/lib/extensions/component.js +12 -3
- package/lib/extensions/image.js +1 -3
- package/lib/extensions/math.js +29 -7
- package/lib/extensions/responseArea.js +1 -5
- package/lib/styles/editorContainerStyles.js +2 -59
- package/package.json +1 -1
- package/src/components/CharacterPicker.jsx +11 -1
- package/src/components/TiptapContainer.jsx +0 -3
- package/src/components/characters/characterUtils.js +321 -1
- package/src/components/respArea/ExplicitConstructedResponse.jsx +11 -2
- package/src/components/respArea/InlineDropdown.jsx +11 -2
- package/src/extensions/component.jsx +11 -2
- package/src/extensions/image.js +0 -3
- package/src/extensions/math.js +31 -19
- package/src/extensions/responseArea.js +0 -3
- package/src/styles/editorContainerStyles.js +0 -57
|
@@ -113,37 +113,7 @@ var styles = function styles(theme) {
|
|
|
113
113
|
padding: '0px',
|
|
114
114
|
overflowY: 'auto',
|
|
115
115
|
color: _renderUi.color.text(),
|
|
116
|
-
backgroundColor: _renderUi.color.background()
|
|
117
|
-
'&::before': {
|
|
118
|
-
left: '0',
|
|
119
|
-
right: '0',
|
|
120
|
-
bottom: '0',
|
|
121
|
-
height: '1px',
|
|
122
|
-
content: '""',
|
|
123
|
-
position: 'absolute',
|
|
124
|
-
transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',
|
|
125
|
-
pointerEvents: 'none',
|
|
126
|
-
backgroundColor: 'rgba(0, 0, 0, 0.42)'
|
|
127
|
-
},
|
|
128
|
-
'&::after': {
|
|
129
|
-
left: '0',
|
|
130
|
-
right: '0',
|
|
131
|
-
bottom: '0',
|
|
132
|
-
height: '1px',
|
|
133
|
-
content: '""',
|
|
134
|
-
position: 'absolute',
|
|
135
|
-
transform: 'scaleX(0)',
|
|
136
|
-
transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',
|
|
137
|
-
backgroundColor: 'rgba(0, 0, 0, 0.42)'
|
|
138
|
-
}
|
|
139
|
-
},
|
|
140
|
-
disabledUnderline: {
|
|
141
|
-
'&::before': {
|
|
142
|
-
display: 'none'
|
|
143
|
-
},
|
|
144
|
-
'&::after': {
|
|
145
|
-
display: 'none'
|
|
146
|
-
}
|
|
116
|
+
backgroundColor: _renderUi.color.background()
|
|
147
117
|
},
|
|
148
118
|
disabledScrollbar: {
|
|
149
119
|
'&::-webkit-scrollbar': {
|
|
@@ -152,33 +122,6 @@ var styles = function styles(theme) {
|
|
|
152
122
|
scrollbarWidth: 'none',
|
|
153
123
|
'-ms-overflow-style': 'none'
|
|
154
124
|
},
|
|
155
|
-
readOnly: {
|
|
156
|
-
'&::before': {
|
|
157
|
-
background: 'transparent',
|
|
158
|
-
backgroundSize: '5px 1px',
|
|
159
|
-
backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',
|
|
160
|
-
backgroundRepeat: 'repeat-x',
|
|
161
|
-
backgroundPosition: 'left top'
|
|
162
|
-
},
|
|
163
|
-
'&::after': {
|
|
164
|
-
left: '0',
|
|
165
|
-
right: '0',
|
|
166
|
-
bottom: '0',
|
|
167
|
-
height: '1px',
|
|
168
|
-
content: '""',
|
|
169
|
-
position: 'absolute',
|
|
170
|
-
transform: 'scaleX(0)',
|
|
171
|
-
transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',
|
|
172
|
-
backgroundColor: 'rgba(0, 0, 0, 0)'
|
|
173
|
-
},
|
|
174
|
-
'&:hover': {
|
|
175
|
-
'&::after': {
|
|
176
|
-
transform: 'scaleX(0)',
|
|
177
|
-
backgroundColor: theme.palette.common.black,
|
|
178
|
-
height: '2px'
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
},
|
|
182
125
|
error: {
|
|
183
126
|
border: "2px solid ".concat(theme.palette.error.main, " !important")
|
|
184
127
|
},
|
|
@@ -196,4 +139,4 @@ var styles = function styles(theme) {
|
|
|
196
139
|
|
|
197
140
|
var _default = styles;
|
|
198
141
|
exports["default"] = _default;
|
|
199
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/styles/editorContainerStyles.js"],"names":["styles","theme","root","position","padding","border","borderRadius","cursor","wordBreak","overflow","maxHeight","marginTop","margin","marginBottom","lineHeight","textWrap","fontSize","backgroundColor","color","background","fontFamily","borderLeft","paddingLeft","borderTop","tableLayout","width","borderCollapse","text","textAlign","children","editorHolder","overflowY","left","right","bottom","height","content","transition","pointerEvents","transform","disabledUnderline","display","disabledScrollbar","scrollbarWidth","readOnly","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","palette","common","black","error","main","noBorder","noPadding","toolbarOnTop"],"mappings":"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","sourcesContent":["import { color } from '@pie-lib/render-ui';\nimport { primary } from '../theme';\n\nconst styles = (theme) => ({\n  root: {\n    position: 'relative',\n    padding: '0px',\n    border: '1px solid #ccc',\n    borderRadius: '4px',\n    cursor: 'text',\n    '& [data-slate-editor=\"true\"]': {\n      wordBreak: 'break-word',\n      overflow: 'visible',\n      maxHeight: '500px',\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '5px',\n    },\n\n    '&:first-child': {\n      marginTop: 0,\n    },\n\n    '& ul, & ol': {\n      padding: '0 1rem',\n      margin: '1.25rem 1rem 1.25rem 0.4rem',\n    },\n\n    '& ul li p, & ol li p': {\n      marginTop: '0.25em',\n      marginBottom: '0.25em',\n    },\n\n    '& h1, & h2, & h3, & h4, & h5, & h6': {\n      lineHeight: 1.1,\n      marginTop: '2.5rem',\n      textWrap: 'pretty',\n    },\n\n    '& h1, & h2': {\n      marginTop: '3.5rem',\n      marginBottom: '1.5rem',\n    },\n\n    '& h1': {\n      fontSize: '1.4rem',\n    },\n\n    '& h2': {\n      fontSize: '1.2rem',\n    },\n\n    '& h3': {\n      fontSize: '1.1rem',\n    },\n\n    '& h4, & h5, & h6': {\n      fontSize: '1rem',\n    },\n\n    '& code': {\n      backgroundColor: 'var(--purple-light)',\n      borderRadius: '0.4rem',\n      color: 'var(--black)',\n      fontSize: '0.85rem',\n      padding: '0.25em 0.3em',\n    },\n\n    '& pre': {\n      background: 'var(--black)',\n      borderRadius: '0.5rem',\n      color: 'var(--white)',\n      fontFamily: \"'JetBrainsMono', monospace\",\n      margin: '1.5rem 0',\n      padding: '0.75rem 1rem',\n\n      '& code': {\n        background: 'none',\n        color: 'inherit',\n        fontSize: '0.8rem',\n        padding: 0,\n      },\n    },\n\n    '& blockquote': {\n      borderLeft: '3px solid var(--gray-3)',\n      margin: '1.5rem 0',\n      paddingLeft: '1rem',\n    },\n\n    '& hr': {\n      border: 'none',\n      borderTop: '1px solid var(--gray-2)',\n      margin: '2rem 0',\n    },\n\n    '& table': {\n      tableLayout: 'fixed',\n      width: '100%',\n      borderCollapse: 'collapse',\n      color: color.text(),\n      backgroundColor: color.background(),\n    },\n    '& table:not([border=\"1\"]) tr': {\n      borderTop: '1px solid #dfe2e5',\n    },\n    '& td, th': {\n      padding: '.6em 1em',\n      textAlign: 'center',\n    },\n    '& table:not([border=\"1\"]) td, th': {\n      border: '1px solid #dfe2e5',\n    },\n  },\n  children: {\n    padding: '10px 16px',\n  },\n  editorHolder: {\n    position: 'relative',\n    padding: '0px',\n    overflowY: 'auto',\n    color: color.text(),\n    backgroundColor: color.background(),\n    '&::before': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n      pointerEvents: 'none',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)',\n    },\n  },\n  disabledUnderline: {\n    '&::before': {\n      display: 'none',\n    },\n    '&::after': {\n      display: 'none',\n    },\n  },\n  disabledScrollbar: {\n    '&::-webkit-scrollbar': {\n      display: 'none',\n    },\n    scrollbarWidth: 'none',\n    '-ms-overflow-style': 'none',\n  },\n  readOnly: {\n    '&::before': {\n      background: 'transparent',\n      backgroundSize: '5px 1px',\n      backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n      backgroundRepeat: 'repeat-x',\n      backgroundPosition: 'left top',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0)',\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(0)',\n        backgroundColor: theme.palette.common.black,\n        height: '2px',\n      },\n    },\n  },\n  error: {\n    border: `2px solid ${theme.palette.error.main} !important`,\n  },\n  noBorder: {\n    border: 'none',\n  },\n  noPadding: {\n    padding: 0,\n  },\n  toolbarOnTop: {\n    marginTop: '45px',\n  },\n});\n\nexport default styles;\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/styles/editorContainerStyles.js"],"names":["styles","theme","root","position","padding","border","borderRadius","cursor","wordBreak","overflow","maxHeight","marginTop","margin","marginBottom","lineHeight","textWrap","fontSize","backgroundColor","color","background","fontFamily","borderLeft","paddingLeft","borderTop","tableLayout","width","borderCollapse","text","textAlign","children","editorHolder","overflowY","disabledScrollbar","display","scrollbarWidth","error","palette","main","noBorder","noPadding","toolbarOnTop"],"mappings":"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","sourcesContent":["import { color } from '@pie-lib/render-ui';\nimport { primary } from '../theme';\n\nconst styles = (theme) => ({\n  root: {\n    position: 'relative',\n    padding: '0px',\n    border: '1px solid #ccc',\n    borderRadius: '4px',\n    cursor: 'text',\n    '& [data-slate-editor=\"true\"]': {\n      wordBreak: 'break-word',\n      overflow: 'visible',\n      maxHeight: '500px',\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '5px',\n    },\n\n    '&:first-child': {\n      marginTop: 0,\n    },\n\n    '& ul, & ol': {\n      padding: '0 1rem',\n      margin: '1.25rem 1rem 1.25rem 0.4rem',\n    },\n\n    '& ul li p, & ol li p': {\n      marginTop: '0.25em',\n      marginBottom: '0.25em',\n    },\n\n    '& h1, & h2, & h3, & h4, & h5, & h6': {\n      lineHeight: 1.1,\n      marginTop: '2.5rem',\n      textWrap: 'pretty',\n    },\n\n    '& h1, & h2': {\n      marginTop: '3.5rem',\n      marginBottom: '1.5rem',\n    },\n\n    '& h1': {\n      fontSize: '1.4rem',\n    },\n\n    '& h2': {\n      fontSize: '1.2rem',\n    },\n\n    '& h3': {\n      fontSize: '1.1rem',\n    },\n\n    '& h4, & h5, & h6': {\n      fontSize: '1rem',\n    },\n\n    '& code': {\n      backgroundColor: 'var(--purple-light)',\n      borderRadius: '0.4rem',\n      color: 'var(--black)',\n      fontSize: '0.85rem',\n      padding: '0.25em 0.3em',\n    },\n\n    '& pre': {\n      background: 'var(--black)',\n      borderRadius: '0.5rem',\n      color: 'var(--white)',\n      fontFamily: \"'JetBrainsMono', monospace\",\n      margin: '1.5rem 0',\n      padding: '0.75rem 1rem',\n\n      '& code': {\n        background: 'none',\n        color: 'inherit',\n        fontSize: '0.8rem',\n        padding: 0,\n      },\n    },\n\n    '& blockquote': {\n      borderLeft: '3px solid var(--gray-3)',\n      margin: '1.5rem 0',\n      paddingLeft: '1rem',\n    },\n\n    '& hr': {\n      border: 'none',\n      borderTop: '1px solid var(--gray-2)',\n      margin: '2rem 0',\n    },\n\n    '& table': {\n      tableLayout: 'fixed',\n      width: '100%',\n      borderCollapse: 'collapse',\n      color: color.text(),\n      backgroundColor: color.background(),\n    },\n    '& table:not([border=\"1\"]) tr': {\n      borderTop: '1px solid #dfe2e5',\n    },\n    '& td, th': {\n      padding: '.6em 1em',\n      textAlign: 'center',\n    },\n    '& table:not([border=\"1\"]) td, th': {\n      border: '1px solid #dfe2e5',\n    },\n  },\n  children: {\n    padding: '10px 16px',\n  },\n  editorHolder: {\n    position: 'relative',\n    padding: '0px',\n    overflowY: 'auto',\n    color: color.text(),\n    backgroundColor: color.background(),\n  },\n  disabledScrollbar: {\n    '&::-webkit-scrollbar': {\n      display: 'none',\n    },\n    scrollbarWidth: 'none',\n    '-ms-overflow-style': 'none',\n  },\n  error: {\n    border: `2px solid ${theme.palette.error.main} !important`,\n  },\n  noBorder: {\n    border: 'none',\n  },\n  noPadding: {\n    padding: 0,\n  },\n  toolbarOnTop: {\n    marginTop: '45px',\n  },\n});\n\nexport default styles;\n"]}
|
package/package.json
CHANGED
|
@@ -73,11 +73,21 @@ export function CharacterPicker({ editor, opts, onClose }) {
|
|
|
73
73
|
if (!editor) return;
|
|
74
74
|
|
|
75
75
|
// Calculate position relative to selection
|
|
76
|
+
const editorDOM = editor.options.element;
|
|
77
|
+
const editorRect = editorDOM.getBoundingClientRect();
|
|
76
78
|
const bodyRect = document.body.getBoundingClientRect();
|
|
77
79
|
const { from } = editor.state.selection;
|
|
78
80
|
const start = editor.view.coordsAtPos(from);
|
|
81
|
+
|
|
82
|
+
let top = editorRect.top + Math.abs(bodyRect.top) + editorRect.height + 60;
|
|
83
|
+
|
|
84
|
+
if (top + containerRef.current.offsetHeight > window.outerHeight) {
|
|
85
|
+
top = top - (containerRef.current.offsetHeight + editorRect.height) - 80;
|
|
86
|
+
}
|
|
87
|
+
|
|
79
88
|
setPosition({
|
|
80
|
-
top: start.top + Math.abs(bodyRect.top) +
|
|
89
|
+
// top: start.top + Math.abs(bodyRect.top) - containerRef.current.offsetHeight - 10 + additionalTopOffset, // shift above
|
|
90
|
+
top: top,
|
|
81
91
|
left: start.left,
|
|
82
92
|
});
|
|
83
93
|
|
|
@@ -13,7 +13,6 @@ function TiptapContainer(props) {
|
|
|
13
13
|
disabled,
|
|
14
14
|
classes,
|
|
15
15
|
children,
|
|
16
|
-
disableUnderline,
|
|
17
16
|
disableScrollbar,
|
|
18
17
|
activePlugins,
|
|
19
18
|
toolbarOpts,
|
|
@@ -28,8 +27,6 @@ function TiptapContainer(props) {
|
|
|
28
27
|
} = props;
|
|
29
28
|
|
|
30
29
|
const holderNames = classNames(classes.editorHolder, {
|
|
31
|
-
[classes.readOnly]: disabled,
|
|
32
|
-
[classes.disabledUnderline]: disableUnderline,
|
|
33
30
|
[classes.disabledScrollbar]: disableScrollbar,
|
|
34
31
|
});
|
|
35
32
|
|
|
@@ -117,7 +117,327 @@ export const specialConfig = {
|
|
|
117
117
|
label: 'Ñ',
|
|
118
118
|
},
|
|
119
119
|
],
|
|
120
|
-
|
|
120
|
+
[
|
|
121
|
+
{
|
|
122
|
+
unicode: 'U+00A3',
|
|
123
|
+
description: 'POUND SIGN',
|
|
124
|
+
write: '£',
|
|
125
|
+
label: '£',
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
unicode: 'U+00AB',
|
|
129
|
+
description: 'LEFT-POINTING DOUBLE ANGLE QUOTATION MARK',
|
|
130
|
+
write: '«',
|
|
131
|
+
label: '«',
|
|
132
|
+
},
|
|
133
|
+
{
|
|
134
|
+
unicode: 'U+005E',
|
|
135
|
+
description: 'CIRCUMFLEX ACCENT',
|
|
136
|
+
write: '^',
|
|
137
|
+
label: '^',
|
|
138
|
+
extraProps: { style: { gridRow: 'span 2' } },
|
|
139
|
+
},
|
|
140
|
+
{
|
|
141
|
+
unicode: 'U+00E2',
|
|
142
|
+
description: 'LATIN SMALL LETTER A WITH CIRCUMFLEX',
|
|
143
|
+
write: 'â',
|
|
144
|
+
label: 'â',
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
unicode: 'U+00EA',
|
|
148
|
+
description: 'LATIN SMALL LETTER E WITH CIRCUMFLEX',
|
|
149
|
+
write: 'ê',
|
|
150
|
+
label: 'ê',
|
|
151
|
+
},
|
|
152
|
+
{
|
|
153
|
+
unicode: 'U+00EE',
|
|
154
|
+
description: 'LATIN SMALL LETTER I WITH CIRCUMFLEX',
|
|
155
|
+
write: 'î',
|
|
156
|
+
label: 'î',
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
unicode: 'U+00F4',
|
|
160
|
+
description: 'LATIN SMALL LETTER O WITH CIRCUMFLEX',
|
|
161
|
+
write: 'ô',
|
|
162
|
+
label: 'ô',
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
unicode: 'U+00FB',
|
|
166
|
+
description: 'LATIN SMALL LETTER U WITH CIRCUMFLEX',
|
|
167
|
+
write: 'û',
|
|
168
|
+
label: 'û',
|
|
169
|
+
},
|
|
170
|
+
{
|
|
171
|
+
unicode: 'U+00E7',
|
|
172
|
+
description: 'LATIN SMALL LETTER C WITH CEDILLA',
|
|
173
|
+
write: 'ç',
|
|
174
|
+
label: 'ç',
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
[
|
|
178
|
+
{
|
|
179
|
+
unicode: 'U+00A5',
|
|
180
|
+
description: 'YEN SIGN',
|
|
181
|
+
write: '¥',
|
|
182
|
+
label: '¥',
|
|
183
|
+
},
|
|
184
|
+
{
|
|
185
|
+
unicode: 'U+00BB',
|
|
186
|
+
description: 'RIGHT-POINTING DOUBLE ANGLE QUOTATION MARK',
|
|
187
|
+
write: '»',
|
|
188
|
+
label: '»',
|
|
189
|
+
},
|
|
190
|
+
{
|
|
191
|
+
unicode: 'U+00C2',
|
|
192
|
+
description: 'LATIN CAPITAL LETTER A WITH CIRCUMFLEX',
|
|
193
|
+
write: 'Â',
|
|
194
|
+
label: 'Â',
|
|
195
|
+
},
|
|
196
|
+
{
|
|
197
|
+
unicode: 'U+00CA',
|
|
198
|
+
description: 'LATIN CAPITAL LETTER E WITH CIRCUMFLEX',
|
|
199
|
+
write: 'Ê',
|
|
200
|
+
label: 'Ê',
|
|
201
|
+
},
|
|
202
|
+
{
|
|
203
|
+
unicode: 'U+00CE',
|
|
204
|
+
description: 'LATIN CAPITAL LETTER I WITH CIRCUMFLEX',
|
|
205
|
+
write: 'Î',
|
|
206
|
+
label: 'Î',
|
|
207
|
+
},
|
|
208
|
+
{
|
|
209
|
+
unicode: 'U+00D4',
|
|
210
|
+
description: 'LATIN CAPITAL LETTER O WITH CIRCUMFLEX',
|
|
211
|
+
write: 'Ô',
|
|
212
|
+
label: 'Ô',
|
|
213
|
+
},
|
|
214
|
+
{
|
|
215
|
+
unicode: 'U+00DB',
|
|
216
|
+
description: 'LATIN CAPITAL LETTER U WITH CIRCUMFLEX',
|
|
217
|
+
write: 'Û',
|
|
218
|
+
label: 'Û',
|
|
219
|
+
},
|
|
220
|
+
{
|
|
221
|
+
unicode: 'U+00C7',
|
|
222
|
+
description: 'LATIN CAPITAL LETTER C WITH CEDILLA',
|
|
223
|
+
write: 'Ç',
|
|
224
|
+
label: 'Ç',
|
|
225
|
+
},
|
|
226
|
+
],
|
|
227
|
+
[
|
|
228
|
+
{
|
|
229
|
+
unicode: 'U+200A',
|
|
230
|
+
description: 'HAIR SPACE',
|
|
231
|
+
write: String.fromCodePoint('0x200A'),
|
|
232
|
+
label: ' ',
|
|
233
|
+
},
|
|
234
|
+
{
|
|
235
|
+
unicode: 'U+00A7',
|
|
236
|
+
description: 'SECTION SIGN',
|
|
237
|
+
write: '§',
|
|
238
|
+
label: '§',
|
|
239
|
+
},
|
|
240
|
+
{
|
|
241
|
+
unicode: 'U+00A8',
|
|
242
|
+
description: 'DIAERESIS',
|
|
243
|
+
write: '¨',
|
|
244
|
+
label: '¨',
|
|
245
|
+
extraProps: { style: { gridRow: 'span 2' } },
|
|
246
|
+
},
|
|
247
|
+
{
|
|
248
|
+
unicode: 'U+00E4',
|
|
249
|
+
description: 'LATIN SMALL LETTER A WITH DIAERESIS',
|
|
250
|
+
write: 'ä',
|
|
251
|
+
label: 'ä',
|
|
252
|
+
},
|
|
253
|
+
{
|
|
254
|
+
unicode: 'U+00EB',
|
|
255
|
+
description: 'LATIN SMALL LETTER E WITH DIAERESIS',
|
|
256
|
+
write: 'ë',
|
|
257
|
+
label: 'ë',
|
|
258
|
+
},
|
|
259
|
+
{
|
|
260
|
+
unicode: 'U+00EF',
|
|
261
|
+
description: 'LATIN SMALL LETTER I WITH DIAERESIS',
|
|
262
|
+
write: 'ï',
|
|
263
|
+
label: 'ï',
|
|
264
|
+
},
|
|
265
|
+
{
|
|
266
|
+
unicode: 'U+00F6',
|
|
267
|
+
description: 'LATIN SMALL LETTER O WITH DIAERESIS',
|
|
268
|
+
write: 'ö',
|
|
269
|
+
label: 'ö',
|
|
270
|
+
},
|
|
271
|
+
{
|
|
272
|
+
unicode: 'U+00FC',
|
|
273
|
+
description: 'LATIN SMALL LETTER U WITH DIAERESIS',
|
|
274
|
+
write: 'ü',
|
|
275
|
+
label: 'ü',
|
|
276
|
+
},
|
|
277
|
+
{
|
|
278
|
+
unicode: 'U+00DF',
|
|
279
|
+
description: 'LATIN SMALL LETTER SHARP S',
|
|
280
|
+
write: 'ß',
|
|
281
|
+
label: 'ß',
|
|
282
|
+
},
|
|
283
|
+
],
|
|
284
|
+
[
|
|
285
|
+
{
|
|
286
|
+
unicode: 'U+2009',
|
|
287
|
+
description: 'THIN SPACE',
|
|
288
|
+
write: String.fromCodePoint('0x2009'),
|
|
289
|
+
label: ' ',
|
|
290
|
+
},
|
|
291
|
+
{
|
|
292
|
+
unicode: 'U+2026',
|
|
293
|
+
description: 'HORIZONTAL ELLIPSIS',
|
|
294
|
+
write: '…',
|
|
295
|
+
label: '…',
|
|
296
|
+
},
|
|
297
|
+
{
|
|
298
|
+
unicode: 'U+00C4',
|
|
299
|
+
description: 'LATIN CAPITAL LETTER A WITH DIAERESIS',
|
|
300
|
+
write: 'Ä',
|
|
301
|
+
label: 'Ä',
|
|
302
|
+
},
|
|
303
|
+
{
|
|
304
|
+
unicode: 'U+00CB',
|
|
305
|
+
description: 'LATIN CAPITAL LETTER E WITH DIAERESIS',
|
|
306
|
+
write: 'Ë',
|
|
307
|
+
label: 'Ë',
|
|
308
|
+
},
|
|
309
|
+
{
|
|
310
|
+
unicode: 'U+00CF',
|
|
311
|
+
description: 'LATIN CAPITAL LETTER I WITH DIAERESIS',
|
|
312
|
+
write: 'Ï',
|
|
313
|
+
label: 'Ï',
|
|
314
|
+
},
|
|
315
|
+
{
|
|
316
|
+
unicode: 'U+00D6',
|
|
317
|
+
description: 'LATIN CAPITAL LETTER O WITH DIAERESIS',
|
|
318
|
+
write: 'Ö',
|
|
319
|
+
label: 'Ö',
|
|
320
|
+
},
|
|
321
|
+
{
|
|
322
|
+
unicode: 'U+00DC',
|
|
323
|
+
description: 'LATIN CAPITAL LETTER U WITH DIAERESIS',
|
|
324
|
+
write: 'Ü',
|
|
325
|
+
label: 'Ü',
|
|
326
|
+
},
|
|
327
|
+
{
|
|
328
|
+
unicode: 'U+2212',
|
|
329
|
+
description: 'MINUS SIGN',
|
|
330
|
+
write: '−',
|
|
331
|
+
label: '−',
|
|
332
|
+
},
|
|
333
|
+
],
|
|
334
|
+
[
|
|
335
|
+
{
|
|
336
|
+
unicode: 'U+00A0',
|
|
337
|
+
description: 'NO-BREAK SPACE',
|
|
338
|
+
write: String.fromCodePoint('0x00A0'),
|
|
339
|
+
label: ' ',
|
|
340
|
+
},
|
|
341
|
+
{
|
|
342
|
+
unicode: 'U+2022',
|
|
343
|
+
description: 'BULLET',
|
|
344
|
+
write: '•',
|
|
345
|
+
label: '•',
|
|
346
|
+
},
|
|
347
|
+
{
|
|
348
|
+
unicode: 'U+0060',
|
|
349
|
+
description: 'GRAVE ACCENT',
|
|
350
|
+
write: '`',
|
|
351
|
+
label: '`',
|
|
352
|
+
extraProps: { style: { gridRow: 'span 2' } },
|
|
353
|
+
},
|
|
354
|
+
{
|
|
355
|
+
unicode: 'U+00E0',
|
|
356
|
+
description: 'LATIN SMALL LETTER A WITH GRAVE',
|
|
357
|
+
write: 'à',
|
|
358
|
+
label: 'à',
|
|
359
|
+
},
|
|
360
|
+
{
|
|
361
|
+
unicode: 'U+00E8',
|
|
362
|
+
description: 'LATIN SMALL LETTER E WITH GRAVE',
|
|
363
|
+
write: 'è',
|
|
364
|
+
label: 'è',
|
|
365
|
+
},
|
|
366
|
+
{
|
|
367
|
+
unicode: 'U+00EC',
|
|
368
|
+
description: 'LATIN SMALL LETTER I WITH GRAVE',
|
|
369
|
+
write: 'ì',
|
|
370
|
+
label: 'ì',
|
|
371
|
+
},
|
|
372
|
+
{
|
|
373
|
+
unicode: 'U+00F2',
|
|
374
|
+
description: 'LATIN SMALL LETTER O WITH GRAVE',
|
|
375
|
+
write: 'ò',
|
|
376
|
+
label: 'ò',
|
|
377
|
+
},
|
|
378
|
+
{
|
|
379
|
+
unicode: 'U+00F9',
|
|
380
|
+
description: 'LATIN SMALL LETTER U WITH GRAVE',
|
|
381
|
+
write: 'ù',
|
|
382
|
+
label: 'ù',
|
|
383
|
+
},
|
|
384
|
+
{
|
|
385
|
+
unicode: 'U+2013',
|
|
386
|
+
description: 'EN DASH',
|
|
387
|
+
write: '–',
|
|
388
|
+
label: '–',
|
|
389
|
+
},
|
|
390
|
+
],
|
|
391
|
+
[
|
|
392
|
+
{
|
|
393
|
+
unicode: 'U+2003',
|
|
394
|
+
description: 'EM SPACE',
|
|
395
|
+
write: String.fromCodePoint('0x2003'),
|
|
396
|
+
label: ' ',
|
|
397
|
+
},
|
|
398
|
+
{
|
|
399
|
+
unicode: 'U+25E6',
|
|
400
|
+
description: 'WHITE BULLET',
|
|
401
|
+
write: '◦',
|
|
402
|
+
label: '◦',
|
|
403
|
+
},
|
|
404
|
+
{
|
|
405
|
+
unicode: 'U+00C0',
|
|
406
|
+
description: 'LATIN CAPITAL LETTER A WITH GRAVE',
|
|
407
|
+
write: 'À',
|
|
408
|
+
label: 'À',
|
|
409
|
+
},
|
|
410
|
+
{
|
|
411
|
+
unicode: 'U+00C8',
|
|
412
|
+
description: 'LATIN CAPITAL LETTER E WITH GRAVE',
|
|
413
|
+
write: 'È',
|
|
414
|
+
label: 'È',
|
|
415
|
+
},
|
|
416
|
+
{
|
|
417
|
+
unicode: 'U+00CC',
|
|
418
|
+
description: 'LATIN CAPITAL LETTER I WITH GRAVE',
|
|
419
|
+
write: 'Ì',
|
|
420
|
+
label: 'Ì',
|
|
421
|
+
},
|
|
422
|
+
{
|
|
423
|
+
unicode: 'U+00D2',
|
|
424
|
+
description: 'LATIN CAPITAL LETTER O WITH GRAVE',
|
|
425
|
+
write: 'Ò',
|
|
426
|
+
label: 'Ò',
|
|
427
|
+
},
|
|
428
|
+
{
|
|
429
|
+
unicode: 'U+00D9',
|
|
430
|
+
description: 'LATIN CAPITAL LETTER U WITH GRAVE',
|
|
431
|
+
write: 'Ù',
|
|
432
|
+
label: 'Ù',
|
|
433
|
+
},
|
|
434
|
+
{
|
|
435
|
+
unicode: 'U+2014',
|
|
436
|
+
description: 'EM DASH',
|
|
437
|
+
write: '—',
|
|
438
|
+
label: '—',
|
|
439
|
+
},
|
|
440
|
+
],
|
|
121
441
|
],
|
|
122
442
|
};
|
|
123
443
|
|
|
@@ -18,8 +18,17 @@ const ExplicitConstructedResponse = (props) => {
|
|
|
18
18
|
};
|
|
19
19
|
|
|
20
20
|
useEffect(() => {
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
const { selection } = editor.state;
|
|
22
|
+
const onlyThisNodeSelected = selection.from + node.nodeSize === selection.to;
|
|
23
|
+
|
|
24
|
+
if (selected) {
|
|
25
|
+
if (onlyThisNodeSelected) {
|
|
26
|
+
setShowToolbar(selected);
|
|
27
|
+
}
|
|
28
|
+
} else {
|
|
29
|
+
setShowToolbar(selected);
|
|
30
|
+
}
|
|
31
|
+
}, [editor, node, selected]);
|
|
23
32
|
|
|
24
33
|
useEffect(() => {
|
|
25
34
|
const handleClickOutside = (event) => {
|
|
@@ -15,8 +15,17 @@ const InlineDropdown = (props) => {
|
|
|
15
15
|
const InlineDropdownToolbar = options.respAreaToolbar(node, editor, () => {});
|
|
16
16
|
|
|
17
17
|
useEffect(() => {
|
|
18
|
-
|
|
19
|
-
|
|
18
|
+
const { selection } = editor.state;
|
|
19
|
+
const onlyThisNodeSelected = selection.from + node.nodeSize === selection.to;
|
|
20
|
+
|
|
21
|
+
if (selected) {
|
|
22
|
+
if (onlyThisNodeSelected) {
|
|
23
|
+
setShowToolbar(selected);
|
|
24
|
+
}
|
|
25
|
+
} else {
|
|
26
|
+
setShowToolbar(selected);
|
|
27
|
+
}
|
|
28
|
+
}, [editor, node, selected]);
|
|
20
29
|
|
|
21
30
|
useEffect(() => {
|
|
22
31
|
const handleClickOutside = (event) => {
|
|
@@ -56,8 +56,17 @@ function ImageComponent(props) {
|
|
|
56
56
|
}, [editor, node.attrs, getPercentFromWidth]);
|
|
57
57
|
|
|
58
58
|
useEffect(() => {
|
|
59
|
-
|
|
60
|
-
|
|
59
|
+
const { selection } = editor.state;
|
|
60
|
+
const onlyThisNodeSelected = selection.from + node.nodeSize === selection.to;
|
|
61
|
+
|
|
62
|
+
if (selected) {
|
|
63
|
+
if (onlyThisNodeSelected) {
|
|
64
|
+
setShowToolbar(selected);
|
|
65
|
+
}
|
|
66
|
+
} else {
|
|
67
|
+
setShowToolbar(selected);
|
|
68
|
+
}
|
|
69
|
+
}, [editor, node, selected]);
|
|
61
70
|
|
|
62
71
|
useEffect(() => {
|
|
63
72
|
options.imageHandling.insertImageRequested(node, (finish) => new InsertImageHandler(editor, node, finish));
|
package/src/extensions/image.js
CHANGED
|
@@ -3,8 +3,6 @@ import { ReactNodeViewRenderer } from '@tiptap/react';
|
|
|
3
3
|
import React from 'react';
|
|
4
4
|
import ImageComponent from './component';
|
|
5
5
|
|
|
6
|
-
// ---- Tiptap Extension ---- //
|
|
7
|
-
|
|
8
6
|
export const ImageUploadNode = Node.create({
|
|
9
7
|
name: 'imageUploadNode',
|
|
10
8
|
|
|
@@ -34,7 +32,6 @@ export const ImageUploadNode = Node.create({
|
|
|
34
32
|
];
|
|
35
33
|
},
|
|
36
34
|
|
|
37
|
-
// ✅ No `0` here!
|
|
38
35
|
renderHTML({ HTMLAttributes }) {
|
|
39
36
|
return ['img', mergeAttributes(HTMLAttributes, { 'data-type': 'image-upload-node' })];
|
|
40
37
|
},
|
package/src/extensions/math.js
CHANGED
|
@@ -4,6 +4,8 @@ import { NodeViewWrapper, ReactRenderer, ReactNodeViewRenderer } from '@tiptap/r
|
|
|
4
4
|
import { Plugin, PluginKey, NodeSelection, TextSelection } from 'prosemirror-state';
|
|
5
5
|
import { MathPreview, MathToolbar } from '@pie-lib/math-toolbar';
|
|
6
6
|
import { wrapMath, mmlToLatex, renderMath } from '@pie-lib/math-rendering';
|
|
7
|
+
import ReactDOM from 'react-dom';
|
|
8
|
+
import CustomPopper from '../components/characters/custom-popper';
|
|
7
9
|
|
|
8
10
|
const ensureTextAfterMathPluginKey = new PluginKey('ensureTextAfterMath');
|
|
9
11
|
|
|
@@ -118,7 +120,6 @@ export const MathNode = Node.create({
|
|
|
118
120
|
addCommands() {
|
|
119
121
|
return {
|
|
120
122
|
insertMath: (latex = '') => ({ tr, editor, dispatch }) => {
|
|
121
|
-
// 2) Now the editor.view.state reflects the insertion
|
|
122
123
|
const { state } = editor.view;
|
|
123
124
|
const node = state.schema.nodes.math.create({
|
|
124
125
|
latex,
|
|
@@ -172,6 +173,7 @@ export const MathNodeView = (props) => {
|
|
|
172
173
|
const { node, updateAttributes, editor, selected, options } = props;
|
|
173
174
|
const [showToolbar, setShowToolbar] = useState(selected);
|
|
174
175
|
const toolbarRef = useRef(null);
|
|
176
|
+
const [position, setPosition] = useState({ top: 0, left: 0 });
|
|
175
177
|
|
|
176
178
|
const latex = node.attrs.latex || '';
|
|
177
179
|
|
|
@@ -186,6 +188,15 @@ export const MathNodeView = (props) => {
|
|
|
186
188
|
}, [showToolbar]);
|
|
187
189
|
|
|
188
190
|
useEffect(() => {
|
|
191
|
+
// Calculate position relative to selection
|
|
192
|
+
const bodyRect = document.body.getBoundingClientRect();
|
|
193
|
+
const { from } = editor.state.selection;
|
|
194
|
+
const start = editor.view.coordsAtPos(from);
|
|
195
|
+
setPosition({
|
|
196
|
+
top: start.top + Math.abs(bodyRect.top) + 40, // shift above
|
|
197
|
+
left: start.left,
|
|
198
|
+
});
|
|
199
|
+
|
|
189
200
|
const handleClickOutside = (event) => {
|
|
190
201
|
if (
|
|
191
202
|
toolbarRef.current &&
|
|
@@ -203,7 +214,7 @@ export const MathNodeView = (props) => {
|
|
|
203
214
|
}
|
|
204
215
|
|
|
205
216
|
return () => document.removeEventListener('mousedown', handleClickOutside);
|
|
206
|
-
}, [showToolbar]);
|
|
217
|
+
}, [editor, showToolbar]);
|
|
207
218
|
|
|
208
219
|
const handleChange = (newLatex) => {
|
|
209
220
|
updateAttributes({ latex: newLatex });
|
|
@@ -237,23 +248,24 @@ export const MathNodeView = (props) => {
|
|
|
237
248
|
<div onClick={() => setShowToolbar(true)} contentEditable={false}>
|
|
238
249
|
<MathPreview latex={latex} />
|
|
239
250
|
</div>
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
251
|
+
{showToolbar &&
|
|
252
|
+
ReactDOM.createPortal(
|
|
253
|
+
<div
|
|
254
|
+
ref={toolbarRef}
|
|
255
|
+
style={{
|
|
256
|
+
position: 'absolute',
|
|
257
|
+
top: `${position.top}px`,
|
|
258
|
+
left: `${position.left}px`,
|
|
259
|
+
zIndex: 20,
|
|
260
|
+
background: 'var(--editable-html-toolbar-bg, #efefef)',
|
|
261
|
+
boxShadow:
|
|
262
|
+
'0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',
|
|
263
|
+
}}
|
|
264
|
+
>
|
|
265
|
+
<MathToolbar latex={latex} autoFocus onChange={handleChange} onDone={handleDone} keypadMode="basic" />
|
|
266
|
+
</div>,
|
|
267
|
+
document.body,
|
|
268
|
+
)}
|
|
257
269
|
</NodeViewWrapper>
|
|
258
270
|
);
|
|
259
271
|
};
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
// InlineNodes.js
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import { Node, ReactNodeViewRenderer, ReactRenderer } from '@tiptap/react';
|
|
4
3
|
import ExplicitConstructedResponse from '../components/respArea/ExplicitConstructedResponse';
|
|
5
4
|
import DragInTheBlank from '../components/respArea/DragInTheBlank/DragInTheBlank';
|
|
6
5
|
import InlineDropdown from '../components/respArea/InlineDropdown';
|
|
7
6
|
import { Extension } from '@tiptap/core';
|
|
8
|
-
import { MathToolbar } from '@pie-lib/math-toolbar';
|
|
9
|
-
import tippy from 'tippy.js';
|
|
10
7
|
|
|
11
8
|
export const ResponseAreaExtension = Extension.create({
|
|
12
9
|
name: 'responseArea',
|