@pie-lib/mask-markup 1.15.0-beta.0 → 1.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/CHANGELOG.json +1 -871
  2. package/CHANGELOG.md +115 -20
  3. package/package.json +8 -5
  4. package/src/choices/choice.jsx +1 -1
  5. package/src/components/__tests__/__snapshots__/dropdown.test.js.snap +15 -12
  6. package/src/components/__tests__/blank.test.js +1 -1
  7. package/src/components/blank.jsx +1 -1
  8. package/src/components/correct-input.jsx +1 -1
  9. package/src/components/dropdown.jsx +118 -23
  10. package/src/constructed-response.jsx +1 -1
  11. package/src/serialization.js +1 -1
  12. package/lib/__tests__/drag-in-the-blank.test.js +0 -71
  13. package/lib/__tests__/index.test.js +0 -50
  14. package/lib/__tests__/mask.test.js +0 -149
  15. package/lib/__tests__/serialization.test.js +0 -45
  16. package/lib/__tests__/utils.js +0 -17
  17. package/lib/__tests__/with-mask.test.js +0 -65
  18. package/lib/choices/__tests__/index.test.js +0 -85
  19. package/lib/choices/choice.js +0 -221
  20. package/lib/choices/index.js +0 -135
  21. package/lib/componentize.js +0 -25
  22. package/lib/components/__tests__/blank.test.js +0 -234
  23. package/lib/components/__tests__/correct-input.test.js +0 -63
  24. package/lib/components/__tests__/dropdown.test.js +0 -70
  25. package/lib/components/__tests__/input.test.js +0 -64
  26. package/lib/components/blank.js +0 -415
  27. package/lib/components/correct-input.js +0 -118
  28. package/lib/components/dropdown.js +0 -349
  29. package/lib/components/input.js +0 -57
  30. package/lib/constructed-response.js +0 -116
  31. package/lib/customizable.js +0 -48
  32. package/lib/drag-in-the-blank.js +0 -217
  33. package/lib/index.js +0 -62
  34. package/lib/inline-dropdown.js +0 -48
  35. package/lib/mask.js +0 -254
  36. package/lib/serialization.js +0 -207
  37. package/lib/with-mask.js +0 -125
@@ -5,12 +5,14 @@ import InputLabel from '@material-ui/core/InputLabel';
5
5
  import Menu from '@material-ui/core/Menu';
6
6
  import MenuItem from '@material-ui/core/MenuItem';
7
7
  import ArrowDropDownIcon from '@material-ui/icons/ArrowDropDown';
8
+ import ArrowDropUpIcon from '@material-ui/icons/ArrowDropUp';
8
9
  import Close from '@material-ui/icons/Close';
9
10
  import Check from '@material-ui/icons/Check';
10
11
  import { withStyles } from '@material-ui/core/styles';
11
12
  import classNames from 'classnames';
13
+ import isEqual from 'lodash/isEqual';
12
14
 
13
- import { color } from '@pie-lib/render-ui';
15
+ import { color } from '../../../render-ui/src/index';
14
16
  import { renderMath } from '@pie-lib/math-rendering';
15
17
 
