@pie-lib/mask-markup 1.13.13-next.0 → 2.0.0-beta.1

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 (50) hide show
  1. package/CHANGELOG.md +0 -186
  2. package/lib/choices/choice.js +2 -2
  3. package/lib/choices/choice.js.map +1 -1
  4. package/lib/choices/index.js +2 -6
  5. package/lib/choices/index.js.map +1 -1
  6. package/lib/componentize.js +1 -1
  7. package/lib/componentize.js.map +1 -1
  8. package/lib/components/blank.js +1 -1
  9. package/lib/components/blank.js.map +1 -1
  10. package/lib/components/correct-input.js +1 -1
  11. package/lib/components/correct-input.js.map +1 -1
  12. package/lib/components/dropdown.js +1 -1
  13. package/lib/components/dropdown.js.map +1 -1
  14. package/lib/components/input.js +1 -1
  15. package/lib/components/input.js.map +1 -1
  16. package/lib/constructed-response.js +1 -1
  17. package/lib/constructed-response.js.map +1 -1
  18. package/lib/drag-in-the-blank.js +1 -1
  19. package/lib/drag-in-the-blank.js.map +1 -1
  20. package/lib/index.js +1 -1
  21. package/lib/index.js.map +1 -1
  22. package/lib/inline-dropdown.js +1 -1
  23. package/lib/inline-dropdown.js.map +1 -1
  24. package/lib/mask.js +10 -19
  25. package/lib/mask.js.map +1 -1
  26. package/lib/new-serialization.js +320 -0
  27. package/lib/parse-html.js +16 -0
  28. package/lib/serialization.js +33 -30
  29. package/lib/serialization.js.map +1 -1
  30. package/lib/test-serializer.js +215 -0
  31. package/lib/with-mask.js +2 -2
  32. package/lib/with-mask.js.map +1 -1
  33. package/package.json +12 -11
  34. package/src/choices/choice.jsx +13 -13
  35. package/src/choices/index.jsx +13 -17
  36. package/src/components/blank.jsx +30 -30
  37. package/src/components/correct-input.jsx +18 -18
  38. package/src/components/dropdown.jsx +38 -27
  39. package/src/components/input.jsx +3 -3
  40. package/src/constructed-response.jsx +4 -2
  41. package/src/drag-in-the-blank.jsx +11 -8
  42. package/src/index.js +8 -1
  43. package/src/inline-dropdown.jsx +3 -2
  44. package/src/mask.jsx +18 -29
  45. package/src/new-serialization.jsx +291 -0
  46. package/src/parse-html.js +8 -0
  47. package/src/serialization.js +43 -37
  48. package/src/test-serializer.js +163 -0
  49. package/src/with-mask.jsx +10 -3
  50. package/LICENSE.md +0 -5
@@ -0,0 +1,215 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
11
+
12
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
+
14
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
+
16
+ var _react = _interopRequireDefault(require("react"));
17
+
18
+ var _server = _interopRequireDefault(require("react-dom/server"));
19
+
20
+ var _escapeHtml = _interopRequireDefault(require("escape-html"));
21
+
22
+ var _slate = require("slate");
23
+
24
+ var _slateHyperscript = require("slate-hyperscript");
25
+
26
+ 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; }
27
+
28
+ 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; }
29
+
30
+ function allWhitespace(node) {
31
+ // Use ECMA-262 Edition 3 String and RegExp features
32
+ return !/[^\t\n\r ]/.test(node.textContent);
33
+ }
34
+
35
+ function defaultParseHtml(html) {
36
+ if (typeof DOMParser === 'undefined') {
37
+ throw new Error('The native `DOMParser` global which the `Html` serializer uses by default is not present in this environment. You must supply the `options.parseHtml` function instead.');
38
+ }
39
+
40
+ var parsed = new DOMParser().parseFromString(html, 'text/html');
41
+ var body = parsed.body;
42
+ var textNodes = document.createTreeWalker(body, NodeFilter.SHOW_TEXT, null, null);
43
+ var n = textNodes.nextNode();
44
+
45
+ while (n) {
46
+ if (allWhitespace(n) || n.nodeValue === "\u200B") {
47
+ n.parentNode.removeChild(n);
48
+ }
49
+
50
+ n = textNodes.nextNode();
51
+ }
52
+
53
+ return body;
54
+ }
55
+
56
+ var Html = /*#__PURE__*/(0, _createClass2["default"])(function Html(props) {
57
+ var _this = this;
58
+
59
+ (0, _classCallCheck2["default"])(this, Html);
60
+ (0, _defineProperty2["default"])(this, "serializeEls", function (node) {
61
+ if (_slate.Text.isText(node)) {
62
+ var string = (0, _escapeHtml["default"])(node.text);
63
+
64
+ if (node.bold) {
65
+ string = /*#__PURE__*/_react["default"].createElement("strong", null, string);
66
+ }
67
+
68
+ return string;
69
+ }
70
+
71
+ var children = (node.children || []).map(function (n) {
72
+ return _this.serializeEls(n);
73
+ });
74
+
75
+ var correctRule = _this.rules.reduce(function (res, rule) {
76
+ return res || rule.serialize(node, children);
77
+ }, null);
78
+
79
+ if (correctRule) {
80
+ return correctRule;
81
+ }
82
+
83
+ switch (node.type) {
84
+ case 'quote':
85
+ return /*#__PURE__*/_react["default"].createElement("blockquote", null, /*#__PURE__*/_react["default"].createElement("p", null, children));
86
+
87
+ case 'paragraph':
88
+ return /*#__PURE__*/_react["default"].createElement("p", null, children);
89
+
90
+ case 'link':
91
+ return /*#__PURE__*/_react["default"].createElement("a", {
92
+ href: (0, _escapeHtml["default"])(node.url)
93
+ }, children);
94
+
95
+ default:
96
+ return children;
97
+ }
98
+ });
99
+ (0, _defineProperty2["default"])(this, "serialize", function (node) {
100
+ var deserialized = _this.serializeEls(node);
101
+
102
+ var html = _server["default"].renderToStaticMarkup( /*#__PURE__*/_react["default"].createElement('body', null, deserialized));
103
+
104
+ var inner = html.slice(6, -7);
105
+ return inner;
106
+ });
107
+ (0, _defineProperty2["default"])(this, "deserialize", function (html) {
108
+ var body = _this.parseHtml(html);
109
+
110
+ if (body.firstChild && body.firstChild.nodeType === Node.TEXT_NODE) {
111
+ body = _this.parseHtml("<p>".concat(html, "</p>"));
112
+ }
113
+
114
+ return _this.deserializeEls(body);
115
+ });
116
+ (0, _defineProperty2["default"])(this, "deserializeEls", function (element) {
117
+ var markAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
118
+
119
+ if (element.nodeType === Node.TEXT_NODE) {
120
+ return (0, _slateHyperscript.jsx)('text', markAttributes, element.textContent);
121
+ } else if (element.nodeType !== Node.ELEMENT_NODE) {
122
+ return null;
123
+ }
124
+
125
+ var nodeAttributes = _objectSpread({}, markAttributes); // define attributes for text nodes
126
+
127
+
128
+ if (element.nodeName === 'STRONG') {
129
+ nodeAttributes.bold = true;
130
+ }
131
+
132
+ var nextFn = function nextFn(nodes) {
133
+ var childNodes = Array.from(nodes);
134
+ var children = Array.from(childNodes).map(function (node) {
135
+ return _this.deserializeEls(node, nodeAttributes);
136
+ }).flat();
137
+
138
+ if (children.length === 0) {
139
+ children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
140
+ }
141
+
142
+ return children;
143
+ };
144
+
145
+ var correctRule = _this.rules.reduce(function (res, rule) {
146
+ return res || rule.deserialize(element, nextFn);
147
+ }, null);
148
+
149
+ if (correctRule) {
150
+ return correctRule;
151
+ }
152
+
153
+ var childNodes = Array.from(element.childNodes);
154
+ var children = Array.from(childNodes).map(function (node) {
155
+ return _this.deserializeEls(node, nodeAttributes);
156
+ }).flat();
157
+
158
+ if (children.length === 0) {
159
+ children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
160
+ }
161
+
162
+ switch (element.nodeName) {
163
+ case 'TABLE':
164
+ return (0, _slateHyperscript.jsx)('element', {
165
+ type: 'table'
166
+ }, children);
167
+
168
+ case 'TBODY':
169
+ return (0, _slateHyperscript.jsx)('element', {
170
+ type: 'tbody'
171
+ }, children);
172
+
173
+ case 'TR':
174
+ return (0, _slateHyperscript.jsx)('element', {
175
+ type: 'tr'
176
+ }, children);
177
+
178
+ case 'TD':
179
+ return (0, _slateHyperscript.jsx)('element', {
180
+ type: 'td'
181
+ }, children);
182
+
183
+ case 'BODY':
184
+ return (0, _slateHyperscript.jsx)('fragment', {}, children);
185
+
186
+ case 'BR':
187
+ return '\n';
188
+
189
+ case 'BLOCKQUOTE':
190
+ return (0, _slateHyperscript.jsx)('element', {
191
+ type: 'quote'
192
+ }, children);
193
+
194
+ case 'P':
195
+ return (0, _slateHyperscript.jsx)('element', {
196
+ type: 'paragraph'
197
+ }, children);
198
+
199
+ case 'A':
200
+ return (0, _slateHyperscript.jsx)('element', {
201
+ type: 'link',
202
+ url: element.getAttribute('href')
203
+ }, children);
204
+
205
+ default:
206
+ return children;
207
+ }
208
+ });
209
+ this.defaultBlock = props.defaultBlock;
210
+ this.parseHtml = defaultParseHtml;
211
+ this.rules = props.rules;
212
+ });
213
+ var _default = Html;
214
+ exports["default"] = _default;
215
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["allWhitespace","node","test","textContent","defaultParseHtml","html","DOMParser","Error","parsed","parseFromString","body","textNodes","document","createTreeWalker","NodeFilter","SHOW_TEXT","n","nextNode","nodeValue","parentNode","removeChild","Html","props","Text","isText","string","escapeHtml","text","bold","children","map","serializeEls","correctRule","rules","reduce","res","rule","serialize","type","url","deserialized","ReactServer","renderToStaticMarkup","React","createElement","inner","slice","parseHtml","firstChild","nodeType","Node","TEXT_NODE","deserializeEls","element","markAttributes","jsx","ELEMENT_NODE","nodeAttributes","nodeName","nextFn","nodes","childNodes","Array","from","flat","length","push","deserialize","getAttribute","defaultBlock"],"sources":["../src/test-serializer.js"],"sourcesContent":["import React from 'react';\nimport ReactServer from 'react-dom/server';\nimport escapeHtml from 'escape-html';\nimport { Text } from 'slate';\nimport { jsx } from 'slate-hyperscript';\n\nfunction allWhitespace(node) {\n  // Use ECMA-262 Edition 3 String and RegExp features\n  return !/[^\\t\\n\\r ]/.test(node.textContent);\n}\n\nfunction defaultParseHtml(html) {\n  if (typeof DOMParser === 'undefined') {\n    throw new Error(\n      'The native `DOMParser` global which the `Html` serializer uses by default is not present in this environment. You must supply the `options.parseHtml` function instead.'\n    );\n  }\n\n  const parsed = new DOMParser().parseFromString(html, 'text/html');\n\n  const { body } = parsed;\n  const textNodes = document.createTreeWalker(body, NodeFilter.SHOW_TEXT, null, null);\n  let n = textNodes.nextNode();\n\n  while (n) {\n    if (allWhitespace(n) || n.nodeValue === '\\u200B') {\n      n.parentNode.removeChild(n);\n    }\n    n = textNodes.nextNode();\n  }\n\n  return body;\n}\n\nclass Html {\n  constructor(props) {\n    this.defaultBlock = props.defaultBlock;\n    this.parseHtml = defaultParseHtml;\n    this.rules = props.rules;\n  }\n\n  serializeEls = node => {\n    if (Text.isText(node)) {\n      let string = escapeHtml(node.text);\n      if (node.bold) {\n        string = <strong>{string}</strong>;\n      }\n      return string;\n    }\n\n    let children = (node.children || []).map(n => this.serializeEls(n));\n\n    const correctRule = this.rules.reduce((res, rule) => {\n      return res || rule.serialize(node, children);\n    }, null);\n\n    if (correctRule) {\n      return correctRule;\n    }\n\n    switch (node.type) {\n      case 'quote':\n        return (\n          <blockquote>\n            <p>{children}</p>\n          </blockquote>\n        );\n      case 'paragraph':\n        return <p>{children}</p>;\n      case 'link':\n        return <a href={escapeHtml(node.url)}>{children}</a>;\n      default:\n        return children;\n    }\n  };\n\n  serialize = node => {\n    const deserialized = this.serializeEls(node);\n    const html = ReactServer.renderToStaticMarkup(React.createElement(\n      'body',\n      null,\n      deserialized\n    ));\n    const inner = html.slice(6, -7);\n    return inner;\n  };\n\n  deserialize = html => {\n    let body = this.parseHtml(html);\n\n    if (body.firstChild && body.firstChild.nodeType === Node.TEXT_NODE) {\n      body = this.parseHtml(`<p>${html}</p>`);\n    }\n\n    return this.deserializeEls(body);\n  };\n\n  deserializeEls = (element, markAttributes = {}) => {\n    if (element.nodeType === Node.TEXT_NODE) {\n      return jsx('text', markAttributes, element.textContent);\n    } else if (element.nodeType !== Node.ELEMENT_NODE) {\n      return null;\n    }\n\n    const nodeAttributes = { ...markAttributes };\n\n    // define attributes for text nodes\n    if (element.nodeName === 'STRONG') {\n      nodeAttributes.bold = true;\n    }\n\n    const nextFn = nodes => {\n      const childNodes = Array.from(nodes);\n      const children = Array.from(childNodes)\n        .map(node => this.deserializeEls(node, nodeAttributes))\n        .flat();\n\n      if (children.length === 0) {\n        children.push(jsx('text', nodeAttributes, ''));\n      }\n\n      return children;\n    };\n\n    const correctRule = this.rules.reduce((res, rule) => {\n      return res || rule.deserialize(element, nextFn);\n    }, null);\n\n    if (correctRule) {\n      return correctRule;\n    }\n\n    const childNodes = Array.from(element.childNodes);\n    const children = Array.from(childNodes)\n      .map(node => this.deserializeEls(node, nodeAttributes))\n      .flat();\n\n    if (children.length === 0) {\n      children.push(jsx('text', nodeAttributes, ''));\n    }\n\n    switch (element.nodeName) {\n      case 'TABLE':\n        return jsx('element', { type: 'table' }, children);\n      case 'TBODY':\n        return jsx('element', { type: 'tbody' }, children);\n      case 'TR':\n        return jsx('element', { type: 'tr' }, children);\n      case 'TD':\n        return jsx('element', { type: 'td' }, children);\n      case 'BODY':\n        return jsx('fragment', {}, children);\n      case 'BR':\n        return '\\n';\n      case 'BLOCKQUOTE':\n        return jsx('element', { type: 'quote' }, children);\n      case 'P':\n        return jsx('element', { type: 'paragraph' }, children);\n      case 'A':\n        return jsx('element', { type: 'link', url: element.getAttribute('href') }, children);\n      default:\n        return children;\n    }\n  };\n}\n\nexport default Html;\n"],"mappings":"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"}
package/lib/with-mask.js CHANGED
@@ -38,7 +38,7 @@ var buildLayoutFromMarkup = function buildLayoutFromMarkup(markup, type) {
38
38
  processed = _componentize.markup;
39
39
 
40
40
  var value = (0, _serialization.deserialize)(processed);
41
- return value.document;
41
+ return value;
42
42
  };