16
18
  class Dropdown extends React.Component {
@@ -23,6 +25,8 @@ class Dropdown extends React.Component {
23
25
  correct: PropTypes.bool,
24
26
  choices: PropTypes.arrayOf(PropTypes.shape({ value: PropTypes.string, label: PropTypes.string })),
25
27
  showCorrectAnswer: PropTypes.bool,
28
+ singleQuery: PropTypes.bool,
29
+ correctValue: PropTypes.string,
26
30
  };
27
31
 
28
32
  constructor(props) {
@@ -31,27 +35,73 @@ class Dropdown extends React.Component {
31
35
  this.state = {
32
36
  anchorEl: null,
33
37
  highlightedOptionId: null,
38
+ menuWidth: null,
39
+ previewValue: null,
34
40
  };
35
-
41
+ this.hiddenRef = React.createRef();
42
+ this.buttonRef = React.createRef();
43
+ this.previewRef = React.createRef();
36
44
  this.elementRefs = [];
37
45
  }
38
46
 
39
- componentDidUpdate() {
40
- this.elementRefs.forEach((ref) => {
41
- if (ref) {
42
- renderMath(ref);
47
+ componentDidMount() {
48
+ // measure hidden menu width once
49
+ if (this.hiddenRef.current && this.state.menuWidth === null) {
50
+ this.setState({ menuWidth: this.hiddenRef.current.clientWidth });
51
+ }
52
+ }
53
+
54
+ componentDidUpdate(prevProps, prevState) {
55
+ const hiddenEl = this.hiddenRef.current;
56
+
57
+ const dropdownJustOpened = !prevState.anchorEl && this.state.anchorEl;
58
+ if (dropdownJustOpened) {
59
+ this.elementRefs.forEach((ref) => {
60
+ if (!ref) return;
61
+
62
+ const containsLatex = ref.querySelector('[data-latex], [data-raw]');
63
+ const hasMathJax = ref.querySelector('mjx-container');
64
+ const mathHandled = ref.querySelector('[data-math-handled="true"]');
65
+
66
+ if (containsLatex && (!mathHandled || !hasMathJax)) {
67
+ renderMath(ref);
68
+ }
69
+ });
70
+ }
71
+
72
+ if (hiddenEl) {
73
+ const newWidth = hiddenEl.clientWidth;
74
+ if (newWidth !== this.state.menuWidth) {
75
+ this.elementRefs.forEach((ref) => {
76
+ if (ref) renderMath(ref);
77
+ });
78
+
79
+ renderMath(hiddenEl);
80
+ this.setState({ menuWidth: newWidth });
43
81
  }
44
- });
82
+ }
45
83
  }
46
84
 
47
85
  handleClick = (event) => this.setState({ anchorEl: event.currentTarget });
48
86
 
49
- handleClose = () => this.setState({ anchorEl: null });
87
+ handleClose = () => {
88
+ const { value } = this.props;
89
+ this.setState({ anchorEl: null, previewValue: null, highlightedOptionId: null });
90
+ // clear displayed preview if no selection
91
+ if (!value && this.previewRef.current) {
92
+ this.previewRef.current.innerHTML = '';
93
+ }
94
+ };
50
95
 
51
96
  handleHighlight = (index) => {
52
97
  const highlightedOptionId = `dropdown-option-${this.props.id}-${index}`;
53
98
 
54
- this.setState({ highlightedOptionId });
99
+ // preview on hover if nothing selected
100
+ const stateUpdate = { highlightedOptionId };
101
+ if (!this.props.value) {
102
+ stateUpdate.previewValue = this.props.choices[index].value;
103
+ }
104
+ this.setState(stateUpdate);
55
105
  };
56
106
 
57
107
  handleSelect = (value, index) => {
@@ -60,6 +110,25 @@ class Dropdown extends React.Component {
60
110
  this.handleClose();
61
111
  };
62
112
 
113
+ handleHover = (index) => {
114
+ const selectedValue = this.props.value;
115
+
116
+ if (selectedValue) return;
117
+
118
+ const highlightedOptionId = `dropdown-option-${this.props.id}-${index}`;
119
+ const previewValue = this.state.previewValue;
120
+
121
+ this.setState({ highlightedOptionId, previewValue }, () => {
122
+ // On hover, preview the math-rendered content inside the button if no value is selected.
123
+ const ref = this.elementRefs[index];
124
+ const preview = this.previewRef.current;
125
+
126
+ if (ref && preview) {
127
+ preview.innerHTML = ref.innerHTML;
128
+ }
129
+ });
130
+ };
131
+
63
132
  getLabel(choices, value) {
64
133
  const found = (choices || []).find((choice) => choice.value === value);
65
134
 
@@ -68,7 +137,6 @@ class Dropdown extends React.Component {
68
137
 
69
138
  render() {
70
139
  const { classes, id, correct, disabled, value, choices, showCorrectAnswer, singleQuery, correctValue } = this.props;
71
-
72
140
  const { anchorEl } = this.state;
73
141
  const open = Boolean(anchorEl);
74
142
  const buttonId = `dropdown-button-${id}`;
@@ -90,7 +158,6 @@ class Dropdown extends React.Component {
90
158
  const labelText = singleQuery ? 'Query' : `Query ${incrementedId}`;
91
159
 
92
160
  // Changed from Select to Button for dropdown to enhance accessibility. This modification offers explicit control over aria attributes and focuses management, ensuring the dropdown is compliant with accessibility standards. The use of Button and Menu components allows for better handling of keyboard interactions and provides accessible labels and menus, aligning with WCAG guidelines and improving usability for assistive technology users.
93
-
94
161
  let correctnessIcon = null;
95
162
  if (disabled && correct !== undefined) {
96
163
  correctnessIcon =
@@ -103,10 +170,23 @@ class Dropdown extends React.Component {
103
170
 
104
171
  return (
105
172
  <>
173
+ <div ref={this.hiddenRef} style={{ position: 'absolute', visibility: 'hidden', top: 0, left: 0 }}>
174
+ {(choices || []).map((c, index) => (
175
+ <MenuItem key={index} classes={{ root: classes.menuRoot, selected: classes.selected }}>
176
+ <span className={classes.label} dangerouslySetInnerHTML={{ __html: c.label }} />
177
+ </MenuItem>
178
+ ))}
179
+ </div>
106
180
  <InputLabel className={classes.srOnly} id={labelId}>
107
181
  {labelText}
108
182
  </InputLabel>
109
183
  <Button
184
+ ref={this.buttonRef}
185
+ style={{
186
+ ...(this.state.menuWidth && { minWidth: `calc(${this.state.menuWidth}px + 8px)` }),
187
+ borderWidth: open ? '2px' : '1px',
188
+ transition: 'border-width 0.2s ease-in-out',
189
+ }}
110
190
  aria-controls={open ? menuId : undefined}
111
191
  aria-haspopup="listbox"
112
192
  aria-expanded={open ? 'true' : undefined}
@@ -125,12 +205,17 @@ class Dropdown extends React.Component {
125
205
  {correctnessIcon}
126
206
  <span
127
207
  id={valueDisplayId}
208
+ ref={this.previewRef}
128
209
  className={classes.label}
129
210
  dangerouslySetInnerHTML={{
130
- __html: correctValue ? correctValue : this.getLabel(choices, value) ? this.getLabel(choices, value) : '',
211
+ __html: correctValue
212
+ ? correctValue
213
+ : open && this.state.previewValue
214
+ ? this.getLabel(choices, this.state.previewValue)
215
+ : this.getLabel(choices, value) || '',
131
216
  }}
132
217
  />
133
- <ArrowDropDownIcon />
218
+ {open ? <ArrowDropUpIcon /> : <ArrowDropDownIcon />}
134
219
  </Button>
135
220
  <Menu
136
221
  id={menuId}
@@ -139,9 +224,14 @@ class Dropdown extends React.Component {
139
224
  keepMounted
140
225
  open={open}
141
226
  onClose={this.handleClose}
227
+ getContentAnchorEl={null}
228
+ anchorOrigin={{ vertical: 'bottom', horizontal: 'left' }}
229
+ transformOrigin={{ vertical: 'top', horizontal: 'left' }}
230
+ PaperProps={this.state.menuWidth ? { style: { minWidth: this.state.menuWidth, padding: '4px' } } : undefined}
142
231
  MenuListProps={{
143
232
  'aria-labelledby': buttonId,
144
233
  role: 'listbox',
234
+ disablePadding: true,
145
235
  }}
146
236
  >
147
237
  {(choices || []).map((c, index) => {
@@ -156,6 +246,7 @@ class Dropdown extends React.Component {
156
246
  onClick={() => this.handleSelect(c.value, index)}
157
247
  role="option"
158
248
  aria-selected={this.state.highlightedOptionId === optionId ? 'true' : undefined}
249
+ onMouseOver={() => this.handleHover(index)}
159
250
  >
160
251
  <span
161
252
  ref={(ref) => (this.elementRefs[index] = ref)}
@@ -163,7 +254,7 @@ class Dropdown extends React.Component {
163
254
  dangerouslySetInnerHTML={{ __html: c.label }}
164
255
  />
165
256
  <span
166
- className={classes.label}
257
+ className={classes.selectedIndicator}
167
258
  dangerouslySetInnerHTML={{ __html: c.value === value ? ' &check;' : '' }}
168
259
  />
169
260
  </MenuItem>
@@ -178,7 +269,7 @@ class Dropdown extends React.Component {
178
269
  const styles = () => ({
179
270
  root: {
180
271
  color: color.text(),
181
- border: `1px solid ${color.text()}`,
272
+ border: `1px solid ${color.borderGray()}`,
182
273
  borderRadius: '4px',
183
274
  justifyContent: 'space-between',
184
275
  backgroundColor: color.background(),
@@ -220,13 +311,17 @@ const styles = () => ({
220
311
  border: `1px solid ${color.text()}`,
221
312
  borderColor: 'initial',
222
313
  },
314
+ // remove default padding on the inner list
315
+ '& .MuiList-root': {
316
+ padding: 0,
317
+ },
223
318
  },
224
319
  selected: {
225
320
  color: `${color.text()} !important`,
226
321
  backgroundColor: `${color.background()} !important`,
227
322
  '&:hover': {
228
323
  color: color.text(),
229
- backgroundColor: `${color.secondaryLight()} !important`,
324
+ backgroundColor: `${color.dropdownBackground()} !important`,
230
325
  },
231
326
  },
232
327
  menuRoot: {
@@ -238,20 +333,20 @@ const styles = () => ({
238
333
  },
239
334
  '&:hover': {
240
335
  color: color.text(),
241
- backgroundColor: color.secondaryLight(),
336
+ backgroundColor: color.dropdownBackground(),
242
337
  },
243
338
  boxSizing: 'border-box',
244
339
  padding: '25px',
245
- '&:first-of-type': {
246
- borderRadius: '3px 3px 0 0',
247
- },
248
- '&:last-of-type': {
249
- borderRadius: '0 0 3px 3px',
250
- },
340
+ borderRadius: '4px',
251
341
  },
252
342
  label: {
253
343
  fontSize: 'max(1rem, 14px)',
254
344
  },
345
+ selectedIndicator: {
346
+ fontSize: 'max(1rem, 14px)',
347
+ position: 'absolute',
348
+ right: '10px',
349
+ },
255
350
  srOnly: {
256
351
  position: 'absolute',
257
352
  left: '-10000px',
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import { withStyles } from '@material-ui/core/styles';
3
3
  import classnames from 'classnames';
4
4
 
5
- import { color } from '@pie-lib/render-ui';
5
+ import { color } from '../../render-ui/src/index';
6
6
  import EditableHtml from '@pie-lib/editable-html';
7
7
  import { withMask } from './with-mask';
8
8
 
@@ -167,4 +167,4 @@ const rules = [
167
167
  */
168
168
  const html = new Html({ rules, defaultBlock: 'span' });
169
169
 
170
- export const deserialize = (s) => html.deserialize(s, { toJSON: true });
170
+ export const deserialize = (s) => html.deserialize(s, { toJSON: true });
@@ -1,71 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
- var React = _interopRequireWildcard(require("react"));
8
-
9
- var _enzyme = require("enzyme");
10
-
11
- var _dragInTheBlank = _interopRequireDefault(require("../drag-in-the-blank"));
12
-
13
- 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); }
14
-
15
- 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; }
16
-
17
- var markup = "<div>\n <img src=\"https://image.shutterstock.com/image-vector/cow-jumped-over-moon-traditional-260nw-1152899330.jpg\"></img>\n <h5>Hey Diddle Diddle <i>by ?</i></h5>\n <p>1: Hey, diddle, diddle,</p>\n <p>2: The cat and the fiddle,</p>\n <p>3: The cow {{0}} over the moon;</p>\n <p>4: The little dog {{1}},</p>\n <p>5: To see such sport,</p>\n <p>6: And the dish ran away with the {{2}}.</p>\n</div>";
18
-
19
- var choice = function choice(v, id) {
20
- return {
21
- value: v,
22
- id: id
23
- };
24
- };
25
-
26
- describe('DragInTheBlank', function () {
27
- var defaultProps = {
28
- disabled: false,
29
- feedback: {},
30
- markup: markup,
31
- choices: [choice('Jumped', '0'), choice('Laughed', '1'), choice('Spoon', '2'), choice('Fork', '3'), choice('Bumped', '4'), choice('Smiled', '5')],
32
- value: {
33
- 0: undefined
34
- }
35
- };
36
- var wrapper;
37
- beforeEach(function () {
38
- wrapper = (0, _enzyme.shallow)( /*#__PURE__*/React.createElement(_dragInTheBlank["default"], defaultProps));
39
- });
40
- describe('render', function () {
41
- it('renders correctly with default props', function () {
42
- expect(wrapper).toMatchSnapshot();
43
- });
44
- it('renders correctly with disabled prop as true', function () {
45
- wrapper.setProps({
46
- disabled: true
47
- });
48
- expect(wrapper).toMatchSnapshot();
49
- });
50
- it('renders correctly with feedback', function () {
51
- wrapper.setProps({
52
- feedback: {
53
- 0: {
54
- value: 'Jumped',
55
- correct: 'Jumped'
56
- },
57
- 1: {
58
- value: 'Laughed',
59
- correct: 'Laughed'
60
- },
61
- 2: {
62
- value: 'Spoon',
63
- correct: 'Spoon'
64
- }
65
- }
66
- });
67
- expect(wrapper).toMatchSnapshot();
68
- });
69
- });
70
- });
71
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vZHJhZy1pbi10aGUtYmxhbmsudGVzdC5qcyJdLCJuYW1lcyI6WyJtYXJrdXAiLCJjaG9pY2UiLCJ2IiwiaWQiLCJ2YWx1ZSIsImRlc2NyaWJlIiwiZGVmYXVsdFByb3BzIiwiZGlzYWJsZWQiLCJmZWVkYmFjayIsImNob2ljZXMiLCJ1bmRlZmluZWQiLCJ3cmFwcGVyIiwiYmVmb3JlRWFjaCIsIml0IiwiZXhwZWN0IiwidG9NYXRjaFNuYXBzaG90Iiwic2V0UHJvcHMiLCJjb3JyZWN0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7Ozs7O0FBRUEsSUFBTUEsTUFBTSx1WkFBWjs7QUFVQSxJQUFNQyxNQUFNLEdBQUcsU0FBVEEsTUFBUyxDQUFDQyxDQUFELEVBQUlDLEVBQUo7QUFBQSxTQUFZO0FBQUVDLElBQUFBLEtBQUssRUFBRUYsQ0FBVDtBQUFZQyxJQUFBQSxFQUFFLEVBQUZBO0FBQVosR0FBWjtBQUFBLENBQWY7O0FBRUFFLFFBQVEsQ0FBQyxnQkFBRCxFQUFtQixZQUFNO0FBQy9CLE1BQU1DLFlBQVksR0FBRztBQUNuQkMsSUFBQUEsUUFBUSxFQUFFLEtBRFM7QUFFbkJDLElBQUFBLFFBQVEsRUFBRSxFQUZTO0FBR25CUixJQUFBQSxNQUFNLEVBQU5BLE1BSG1CO0FBSW5CUyxJQUFBQSxPQUFPLEVBQUUsQ0FDUFIsTUFBTSxDQUFDLFFBQUQsRUFBVyxHQUFYLENBREMsRUFFUEEsTUFBTSxDQUFDLFNBQUQsRUFBWSxHQUFaLENBRkMsRUFHUEEsTUFBTSxDQUFDLE9BQUQsRUFBVSxHQUFWLENBSEMsRUFJUEEsTUFBTSxDQUFDLE1BQUQsRUFBUyxHQUFULENBSkMsRUFLUEEsTUFBTSxDQUFDLFFBQUQsRUFBVyxHQUFYLENBTEMsRUFNUEEsTUFBTSxDQUFDLFFBQUQsRUFBVyxHQUFYLENBTkMsQ0FKVTtBQWFuQkcsSUFBQUEsS0FBSyxFQUFFO0FBQ0wsU0FBR007QUFERTtBQWJZLEdBQXJCO0FBaUJBLE1BQUlDLE9BQUo7QUFFQUMsRUFBQUEsVUFBVSxDQUFDLFlBQU07QUFDZkQsSUFBQUEsT0FBTyxHQUFHLG1DQUFRLG9CQUFDLDBCQUFELEVBQW9CTCxZQUFwQixDQUFSLENBQVY7QUFDRCxHQUZTLENBQVY7QUFJQUQsRUFBQUEsUUFBUSxDQUFDLFFBQUQsRUFBVyxZQUFNO0FBQ3ZCUSxJQUFBQSxFQUFFLENBQUMsc0NBQUQsRUFBeUMsWUFBTTtBQUMvQ0MsTUFBQUEsTUFBTSxDQUFDSCxPQUFELENBQU4sQ0FBZ0JJLGVBQWhCO0FBQ0QsS0FGQyxDQUFGO0FBSUFGLElBQUFBLEVBQUUsQ0FBQyw4Q0FBRCxFQUFpRCxZQUFNO0FBQ3ZERixNQUFBQSxPQUFPLENBQUNLLFFBQVIsQ0FBaUI7QUFBRVQsUUFBQUEsUUFBUSxFQUFFO0FBQVosT0FBakI7QUFDQU8sTUFBQUEsTUFBTSxDQUFDSCxPQUFELENBQU4sQ0FBZ0JJLGVBQWhCO0FBQ0QsS0FIQyxDQUFGO0FBS0FGLElBQUFBLEVBQUUsQ0FBQyxpQ0FBRCxFQUFvQyxZQUFNO0FBQzFDRixNQUFBQSxPQUFPLENBQUNLLFFBQVIsQ0FBaUI7QUFDZlIsUUFBQUEsUUFBUSxFQUFFO0FBQ1IsYUFBRztBQUNESixZQUFBQSxLQUFLLEVBQUUsUUFETjtBQUVEYSxZQUFBQSxPQUFPLEVBQUU7QUFGUixXQURLO0FBS1IsYUFBRztBQUNEYixZQUFBQSxLQUFLLEVBQUUsU0FETjtBQUVEYSxZQUFBQSxPQUFPLEVBQUU7QUFGUixXQUxLO0FBU1IsYUFBRztBQUNEYixZQUFBQSxLQUFLLEVBQUUsT0FETjtBQUVEYSxZQUFBQSxPQUFPLEVBQUU7QUFGUjtBQVRLO0FBREssT0FBakI7QUFnQkFILE1BQUFBLE1BQU0sQ0FBQ0gsT0FBRCxDQUFOLENBQWdCSSxlQUFoQjtBQUNELEtBbEJDLENBQUY7QUFtQkQsR0E3Qk8sQ0FBUjtBQThCRCxDQXRETyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgc2hhbGxvdyB9IGZyb20gJ2VuenltZSc7XG5pbXBvcnQgRHJhZ0luVGhlQmxhbmsgZnJvbSAnLi4vZHJhZy1pbi10aGUtYmxhbmsnO1xuXG5jb25zdCBtYXJrdXAgPSBgPGRpdj5cbiAgPGltZyBzcmM9XCJodHRwczovL2ltYWdlLnNodXR0ZXJzdG9jay5jb20vaW1hZ2UtdmVjdG9yL2Nvdy1qdW1wZWQtb3Zlci1tb29uLXRyYWRpdGlvbmFsLTI2MG53LTExNTI4OTkzMzAuanBnXCI+PC9pbWc+XG4gICA8aDU+SGV5IERpZGRsZSBEaWRkbGUgPGk+YnkgPzwvaT48L2g1PlxuIDxwPjE6IEhleSwgZGlkZGxlLCBkaWRkbGUsPC9wPlxuIDxwPjI6IFRoZSBjYXQgYW5kIHRoZSBmaWRkbGUsPC9wPlxuIDxwPjM6IFRoZSBjb3cge3swfX0gb3ZlciB0aGUgbW9vbjs8L3A+XG4gPHA+NDogVGhlIGxpdHRsZSBkb2cge3sxfX0sPC9wPlxuIDxwPjU6IFRvIHNlZSBzdWNoIHNwb3J0LDwvcD5cbiA8cD42OiBBbmQgdGhlIGRpc2ggcmFuIGF3YXkgd2l0aCB0aGUge3syfX0uPC9wPlxuPC9kaXY+YDtcbmNvbnN0IGNob2ljZSA9ICh2LCBpZCkgPT4gKHsgdmFsdWU6IHYsIGlkIH0pO1xuXG5kZXNjcmliZSgnRHJhZ0luVGhlQmxhbmsnLCAoKSA9PiB7XG4gIGNvbnN0IGRlZmF1bHRQcm9wcyA9IHtcbiAgICBkaXNhYmxlZDogZmFsc2UsXG4gICAgZmVlZGJhY2s6IHt9LFxuICAgIG1hcmt1cCxcbiAgICBjaG9pY2VzOiBbXG4gICAgICBjaG9pY2UoJ0p1bXBlZCcsICcwJyksXG4gICAgICBjaG9pY2UoJ0xhdWdoZWQnLCAnMScpLFxuICAgICAgY2hvaWNlKCdTcG9vbicsICcyJyksXG4gICAgICBjaG9pY2UoJ0ZvcmsnLCAnMycpLFxuICAgICAgY2hvaWNlKCdCdW1wZWQnLCAnNCcpLFxuICAgICAgY2hvaWNlKCdTbWlsZWQnLCAnNScpLFxuICAgIF0sXG5cbiAgICB2YWx1ZToge1xuICAgICAgMDogdW5kZWZpbmVkLFxuICAgIH0sXG4gIH07XG4gIGxldCB3cmFwcGVyO1xuXG4gIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgIHdyYXBwZXIgPSBzaGFsbG93KDxEcmFnSW5UaGVCbGFuayB7Li4uZGVmYXVsdFByb3BzfSAvPik7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdyZW5kZXInLCAoKSA9PiB7XG4gICAgaXQoJ3JlbmRlcnMgY29ycmVjdGx5IHdpdGggZGVmYXVsdCBwcm9wcycsICgpID0+IHtcbiAgICAgIGV4cGVjdCh3cmFwcGVyKS50b01hdGNoU25hcHNob3QoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIGNvcnJlY3RseSB3aXRoIGRpc2FibGVkIHByb3AgYXMgdHJ1ZScsICgpID0+IHtcbiAgICAgIHdyYXBwZXIuc2V0UHJvcHMoeyBkaXNhYmxlZDogdHJ1ZSB9KTtcbiAgICAgIGV4cGVjdCh3cmFwcGVyKS50b01hdGNoU25hcHNob3QoKTtcbiAgICB9KTtcblxuICAgIGl0KCdyZW5kZXJzIGNvcnJlY3RseSB3aXRoIGZlZWRiYWNrJywgKCkgPT4ge1xuICAgICAgd3JhcHBlci5zZXRQcm9wcyh7XG4gICAgICAgIGZlZWRiYWNrOiB7XG4gICAgICAgICAgMDoge1xuICAgICAgICAgICAgdmFsdWU6ICdKdW1wZWQnLFxuICAgICAgICAgICAgY29ycmVjdDogJ0p1bXBlZCcsXG4gICAgICAgICAgfSxcbiAgICAgICAgICAxOiB7XG4gICAgICAgICAgICB2YWx1ZTogJ0xhdWdoZWQnLFxuICAgICAgICAgICAgY29ycmVjdDogJ0xhdWdoZWQnLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgMjoge1xuICAgICAgICAgICAgdmFsdWU6ICdTcG9vbicsXG4gICAgICAgICAgICBjb3JyZWN0OiAnU3Bvb24nLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICAgIGV4cGVjdCh3cmFwcGVyKS50b01hdGNoU25hcHNob3QoKTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -1,50 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
- var React = _interopRequireWildcard(require("react"));
8
-
9
- var _componentize = _interopRequireDefault(require("../componentize"));
10
-
11
- var _serialization = require("../serialization");
12
-
13
- 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); }
14
-
15
- 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; }
16
-
17
- describe('index', function () {
18
- describe('componentize', function () {
19
- it('should return an array with the appropriate markup', function () {
20
- var dropDownMarkup = (0, _componentize["default"])('{{0}} foo {{1}}', 'dropdown');
21
- expect(dropDownMarkup).toEqual({
22
- markup: '<span data-component="dropdown" data-id="0"></span> foo <span data-component="dropdown" data-id="1"></span>'
23
- });
24
- });
25
- });
26
- describe('serialization', function () {
27
- it('should have default node a span', function () {
28
- expect((0, _serialization.deserialize)('something')).toEqual(expect.objectContaining({
29
- object: 'value',
30
- document: {
31
- object: 'document',
32
- data: {},
33
- nodes: [{
34
- object: 'block',
35
- data: {},
36
- isVoid: false,
37
- type: 'span',
38
- nodes: [{
39
- object: 'text',
40
- leaves: [{
41
- text: 'something'
42
- }]
43
- }]
44
- }]
45
- }
46
- }));
47
- });
48
- });
49
- });
50
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vaW5kZXgudGVzdC5qcyJdLCJuYW1lcyI6WyJkZXNjcmliZSIsIml0IiwiZHJvcERvd25NYXJrdXAiLCJleHBlY3QiLCJ0b0VxdWFsIiwibWFya3VwIiwib2JqZWN0Q29udGFpbmluZyIsIm9iamVjdCIsImRvY3VtZW50IiwiZGF0YSIsIm5vZGVzIiwiaXNWb2lkIiwidHlwZSIsImxlYXZlcyIsInRleHQiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBOztBQUNBOztBQUNBOzs7Ozs7QUFFQUEsUUFBUSxDQUFDLE9BQUQsRUFBVSxZQUFNO0FBQ3RCQSxFQUFBQSxRQUFRLENBQUMsY0FBRCxFQUFpQixZQUFNO0FBQzdCQyxJQUFBQSxFQUFFLENBQUMsb0RBQUQsRUFBdUQsWUFBTTtBQUM3RCxVQUFNQyxjQUFjLEdBQUcsOEJBQWEsaUJBQWIsRUFBZ0MsVUFBaEMsQ0FBdkI7QUFFQUMsTUFBQUEsTUFBTSxDQUFDRCxjQUFELENBQU4sQ0FBdUJFLE9BQXZCLENBQStCO0FBQzdCQyxRQUFBQSxNQUFNLEVBQ0o7QUFGMkIsT0FBL0I7QUFJRCxLQVBDLENBQUY7QUFRRCxHQVRPLENBQVI7QUFXQUwsRUFBQUEsUUFBUSxDQUFDLGVBQUQsRUFBa0IsWUFBTTtBQUM5QkMsSUFBQUEsRUFBRSxDQUFDLGlDQUFELEVBQW9DLFlBQU07QUFDMUNFLE1BQUFBLE1BQU0sQ0FBQyxnQ0FBWSxXQUFaLENBQUQsQ0FBTixDQUFpQ0MsT0FBakMsQ0FDRUQsTUFBTSxDQUFDRyxnQkFBUCxDQUF3QjtBQUN0QkMsUUFBQUEsTUFBTSxFQUFFLE9BRGM7QUFFdEJDLFFBQUFBLFFBQVEsRUFBRTtBQUNSRCxVQUFBQSxNQUFNLEVBQUUsVUFEQTtBQUVSRSxVQUFBQSxJQUFJLEVBQUUsRUFGRTtBQUdSQyxVQUFBQSxLQUFLLEVBQUUsQ0FDTDtBQUNFSCxZQUFBQSxNQUFNLEVBQUUsT0FEVjtBQUVFRSxZQUFBQSxJQUFJLEVBQUUsRUFGUjtBQUdFRSxZQUFBQSxNQUFNLEVBQUUsS0FIVjtBQUlFQyxZQUFBQSxJQUFJLEVBQUUsTUFKUjtBQUtFRixZQUFBQSxLQUFLLEVBQUUsQ0FBQztBQUFFSCxjQUFBQSxNQUFNLEVBQUUsTUFBVjtBQUFrQk0sY0FBQUEsTUFBTSxFQUFFLENBQUM7QUFBRUMsZ0JBQUFBLElBQUksRUFBRTtBQUFSLGVBQUQ7QUFBMUIsYUFBRDtBQUxULFdBREs7QUFIQztBQUZZLE9BQXhCLENBREY7QUFrQkQsS0FuQkMsQ0FBRjtBQW9CRCxHQXJCTyxDQUFSO0FBc0JELENBbENPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgY29tcG9uZW50aXplIGZyb20gJy4uL2NvbXBvbmVudGl6ZSc7XG5pbXBvcnQgeyBkZXNlcmlhbGl6ZSB9IGZyb20gJy4uL3NlcmlhbGl6YXRpb24nO1xuXG5kZXNjcmliZSgnaW5kZXgnLCAoKSA9PiB7XG4gIGRlc2NyaWJlKCdjb21wb25lbnRpemUnLCAoKSA9PiB7XG4gICAgaXQoJ3Nob3VsZCByZXR1cm4gYW4gYXJyYXkgd2l0aCB0aGUgYXBwcm9wcmlhdGUgbWFya3VwJywgKCkgPT4ge1xuICAgICAgY29uc3QgZHJvcERvd25NYXJrdXAgPSBjb21wb25lbnRpemUoJ3t7MH19IGZvbyB7ezF9fScsICdkcm9wZG93bicpO1xuXG4gICAgICBleHBlY3QoZHJvcERvd25NYXJrdXApLnRvRXF1YWwoe1xuICAgICAgICBtYXJrdXA6XG4gICAgICAgICAgJzxzcGFuIGRhdGEtY29tcG9uZW50PVwiZHJvcGRvd25cIiBkYXRhLWlkPVwiMFwiPjwvc3Bhbj4gZm9vIDxzcGFuIGRhdGEtY29tcG9uZW50PVwiZHJvcGRvd25cIiBkYXRhLWlkPVwiMVwiPjwvc3Bhbj4nLFxuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKCdzZXJpYWxpemF0aW9uJywgKCkgPT4ge1xuICAgIGl0KCdzaG91bGQgaGF2ZSBkZWZhdWx0IG5vZGUgYSBzcGFuJywgKCkgPT4ge1xuICAgICAgZXhwZWN0KGRlc2VyaWFsaXplKCdzb21ldGhpbmcnKSkudG9FcXVhbChcbiAgICAgICAgZXhwZWN0Lm9iamVjdENvbnRhaW5pbmcoe1xuICAgICAgICAgIG9iamVjdDogJ3ZhbHVlJyxcbiAgICAgICAgICBkb2N1bWVudDoge1xuICAgICAgICAgICAgb2JqZWN0OiAnZG9jdW1lbnQnLFxuICAgICAgICAgICAgZGF0YToge30sXG4gICAgICAgICAgICBub2RlczogW1xuICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgb2JqZWN0OiAnYmxvY2snLFxuICAgICAgICAgICAgICAgIGRhdGE6IHt9LFxuICAgICAgICAgICAgICAgIGlzVm9pZDogZmFsc2UsXG4gICAgICAgICAgICAgICAgdHlwZTogJ3NwYW4nLFxuICAgICAgICAgICAgICAgIG5vZGVzOiBbeyBvYmplY3Q6ICd0ZXh0JywgbGVhdmVzOiBbeyB0ZXh0OiAnc29tZXRoaW5nJyB9XSB9XSxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIF0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSksXG4gICAgICApO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
@@ -1,149 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
-
7
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
8
-
9
- var React = _interopRequireWildcard(require("react"));
10
-
11
- var _enzyme = require("enzyme");
12
-
13
- var _mask = _interopRequireDefault(require("../mask"));
14
-
15
- 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); }
16
-
17
- 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; }
18
-
19
- 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; }
20
-
21
- 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; }
22
-
23
- describe('Mask', function () {
24
- var renderChildren = jest.fn();
25
- var onChange = jest.fn();
26
- var defaultProps = {
27
- renderChildren: renderChildren,
28
- onChange: onChange,
29
- layout: {
30
- nodes: [{
31
- object: 'text',
32
- leaves: [{
33
- text: 'Foo'
34
- }]
35
- }]
36
- },
37
- value: {}
38
- };
39
- var wrapper;
40
- beforeEach(function () {
41
- wrapper = (0, _enzyme.shallow)( /*#__PURE__*/React.createElement(_mask["default"], defaultProps));
42
- });
43
- describe('render', function () {
44
- it('renders correctly with default props', function () {
45
- expect(wrapper).toMatchSnapshot();
46
- });
47
- it('renders correctly a paragraph', function () {
48
- wrapper.setProps({
49
- layout: {
50
- nodes: [{
51
- type: 'p',
52
- nodes: [{
53
- object: 'text',
54
- leaves: [{
55
- text: 'Foo'
56
- }]
57
- }]
58
- }]
59
- }
60
- });
61
- expect(wrapper).toMatchSnapshot();
62
- });
63
- it('renders correctly a div', function () {
64
- wrapper.setProps({
65
- layout: {
66
- nodes: [{
67
- type: 'div',
68
- data: {
69
- attributes: {}
70
- },
71
- nodes: [{
72
- type: 'p',
73
- data: {
74
- attributes: {}
75
- },
76
- nodes: [{
77
- object: 'text',
78
- leaves: [{
79
- text: 'Foo'
80
- }]
81
- }]
82
- }]
83
- }]
84
- }
85
- });
86
- expect(wrapper).toMatchSnapshot();
87
- });
88
- it.only('renders correctly a em', function () {
89
- wrapper.setProps({
90
- layout: {
91
- nodes: [{
92
- leaves: [{
93
- text: 'Foo '
94
- }],
95
- object: 'text'
96
- }, {
97
- leaves: [{
98
- marks: [{
99
- data: undefined,
100
- type: 'italic'
101
- }],
102
- text: 'x'
103
- }],
104
- object: 'text'
105
- }, {
106
- leaves: [{
107
- text: ' bar'
108
- }],
109
- object: 'text'
110
- }],
111
- object: 'block',
112
- type: 'div'
113
- }
114
- });
115
- expect(wrapper).toMatchSnapshot();
116
- });
117
-
118
- var da = function da() {
119
- return {
120
- data: {
121
- attributes: {}
122
- }
123
- };
124
- };
125
-
126
- it('renders without space under tbody', function () {
127
- wrapper.setProps({
128
- layout: {
129
- nodes: [_objectSpread(_objectSpread({
130
- type: 'tbody'
131
- }, da()), {}, {
132
- nodes: [{
133
- object: 'text',
134
- leaves: [{
135
- text: ' '
136
- }]
137
- }, _objectSpread(_objectSpread({
138
- type: 'tr'
139
- }, da()), {}, {
140
- nodes: []
141
- })]
142
- })]
143
- }
144
- });
145
- expect(wrapper).toMatchSnapshot();
146
- });
147
- });
148
- });
149
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/mask.test.js"],"names":["describe","renderChildren","jest","fn","onChange","defaultProps","layout","nodes","object","leaves","text","value","wrapper","beforeEach","it","expect","toMatchSnapshot","setProps","type","data","attributes","only","marks","undefined","da"],"mappings":"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","sourcesContent":["import * as React from 'react';\nimport { shallow } from 'enzyme';\nimport Mask from '../mask';\n\ndescribe('Mask', () => {\n  const renderChildren = jest.fn();\n  const onChange = jest.fn();\n  const defaultProps = {\n    renderChildren,\n    onChange,\n    layout: {\n      nodes: [\n        {\n          object: 'text',\n          leaves: [\n            {\n              text: 'Foo',\n            },\n          ],\n        },\n      ],\n    },\n    value: {},\n  };\n  let wrapper;\n\n  beforeEach(() => {\n    wrapper = shallow(<Mask {...defaultProps} />);\n  });\n\n  describe('render', () => {\n    it('renders correctly with default props', () => {\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it('renders correctly a paragraph', () => {\n      wrapper.setProps({\n        layout: {\n          nodes: [\n            {\n              type: 'p',\n              nodes: [\n                {\n                  object: 'text',\n                  leaves: [\n                    {\n                      text: 'Foo',\n                    },\n                  ],\n                },\n              ],\n            },\n          ],\n        },\n      });\n\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it('renders correctly a div', () => {\n      wrapper.setProps({\n        layout: {\n          nodes: [\n            {\n              type: 'div',\n              data: {\n                attributes: {},\n              },\n              nodes: [\n                {\n                  type: 'p',\n                  data: {\n                    attributes: {},\n                  },\n                  nodes: [\n                    {\n                      object: 'text',\n                      leaves: [\n                        {\n                          text: 'Foo',\n                        },\n                      ],\n                    },\n                  ],\n                },\n              ],\n            },\n          ],\n        },\n      });\n\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    it.only('renders correctly a em', () => {\n      wrapper.setProps({\n        layout: {\n          nodes: [\n            {\n              leaves: [{ text: 'Foo ' }],\n              object: 'text',\n            },\n            {\n              leaves: [\n                {\n                  marks: [\n                    {\n                      data: undefined,\n                      type: 'italic',\n                    },\n                  ],\n                  text: 'x',\n                },\n              ],\n              object: 'text',\n            },\n            {\n              leaves: [{ text: ' bar' }],\n              object: 'text',\n            },\n          ],\n          object: 'block',\n          type: 'div',\n        },\n      });\n\n      expect(wrapper).toMatchSnapshot();\n    });\n\n    const da = () => ({ data: { attributes: {} } });\n    it('renders without space under tbody', () => {\n      wrapper.setProps({\n        layout: {\n          nodes: [\n            {\n              type: 'tbody',\n              ...da(),\n              nodes: [\n                {\n                  object: 'text',\n                  leaves: [{ text: ' ' }],\n                },\n                { type: 'tr', ...da(), nodes: [] },\n              ],\n            },\n          ],\n        },\n      });\n      expect(wrapper).toMatchSnapshot();\n    });\n  });\n});\n"]}
@@ -1,45 +0,0 @@
1
- "use strict";
2
-
3
- var _serialization = require("../serialization");
4
-
5
- describe('serialization', function () {
6
- it('ignores comments', function () {
7
- var out = (0, _serialization.deserialize)("<!-- hi -->");
8
- expect(out.document.nodes[0]).toEqual(expect.objectContaining({
9
- type: 'span'
10
- }));
11
- });
12
- it('ignores comments', function () {
13
- var out = (0, _serialization.deserialize)("<!-- hi --><div>foo</div>");
14
- expect(out.document.nodes[0]).toEqual(expect.objectContaining({
15
- type: 'div',
16
- nodes: [expect.objectContaining({
17
- object: 'text',
18
- leaves: [{
19
- text: 'foo'
20
- }]
21
- })]
22
- }));
23
- });
24
- it('deserializes an em', function () {
25
- var out = (0, _serialization.deserialize)("<!-- hi --><div> <em>x</em> </div>");
26
- expect(out.document.nodes[0]).toEqual(expect.objectContaining({
27
- type: 'div',
28
- nodes: [expect.objectContaining({
29
- object: 'text'
30
- }), expect.objectContaining({
31
- leaves: [{
32
- marks: [{
33
- data: undefined,
34
- type: 'italic'
35
- }],
36
- text: 'x'
37
- }],
38
- object: 'text'
39
- }), expect.objectContaining({
40
- object: 'text'
41
- })]
42
- }));
43
- });
44
- });
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vc2VyaWFsaXphdGlvbi50ZXN0LmpzIl0sIm5hbWVzIjpbImRlc2NyaWJlIiwiaXQiLCJvdXQiLCJleHBlY3QiLCJkb2N1bWVudCIsIm5vZGVzIiwidG9FcXVhbCIsIm9iamVjdENvbnRhaW5pbmciLCJ0eXBlIiwib2JqZWN0IiwibGVhdmVzIiwidGV4dCIsIm1hcmtzIiwiZGF0YSIsInVuZGVmaW5lZCJdLCJtYXBwaW5ncyI6Ijs7QUFBQTs7QUFFQUEsUUFBUSxDQUFDLGVBQUQsRUFBa0IsWUFBTTtBQUM5QkMsRUFBQUEsRUFBRSxDQUFDLGtCQUFELEVBQXFCLFlBQU07QUFDM0IsUUFBTUMsR0FBRyxHQUFHLDhDQUFaO0FBQ0FDLElBQUFBLE1BQU0sQ0FBQ0QsR0FBRyxDQUFDRSxRQUFKLENBQWFDLEtBQWIsQ0FBbUIsQ0FBbkIsQ0FBRCxDQUFOLENBQThCQyxPQUE5QixDQUFzQ0gsTUFBTSxDQUFDSSxnQkFBUCxDQUF3QjtBQUFFQyxNQUFBQSxJQUFJLEVBQUU7QUFBUixLQUF4QixDQUF0QztBQUNELEdBSEMsQ0FBRjtBQUtBUCxFQUFBQSxFQUFFLENBQUMsa0JBQUQsRUFBcUIsWUFBTTtBQUMzQixRQUFNQyxHQUFHLEdBQUcsNERBQVo7QUFDQUMsSUFBQUEsTUFBTSxDQUFDRCxHQUFHLENBQUNFLFFBQUosQ0FBYUMsS0FBYixDQUFtQixDQUFuQixDQUFELENBQU4sQ0FBOEJDLE9BQTlCLENBQ0VILE1BQU0sQ0FBQ0ksZ0JBQVAsQ0FBd0I7QUFDdEJDLE1BQUFBLElBQUksRUFBRSxLQURnQjtBQUV0QkgsTUFBQUEsS0FBSyxFQUFFLENBQ0xGLE1BQU0sQ0FBQ0ksZ0JBQVAsQ0FBd0I7QUFDdEJFLFFBQUFBLE1BQU0sRUFBRSxNQURjO0FBRXRCQyxRQUFBQSxNQUFNLEVBQUUsQ0FBQztBQUFFQyxVQUFBQSxJQUFJLEVBQUU7QUFBUixTQUFEO0FBRmMsT0FBeEIsQ0FESztBQUZlLEtBQXhCLENBREY7QUFXRCxHQWJDLENBQUY7QUFlQVYsRUFBQUEsRUFBRSxDQUFDLG9CQUFELEVBQXVCLFlBQU07QUFDN0IsUUFBTUMsR0FBRyxHQUFHLHFFQUFaO0FBQ0FDLElBQUFBLE1BQU0sQ0FBQ0QsR0FBRyxDQUFDRSxRQUFKLENBQWFDLEtBQWIsQ0FBbUIsQ0FBbkIsQ0FBRCxDQUFOLENBQThCQyxPQUE5QixDQUNFSCxNQUFNLENBQUNJLGdCQUFQLENBQXdCO0FBQ3RCQyxNQUFBQSxJQUFJLEVBQUUsS0FEZ0I7QUFFdEJILE1BQUFBLEtBQUssRUFBRSxDQUNMRixNQUFNLENBQUNJLGdCQUFQLENBQXdCO0FBQ3RCRSxRQUFBQSxNQUFNLEVBQUU7QUFEYyxPQUF4QixDQURLLEVBSUxOLE1BQU0sQ0FBQ0ksZ0JBQVAsQ0FBd0I7QUFDdEJHLFFBQUFBLE1BQU0sRUFBRSxDQUNOO0FBQ0VFLFVBQUFBLEtBQUssRUFBRSxDQUNMO0FBQ0VDLFlBQUFBLElBQUksRUFBRUMsU0FEUjtBQUVFTixZQUFBQSxJQUFJLEVBQUU7QUFGUixXQURLLENBRFQ7QUFPRUcsVUFBQUEsSUFBSSxFQUFFO0FBUFIsU0FETSxDQURjO0FBWXRCRixRQUFBQSxNQUFNLEVBQUU7QUFaYyxPQUF4QixDQUpLLEVBa0JMTixNQUFNLENBQUNJLGdCQUFQLENBQXdCO0FBQ3RCRSxRQUFBQSxNQUFNLEVBQUU7QUFEYyxPQUF4QixDQWxCSztBQUZlLEtBQXhCLENBREY7QUEyQkQsR0E3QkMsQ0FBRjtBQThCRCxDQW5ETyxDQUFSIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZGVzZXJpYWxpemUgfSBmcm9tICcuLi9zZXJpYWxpemF0aW9uJztcblxuZGVzY3JpYmUoJ3NlcmlhbGl6YXRpb24nLCAoKSA9PiB7XG4gIGl0KCdpZ25vcmVzIGNvbW1lbnRzJywgKCkgPT4ge1xuICAgIGNvbnN0IG91dCA9IGRlc2VyaWFsaXplKGA8IS0tIGhpIC0tPmApO1xuICAgIGV4cGVjdChvdXQuZG9jdW1lbnQubm9kZXNbMF0pLnRvRXF1YWwoZXhwZWN0Lm9iamVjdENvbnRhaW5pbmcoeyB0eXBlOiAnc3BhbicgfSkpO1xuICB9KTtcblxuICBpdCgnaWdub3JlcyBjb21tZW50cycsICgpID0+IHtcbiAgICBjb25zdCBvdXQgPSBkZXNlcmlhbGl6ZShgPCEtLSBoaSAtLT48ZGl2PmZvbzwvZGl2PmApO1xuICAgIGV4cGVjdChvdXQuZG9jdW1lbnQubm9kZXNbMF0pLnRvRXF1YWwoXG4gICAgICBleHBlY3Qub2JqZWN0Q29udGFpbmluZyh7XG4gICAgICAgIHR5cGU6ICdkaXYnLFxuICAgICAgICBub2RlczogW1xuICAgICAgICAgIGV4cGVjdC5vYmplY3RDb250YWluaW5nKHtcbiAgICAgICAgICAgIG9iamVjdDogJ3RleHQnLFxuICAgICAgICAgICAgbGVhdmVzOiBbeyB0ZXh0OiAnZm9vJyB9XSxcbiAgICAgICAgICB9KSxcbiAgICAgICAgXSxcbiAgICAgIH0pLFxuICAgICk7XG4gIH0pO1xuXG4gIGl0KCdkZXNlcmlhbGl6ZXMgYW4gZW0nLCAoKSA9PiB7XG4gICAgY29uc3Qgb3V0ID0gZGVzZXJpYWxpemUoYDwhLS0gaGkgLS0+PGRpdj4gPGVtPng8L2VtPiA8L2Rpdj5gKTtcbiAgICBleHBlY3Qob3V0LmRvY3VtZW50Lm5vZGVzWzBdKS50b0VxdWFsKFxuICAgICAgZXhwZWN0Lm9iamVjdENvbnRhaW5pbmcoe1xuICAgICAgICB0eXBlOiAnZGl2JyxcbiAgICAgICAgbm9kZXM6IFtcbiAgICAgICAgICBleHBlY3Qub2JqZWN0Q29udGFpbmluZyh7XG4gICAgICAgICAgICBvYmplY3Q6ICd0ZXh0JyxcbiAgICAgICAgICB9KSxcbiAgICAgICAgICBleHBlY3Qub2JqZWN0Q29udGFpbmluZyh7XG4gICAgICAgICAgICBsZWF2ZXM6IFtcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG1hcmtzOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGRhdGE6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgICAgICAgICAgdHlwZTogJ2l0YWxpYycsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgICAgdGV4dDogJ3gnLFxuICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgXSxcbiAgICAgICAgICAgIG9iamVjdDogJ3RleHQnLFxuICAgICAgICAgIH0pLFxuICAgICAgICAgIGV4cGVjdC5vYmplY3RDb250YWluaW5nKHtcbiAgICAgICAgICAgIG9iamVjdDogJ3RleHQnLFxuICAgICAgICAgIH0pLFxuICAgICAgICBdLFxuICAgICAgfSksXG4gICAgKTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -1,17 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.choice = void 0;
7
-
8
- var choice = function choice(v, id) {
9
- return {
10
- label: v,
11
- value: v,
12
- id: id
13
- };
14
- };
15
-
16
- exports.choice = choice;
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vdXRpbHMuanMiXSwibmFtZXMiOlsiY2hvaWNlIiwidiIsImlkIiwibGFiZWwiLCJ2YWx1ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFPLElBQU1BLE1BQU0sR0FBRyxTQUFUQSxNQUFTLENBQUNDLENBQUQsRUFBSUMsRUFBSjtBQUFBLFNBQVk7QUFBRUMsSUFBQUEsS0FBSyxFQUFFRixDQUFUO0FBQVlHLElBQUFBLEtBQUssRUFBRUgsQ0FBbkI7QUFBc0JDLElBQUFBLEVBQUUsRUFBRkE7QUFBdEIsR0FBWjtBQUFBLENBQWYiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgY2hvaWNlID0gKHYsIGlkKSA9PiAoeyBsYWJlbDogdiwgdmFsdWU6IHYsIGlkIH0pO1xuIl19