43
43
 
44
44
  exports.buildLayoutFromMarkup = buildLayoutFromMarkup;
@@ -90,4 +90,4 @@ var withMask = function withMask(type, renderChildren) {
90
90
  };
91
91
 
92
92
  exports.withMask = withMask;
93
- //# sourceMappingURL=with-mask.js.map
93
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZExheW91dEZyb21NYXJrdXAiLCJtYXJrdXAiLCJ0eXBlIiwiY29tcG9uZW50aXplIiwicHJvY2Vzc2VkIiwidmFsdWUiLCJkZXNlcmlhbGl6ZSIsIndpdGhNYXNrIiwicmVuZGVyQ2hpbGRyZW4iLCJwcm9wcyIsImxheW91dCIsIm9uQ2hhbmdlIiwibWFza0xheW91dCIsIlJlYWN0IiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwic3RyaW5nIiwib2JqZWN0IiwiZnVuYyJdLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoLW1hc2suanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IE1hc2sgZnJvbSAnLi9tYXNrJztcbmltcG9ydCBjb21wb25lbnRpemUgZnJvbSAnLi9jb21wb25lbnRpemUnO1xuaW1wb3J0IHsgZGVzZXJpYWxpemUgfSBmcm9tICcuL3NlcmlhbGl6YXRpb24nO1xuXG5leHBvcnQgY29uc3QgYnVpbGRMYXlvdXRGcm9tTWFya3VwID0gKG1hcmt1cCwgdHlwZSkgPT4ge1xuICBjb25zdCB7IG1hcmt1cDogcHJvY2Vzc2VkIH0gPSBjb21wb25lbnRpemUobWFya3VwLCB0eXBlKTtcbiAgY29uc3QgdmFsdWUgPSBkZXNlcmlhbGl6ZShwcm9jZXNzZWQpO1xuICByZXR1cm4gdmFsdWU7XG59O1xuXG5leHBvcnQgY29uc3Qgd2l0aE1hc2sgPSAodHlwZSwgcmVuZGVyQ2hpbGRyZW4pID0+IHtcbiAgcmV0dXJuIGNsYXNzIFdpdGhNYXNrIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgICAgLyoqXG4gICAgICAgKiBBdCB0aGUgc3RhcnQgd2UnbGwgcHJvYmFibHkgd29yayB3aXRoIG1hcmt1cFxuICAgICAgICovXG4gICAgICBtYXJrdXA6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgICAvKipcbiAgICAgICAqIE9uY2Ugd2Ugc3RhcnQgYXV0aG9yaW5nLCBpdCBtYXkgbWFrZSBzZW5zZSBmb3IgdXNlIHRvIHVzIGxheW91dCwgd2hpY2ggd2lsbCBiZSBhIHNpbXBsZSBqcyBvYmplY3QgdGhhdCBtYXBzIHRvIGBzbGF0ZS5WYWx1ZWAuXG4gICAgICAgKi9cbiAgICAgIGxheW91dDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICAgIHZhbHVlOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgICAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jXG4gICAgfTtcblxuICAgIHJlbmRlcigpIHtcbiAgICAgIGNvbnN0IHsgbWFya3VwLCBsYXlvdXQsIHZhbHVlLCBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgICAgY29uc3QgbWFza0xheW91dCA9IGxheW91dCA/IGxheW91dCA6IGJ1aWxkTGF5b3V0RnJvbU1hcmt1cChtYXJrdXAsIHR5cGUpO1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPE1hc2tcbiAgICAgICAgICBsYXlvdXQ9e21hc2tMYXlvdXR9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICByZW5kZXJDaGlsZHJlbj17cmVuZGVyQ2hpbGRyZW4odGhpcy5wcm9wcyl9XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH1cbiAgfTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7QUFFTyxJQUFNQSxxQkFBcUIsR0FBRyxTQUF4QkEscUJBQXdCLENBQUNDLE1BQUQsRUFBU0MsSUFBVCxFQUFrQjtFQUNyRCxvQkFBOEIsSUFBQUMseUJBQUEsRUFBYUYsTUFBYixFQUFxQkMsSUFBckIsQ0FBOUI7RUFBQSxJQUFnQkUsU0FBaEIsaUJBQVFILE1BQVI7O0VBQ0EsSUFBTUksS0FBSyxHQUFHLElBQUFDLDBCQUFBLEVBQVlGLFNBQVosQ0FBZDtFQUNBLE9BQU9DLEtBQVA7QUFDRCxDQUpNOzs7O0FBTUEsSUFBTUUsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0wsSUFBRCxFQUFPTSxjQUFQLEVBQTBCO0VBQUE7O0VBQ2hEO0lBQUE7O0lBQUE7O0lBQUE7TUFBQTtNQUFBO0lBQUE7O0lBQUE7TUFBQTtNQUFBLE9BY0Usa0JBQVM7UUFDUCxrQkFBNEMsS0FBS0MsS0FBakQ7UUFBQSxJQUFRUixNQUFSLGVBQVFBLE1BQVI7UUFBQSxJQUFnQlMsTUFBaEIsZUFBZ0JBLE1BQWhCO1FBQUEsSUFBd0JMLEtBQXhCLGVBQXdCQSxLQUF4QjtRQUFBLElBQStCTSxRQUEvQixlQUErQkEsUUFBL0I7UUFFQSxJQUFNQyxVQUFVLEdBQUdGLE1BQU0sR0FBR0EsTUFBSCxHQUFZVixxQkFBcUIsQ0FBQ0MsTUFBRCxFQUFTQyxJQUFULENBQTFEO1FBQ0Esb0JBQ0UsZ0NBQUMsZ0JBQUQ7VUFDRSxNQUFNLEVBQUVVLFVBRFY7VUFFRSxLQUFLLEVBQUVQLEtBRlQ7VUFHRSxRQUFRLEVBQUVNLFFBSFo7VUFJRSxjQUFjLEVBQUVILGNBQWMsQ0FBQyxLQUFLQyxLQUFOO1FBSmhDLEVBREY7TUFRRDtJQTFCSDtJQUFBO0VBQUEsRUFBOEJJLGlCQUFBLENBQU1DLFNBQXBDLHlEQUNxQjtJQUNqQjtBQUNOO0FBQ0E7SUFDTWIsTUFBTSxFQUFFYyxxQkFBQSxDQUFVQyxNQUpEOztJQUtqQjtBQUNOO0FBQ0E7SUFDTU4sTUFBTSxFQUFFSyxxQkFBQSxDQUFVRSxNQVJEO0lBU2pCWixLQUFLLEVBQUVVLHFCQUFBLENBQVVFLE1BVEE7SUFVakJOLFFBQVEsRUFBRUkscUJBQUEsQ0FBVUc7RUFWSCxDQURyQjtBQTRCRCxDQTdCTSJ9
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/with-mask.jsx"],"names":["buildLayoutFromMarkup","markup","type","processed","value","document","withMask","renderChildren","props","layout","onChange","maskLayout","React","Component","PropTypes","string","object","func"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEO,IAAMA,qBAAqB,GAAG,SAAxBA,qBAAwB,CAACC,MAAD,EAASC,IAAT,EAAkB;AACrD,sBAA8B,+BAAaD,MAAb,EAAqBC,IAArB,CAA9B;AAAA,MAAgBC,SAAhB,iBAAQF,MAAR;;AACA,MAAMG,KAAK,GAAG,gCAAYD,SAAZ,CAAd;AACA,SAAOC,KAAK,CAACC,QAAb;AACD,CAJM;;;;AAMA,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACJ,IAAD,EAAOK,cAAP,EAA0B;AAAA;;AAChD;AAAA;;AAAA;;AAAA;AAAA;AAAA;AAAA;;AAAA;AAAA;AAAA,aAcE,kBAAS;AACP,0BAA4C,KAAKC,KAAjD;AAAA,YAAQP,MAAR,eAAQA,MAAR;AAAA,YAAgBQ,MAAhB,eAAgBA,MAAhB;AAAA,YAAwBL,KAAxB,eAAwBA,KAAxB;AAAA,YAA+BM,QAA/B,eAA+BA,QAA/B;AAEA,YAAMC,UAAU,GAAGF,MAAM,GAAGA,MAAH,GAAYT,qBAAqB,CAACC,MAAD,EAASC,IAAT,CAA1D;AACA,4BAAO,gCAAC,gBAAD;AAAM,UAAA,MAAM,EAAES,UAAd;AAA0B,UAAA,KAAK,EAAEP,KAAjC;AAAwC,UAAA,QAAQ,EAAEM,QAAlD;AAA4D,UAAA,cAAc,EAAEH,cAAc,CAAC,KAAKC,KAAN;AAA1F,UAAP;AACD;AAnBH;AAAA;AAAA,IAA8BI,kBAAMC,SAApC,yDACqB;AACjB;AACN;AACA;AACMZ,IAAAA,MAAM,EAAEa,sBAAUC,MAJD;;AAKjB;AACN;AACA;AACMN,IAAAA,MAAM,EAAEK,sBAAUE,MARD;AASjBZ,IAAAA,KAAK,EAAEU,sBAAUE,MATA;AAUjBN,IAAAA,QAAQ,EAAEI,sBAAUG;AAVH,GADrB;AAqBD,CAtBM","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Mask from './mask';\nimport componentize from './componentize';\nimport { deserialize } from './serialization';\n\nexport const buildLayoutFromMarkup = (markup, type) => {\n const { markup: processed } = componentize(markup, type);\n const value = deserialize(processed);\n return value.document;\n};\n\nexport const withMask = (type, renderChildren) => {\n return class WithMask extends React.Component {\n static propTypes = {\n /**\n * At the start we'll probably work with markup\n */\n markup: PropTypes.string,\n /**\n * Once we start authoring, it may make sense for use to us layout, which will be a simple js object that maps to `slate.Value`.\n */\n layout: PropTypes.object,\n value: PropTypes.object,\n onChange: PropTypes.func,\n };\n\n render() {\n const { markup, layout, value, onChange } = this.props;\n\n const maskLayout = layout ? layout : buildLayoutFromMarkup(markup, type);\n return <Mask layout={maskLayout} value={value} onChange={onChange} renderChildren={renderChildren(this.props)} />;\n }\n };\n};\n"],"file":"with-mask.js"}
1
+ {"version":3,"file":"with-mask.js","names":["buildLayoutFromMarkup","markup","type","componentize","processed","value","deserialize","document","withMask","renderChildren","props","layout","onChange","maskLayout","React","Component","PropTypes","string","object","func"],"sources":["../src/with-mask.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport Mask from './mask';\nimport componentize from './componentize';\nimport { deserialize } from './serialization';\n\nexport const buildLayoutFromMarkup = (markup, type) => {\n const { markup: processed } = componentize(markup, type);\n const value = deserialize(processed);\n return value.document;\n};\n\nexport const withMask = (type, renderChildren) => {\n return class WithMask extends React.Component {\n static propTypes = {\n /**\n * At the start we'll probably work with markup\n */\n markup: PropTypes.string,\n /**\n * Once we start authoring, it may make sense for use to us layout, which will be a simple js object that maps to `slate.Value`.\n */\n layout: PropTypes.object,\n value: PropTypes.object,\n onChange: PropTypes.func\n };\n\n render() {\n const { markup, layout, value, onChange } = this.props;\n\n const maskLayout = layout ? layout : buildLayoutFromMarkup(markup, type);\n return (\n <Mask\n layout={maskLayout}\n value={value}\n onChange={onChange}\n renderChildren={renderChildren(this.props)}\n />\n );\n }\n };\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEO,IAAMA,qBAAqB,GAAG,SAAxBA,qBAAwB,CAACC,MAAD,EAASC,IAAT,EAAkB;EACrD,oBAA8B,IAAAC,yBAAA,EAAaF,MAAb,EAAqBC,IAArB,CAA9B;EAAA,IAAgBE,SAAhB,iBAAQH,MAAR;;EACA,IAAMI,KAAK,GAAG,IAAAC,0BAAA,EAAYF,SAAZ,CAAd;EACA,OAAOC,KAAK,CAACE,QAAb;AACD,CAJM;;;;AAMA,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACN,IAAD,EAAOO,cAAP,EAA0B;EAAA;;EAChD;IAAA;;IAAA;;IAAA;MAAA;MAAA;IAAA;;IAAA;MAAA;MAAA,OAcE,kBAAS;QACP,kBAA4C,KAAKC,KAAjD;QAAA,IAAQT,MAAR,eAAQA,MAAR;QAAA,IAAgBU,MAAhB,eAAgBA,MAAhB;QAAA,IAAwBN,KAAxB,eAAwBA,KAAxB;QAAA,IAA+BO,QAA/B,eAA+BA,QAA/B;QAEA,IAAMC,UAAU,GAAGF,MAAM,GAAGA,MAAH,GAAYX,qBAAqB,CAACC,MAAD,EAASC,IAAT,CAA1D;QACA,oBACE,gCAAC,gBAAD;UACE,MAAM,EAAEW,UADV;UAEE,KAAK,EAAER,KAFT;UAGE,QAAQ,EAAEO,QAHZ;UAIE,cAAc,EAAEH,cAAc,CAAC,KAAKC,KAAN;QAJhC,EADF;MAQD;IA1BH;IAAA;EAAA,EAA8BI,iBAAA,CAAMC,SAApC,yDACqB;IACjB;AACN;AACA;IACMd,MAAM,EAAEe,qBAAA,CAAUC,MAJD;;IAKjB;AACN;AACA;IACMN,MAAM,EAAEK,qBAAA,CAAUE,MARD;IASjBb,KAAK,EAAEW,qBAAA,CAAUE,MATA;IAUjBN,QAAQ,EAAEI,qBAAA,CAAUG;EAVH,CADrB;AA4BD,CA7BM"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/mask-markup",
3
- "version": "1.13.13-next.0+2f8c6198",
3
+ "version": "2.0.0-beta.1",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "module": "src/index.js",
@@ -9,23 +9,24 @@
9
9
  },
10
10
  "dependencies": {
11
11
  "@material-ui/core": "^3.9.3",
12
- "@pie-lib/drag": "^2.1.13-next.0+2f8c6198",
13
- "@pie-lib/math-rendering": "^2.5.13-next.0+2f8c6198",
14
- "@pie-lib/render-ui": "^4.14.13-next.0+2f8c6198",
12
+ "@pie-lib/drag": "^1.1.52",
13
+ "@pie-lib/math-rendering": "^2.5.0",
14
+ "@pie-lib/render-ui": "^4.13.4",
15
15
  "classnames": "^2.2.6",
16
16
  "debug": "^4.1.1",
17
+ "escape-html": "^1.0.3",
17
18
  "immutable": ">=3.8.1",
18
19
  "prop-types": "^15.7.2",
19
20
  "react": "^16.8.1",
20
- "react-dnd-html5-backend": "^14.0.2",
21
- "slate": "^0.36.2",
22
- "slate-html-serializer": "^0.6.12",
23
- "slate-prop-types": "^0.4.38",
24
- "slate-react": "^0.14.3",
21
+ "react-dnd-html5-backend": "^11.1.3",
22
+ "slate": "^0.82.1",
23
+ "slate-html-serializer": "^0.8.13",
24
+ "slate-hyperscript": "^0.77.0",
25
+ "slate-prop-types": "^0.5.44",
26
+ "slate-react": "^0.82.1",
25
27
  "to-style": "^1.3.3"
26
28
  },
27
29
  "keywords": [],
28
30
  "author": "",
29
- "license": "ISC",
30
- "gitHead": "2f8c619845b4aa9a1c862b2ac549a975fe0bd13f"
31
+ "license": "ISC"
31
32
  }
@@ -14,7 +14,7 @@ class BlankContentComp extends React.Component {
14
14
  disabled: PropTypes.bool,
15
15
  choice: PropTypes.object,
16
16
  classes: PropTypes.object,
17
- connectDragSource: PropTypes.func,
17
+ connectDragSource: PropTypes.func
18
18
  };
19
19
 
20
20
  componentDidUpdate() {
@@ -27,7 +27,7 @@ class BlankContentComp extends React.Component {
27
27
  return connectDragSource(
28
28
  <span className={classnames(classes.choice, disabled && classes.disabled)}>
29
29
  <Chip
30
- ref={(ref) => {
30
+ ref={ref => {
31
31
  //eslint-disable-next-line
32
32
  this.rootRef = ReactDOM.findDOMNode(ref);
33
33
  }}
@@ -35,7 +35,7 @@ class BlankContentComp extends React.Component {
35
35
  label={
36
36
  <span
37
37
  className={classes.chipLabel}
38
- ref={(ref) => {
38
+ ref={ref => {
39
39
  if (ref) {
40
40
  ref.innerHTML = choice.value || ' ';
41
41
  }
@@ -47,14 +47,14 @@ class BlankContentComp extends React.Component {
47
47
  variant={disabled ? 'outlined' : undefined}
48
48
  />
49
49
  </span>,
50
- {},
50
+ {}
51
51
  );
52
52
  }
53
53
  }
54
54
 
55
- export const BlankContent = withStyles((theme) => ({
55
+ export const BlankContent = withStyles(theme => ({
56
56
  choice: {
57
- border: `solid 0px ${theme.palette.primary.main}`,
57
+ border: `solid 0px ${theme.palette.primary.main}`
58
58
  },
59
59
  chip: {
60
60
  alignItems: 'center',
@@ -64,16 +64,16 @@ export const BlankContent = withStyles((theme) => ({
64
64
  fontSize: 'inherit',
65
65
  whiteSpace: 'pre-wrap',
66
66
  maxWidth: '374px',
67
- margin: theme.spacing.unit / 2,
67
+ margin: '4px'
68
68
  },
69
69
  chipLabel: {
70
70
  whiteSpace: 'pre-wrap',
71
71
  '& img': {
72
72
  display: 'block',
73
- padding: '2px 0',
74
- },
73
+ padding: '2px 0'
74
+ }
75
75
  },
76
- disabled: {},
76
+ disabled: {}
77
77
  }))(BlankContentComp);
78
78
 
79
79
  const tileSource = {
@@ -83,14 +83,14 @@ const tileSource = {
83
83
  beginDrag(props) {
84
84
  return {
85
85
  choice: props.choice,
86
- instanceId: props.instanceId,
86
+ instanceId: props.instanceId
87
87
  };
88
- },
88
+ }
89
89
  };
90
90
 
91
91
  const DragDropTile = DragSource(DRAG_TYPE, tileSource, (connect, monitor) => ({
92
92
  connectDragSource: connect.dragSource(),
93
- isDragging: monitor.isDragging(),
93
+ isDragging: monitor.isDragging()
94
94
  }))(BlankContent);
95
95
 
96
96
  export default DragDropTile;
@@ -2,15 +2,16 @@ import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import findKey from 'lodash/findKey';
4
4
  import Choice from './choice';
5
- import DragDroppablePlaceholder from '@pie-lib/drag/lib/drag-in-the-blank-dp';
6
5
 
7
6
  export default class Choices extends React.Component {
8
7
  static propTypes = {
9
8
  disabled: PropTypes.bool,
10
9
  duplicates: PropTypes.bool,
11
- choices: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })),
10
+ choices: PropTypes.arrayOf(
11
+ PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })
12
+ ),
12
13
  value: PropTypes.object,
13
- choicePosition: PropTypes.string.isRequired,
14
+ choicePosition: PropTypes.string.isRequired
14
15
  };
15
16
 
16
17
  getStyleForWrapper = () => {
@@ -19,44 +20,39 @@ export default class Choices extends React.Component {
19
20
  switch (choicePosition) {
20
21
  case 'above':
21
22
  return {
22
- margin: '0 0 40px 0',
23
+ margin: '0 0 40px 0'
23
24
  };
24
-
25
25
  case 'below':
26
26
  return {
27
- margin: '40px 0 0 0',
27
+ margin: '40px 0 0 0'
28
28
  };
29
-
30
29
  case 'right':
31
30
  return {
32
- margin: '0 0 0 40px',
31
+ margin: '0 0 0 40px'
33
32
  };
34
-
35
33
  default:
36
34
  return {
37
- margin: '0 40px 0 0',
35
+ margin: '0 40px 0 0'
38
36
  };
39
37
  }
40
38
  };
41
39
 
42
40
  render() {
43
41
  const { disabled, duplicates, choices, value } = this.props;
44
- const filteredChoices = choices.filter((c) => {
42
+ const filteredChoices = choices.filter(c => {
45
43
  if (duplicates === true) {
46
44
  return true;
47
45
  }
48
- const foundChoice = findKey(value, (v) => v === c.id);
46
+ const foundChoice = findKey(value, v => v === c.id);
49
47
  return foundChoice === undefined;
50
48
  });
51
49
  const elementStyle = this.getStyleForWrapper();
52
50
 
53
51
  return (
54
52
  <div style={elementStyle}>
55
- <DragDroppablePlaceholder disabled={disabled}>
56
- {filteredChoices.map((c, index) => (
57
- <Choice key={`${c.value}-${index}`} disabled={disabled} choice={c} />
58
- ))}
59
- </DragDroppablePlaceholder>
53
+ {filteredChoices.map((c, index) => (
54
+ <Choice key={`${c.value}-${index}`} disabled={disabled} choice={c} />
55
+ ))}
60
56
  </div>
61
57
  );
62
58
  }
@@ -14,7 +14,7 @@ export const DRAG_TYPE = 'MaskBlank';
14
14
  const useStyles = withStyles(() => ({
15
15
  content: {
16
16
  border: `solid 0px ${color.primary()}`,
17
- minWidth: '200px',
17
+ minWidth: '200px'
18
18
  },
19
19
  chip: {
20
20
  minWidth: '90px',
@@ -22,34 +22,34 @@ const useStyles = withStyles(() => ({
22
22
  minHeight: '32px',
23
23
  height: 'auto',
24
24
  maxWidth: '374px',
25
- position: 'relative',
25
+ position: 'relative'
26
26
  },
27
27
  chipLabel: {
28
28
  whiteSpace: 'pre-wrap',
29
29
  '& img': {
30
30
  display: 'block',
31
- padding: '2px 0',
32
- },
31
+ padding: '2px 0'
32
+ }
33
33
  },
34
34
  hidden: {
35
35
  color: 'transparent',
36
- opacity: 0,
36
+ opacity: 0
37
37
  },
38
38
  dragged: {
39
39
  position: 'absolute',
40
40
  left: 14,
41
- maxWidth: '60px',
41
+ maxWidth: '60px'
42
42
  },
43
43
  correct: {
44
- border: `solid 1px ${color.correct()}`,
44
+ border: `solid 1px ${color.correct()}`
45
45
  },
46
46
  incorrect: {
47
- border: `solid 1px ${color.incorrect()}`,
47
+ border: `solid 1px ${color.incorrect()}`
48
48
  },
49
49
  over: {
50
50
  whiteSpace: 'nowrap',
51
- overflow: 'hidden',
52
- },
51
+ overflow: 'hidden'
52
+ }
53
53
  }));
54
54
 
55
55
  export class BlankContent extends React.Component {
@@ -62,13 +62,13 @@ export class BlankContent extends React.Component {
62
62
  isOver: PropTypes.bool,
63
63
  dragItem: PropTypes.object,
64
64
  correct: PropTypes.bool,
65
- onChange: PropTypes.func,
65
+ onChange: PropTypes.func
66
66
  };
67
67
 
68
68
  constructor() {
69
69
  super();
70
70
  this.state = {
71
- height: 0,
71
+ height: 0
72
72
  };
73
73
  }
74
74
 
@@ -80,20 +80,20 @@ export class BlankContent extends React.Component {
80
80
  if (JSON.stringify(currentChoice) !== JSON.stringify(prevChoice)) {
81
81
  if (!currentChoice) {
82
82
  this.setState({
83
- height: 0,
83
+ height: 0
84
84
  });
85
85
  return;
86
86
  }
87
87
  setTimeout(() => {
88
88
  this.setState({
89
- height: this.spanRef.offsetHeight,
89
+ height: this.spanRef.offsetHeight
90
90
  });
91
91
  }, 300);
92
92
  }
93
93
  }
94
94
 
95
95
  addDraggableFalseAttributes(parent) {
96
- parent.childNodes.forEach((elem) => {
96
+ parent.childNodes.forEach(elem => {
97
97
  if (elem instanceof Element || elem instanceof HTMLDocument) {
98
98
  elem.setAttribute('draggable', false);
99
99
  }
@@ -107,7 +107,7 @@ export class BlankContent extends React.Component {
107
107
 
108
108
  return (
109
109
  <Chip
110
- ref={(ref) => {
110
+ ref={ref => {
111
111
  //eslint-disable-next-line
112
112
  this.rootRef = ReactDOM.findDOMNode(ref);
113
113
  }}
@@ -116,9 +116,9 @@ export class BlankContent extends React.Component {
116
116
  <React.Fragment>
117
117
  <span
118
118
  className={classnames(classes.chipLabel, isOver && classes.over, {
119
- [classes.hidden]: draggedLabel,
119
+ [classes.hidden]: draggedLabel
120
120
  })}
121
- ref={(ref) => {
121
+ ref={ref => {
122
122
  if (ref) {
123
123
  //eslint-disable-next-line
124
124
  this.spanRef = ReactDOM.findDOMNode(ref);
@@ -132,7 +132,7 @@ export class BlankContent extends React.Component {
132
132
  {draggedLabel && (
133
133
  <span
134
134
  className={classnames(classes.chipLabel, isOver && classes.over, classes.dragged)}
135
- ref={(ref) => {
135
+ ref={ref => {
136
136
  if (ref) {
137
137
  //eslint-disable-next-line
138
138
  this.spanRef = ReactDOM.findDOMNode(ref);
@@ -148,14 +148,14 @@ export class BlankContent extends React.Component {
148
148
  }
149
149
  className={classnames(classes.chip, isOver && classes.over, {
150
150
  [classes.correct]: correct !== undefined && correct,
151
- [classes.incorrect]: correct !== undefined && !correct,
151
+ [classes.incorrect]: correct !== undefined && !correct
152
152
  })}
153
153
  variant={disabled ? 'outlined' : undefined}
154
154
  style={{
155
- ...(this.state.height ? { height: this.state.height } : {}),
155
+ ...(this.state.height ? { height: this.state.height } : {})
156
156
  }}
157
157
  classes={{
158
- label: isOver && classes.over,
158
+ label: isOver && classes.over
159
159
  }}
160
160
  />
161
161
  );
@@ -171,8 +171,8 @@ const connectedBlankContent = useStyles(({ connectDragSource, connectDropTarget,
171
171
  connectDragSource(
172
172
  <span className={classnames(classes.content, isOver && classes.over)}>
173
173
  <StyledBlankContent {...props} />
174
- </span>,
175
- ),
174
+ </span>
175
+ )
176
176
  );
177
177
  });
178
178
 
@@ -187,20 +187,20 @@ const tileTarget = {
187
187
  }
188
188
 
189
189
  return {
190
- dropped: draggedItem.id !== props.id,
190
+ dropped: draggedItem.id !== props.id
191
191
  };
192
192
  },
193
193
  canDrop(props, monitor) {
194
194
  const draggedItem = monitor.getItem();
195
195
 
196
196
  return draggedItem.instanceId === props.instanceId;
197
- },
197
+ }
198
198
  };
199
199
 
200
200
  const DropTile = DropTarget(DRAG_TYPE, tileTarget, (connect, monitor) => ({
201
201
  connectDropTarget: connect.dropTarget(),
202
202
  isOver: monitor.isOver(),
203
- dragItem: monitor.getItem(),
203
+ dragItem: monitor.getItem()
204
204
  }))(connectedBlankContent);
205
205
 
206
206
  const tileSource = {
@@ -212,7 +212,7 @@ const tileSource = {
212
212
  id: props.id,
213
213
  choice: props.choice,
214
214
  instanceId: props.instanceId,
215
- fromChoice: true,
215
+ fromChoice: true
216
216
  };
217
217
  },
218
218
  endDrag(props, monitor) {
@@ -226,12 +226,12 @@ const tileSource = {
226
226
  props.onChange(props.id, undefined);
227
227
  }
228
228
  }
229
- },
229
+ }
230
230
  };
231
231
 
232
232
  const DragDropTile = DragSource(DRAG_TYPE, tileSource, (connect, monitor) => ({
233
233
  connectDragSource: connect.dragSource(),
234
- isDragging: monitor.isDragging(),
234
+ isDragging: monitor.isDragging()
235
235
  }))(DropTile);
236
236
 
237
237
  export default DragDropTile;