@pie-lib/mask-markup 2.0.0-beta.1 → 2.0.0-beta.2

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 (52) hide show
  1. package/CHANGELOG.md +143 -35
  2. package/lib/choices/choice.js +22 -31
  3. package/lib/choices/choice.js.map +1 -1
  4. package/lib/choices/index.js +9 -33
  5. package/lib/choices/index.js.map +1 -1
  6. package/lib/componentize.js +1 -4
  7. package/lib/componentize.js.map +1 -1
  8. package/lib/components/blank.js +61 -86
  9. package/lib/components/blank.js.map +1 -1
  10. package/lib/components/correct-input.js +9 -25
  11. package/lib/components/correct-input.js.map +1 -1
  12. package/lib/components/dropdown.js +11 -37
  13. package/lib/components/dropdown.js.map +1 -1
  14. package/lib/components/input.js +14 -17
  15. package/lib/components/input.js.map +1 -1
  16. package/lib/constructed-response.js +11 -14
  17. package/lib/constructed-response.js.map +1 -1
  18. package/lib/drag-in-the-blank.js +21 -50
  19. package/lib/drag-in-the-blank.js.map +1 -1
  20. package/lib/index.js +1 -7
  21. package/lib/index.js.map +1 -1
  22. package/lib/inline-dropdown.js +6 -11
  23. package/lib/inline-dropdown.js.map +1 -1
  24. package/lib/mask.js +8 -49
  25. package/lib/mask.js.map +1 -1
  26. package/lib/new-serialization.js +6 -59
  27. package/lib/new-serialization.js.map +1 -0
  28. package/lib/parse-html.js +7 -6
  29. package/lib/parse-html.js.map +1 -0
  30. package/lib/serialization.js +9 -42
  31. package/lib/serialization.js.map +1 -1
  32. package/lib/test-serializer.js +4 -55
  33. package/lib/test-serializer.js.map +1 -0
  34. package/lib/with-mask.js +6 -30
  35. package/lib/with-mask.js.map +1 -1
  36. package/package.json +7 -7
  37. package/src/choices/choice.jsx +27 -13
  38. package/src/choices/index.jsx +17 -13
  39. package/src/components/blank.jsx +43 -31
  40. package/src/components/correct-input.jsx +18 -18
  41. package/src/components/dropdown.jsx +27 -38
  42. package/src/components/input.jsx +6 -3
  43. package/src/constructed-response.jsx +5 -4
  44. package/src/drag-in-the-blank.jsx +12 -12
  45. package/src/index.js +1 -8
  46. package/src/inline-dropdown.jsx +4 -3
  47. package/src/mask.jsx +13 -14
  48. package/src/new-serialization.jsx +19 -19
  49. package/src/parse-html.js +1 -1
  50. package/src/serialization.js +19 -14
  51. package/src/test-serializer.js +9 -9
  52. package/src/with-mask.jsx +2 -9
@@ -1,207 +1,156 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports["default"] = void 0;
9
-
10
8
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
11
-
12
9
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
-
14
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
-
16
11
  var _react = _interopRequireDefault(require("react"));
17
-
18
12
  var _server = _interopRequireDefault(require("react-dom/server"));
19
-
20
13
  var _escapeHtml = _interopRequireDefault(require("escape-html"));
21
-
22
14
  var _slate = require("slate");
23
-
24
15
  var _slateHyperscript = require("slate-hyperscript");
25
-
26
16
  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
17
  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
18
  function allWhitespace(node) {
31
19
  // Use ECMA-262 Edition 3 String and RegExp features
32
20
  return !/[^\t\n\r ]/.test(node.textContent);
33
21
  }
34
-
35
22
  function defaultParseHtml(html) {
36
23
  if (typeof DOMParser === 'undefined') {
37
24
  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
25
  }
39
-
40
26
  var parsed = new DOMParser().parseFromString(html, 'text/html');
41
27
  var body = parsed.body;
42
28
  var textNodes = document.createTreeWalker(body, NodeFilter.SHOW_TEXT, null, null);
43
29
  var n = textNodes.nextNode();
44
-
45
30
  while (n) {
46
31
  if (allWhitespace(n) || n.nodeValue === "\u200B") {
47
32
  n.parentNode.removeChild(n);
48
33
  }
49
-
50
34
  n = textNodes.nextNode();
51
35
  }
52
-
53
36
  return body;
54
37
  }
55
-
56
38
  var Html = /*#__PURE__*/(0, _createClass2["default"])(function Html(props) {
57
39
  var _this = this;
58
-
59
40
  (0, _classCallCheck2["default"])(this, Html);
60
41
  (0, _defineProperty2["default"])(this, "serializeEls", function (node) {
61
42
  if (_slate.Text.isText(node)) {
62
43
  var string = (0, _escapeHtml["default"])(node.text);
63
-
64
44
  if (node.bold) {
65
45
  string = /*#__PURE__*/_react["default"].createElement("strong", null, string);
66
46
  }
67
-
68
47
  return string;
69
48
  }
70
-
71
49
  var children = (node.children || []).map(function (n) {
72
50
  return _this.serializeEls(n);
73
51
  });
74
-
75
52
  var correctRule = _this.rules.reduce(function (res, rule) {
76
53
  return res || rule.serialize(node, children);
77
54
  }, null);
78
-
79
55
  if (correctRule) {
80
56
  return correctRule;
81
57
  }
82
-
83
58
  switch (node.type) {
84
59
  case 'quote':
85
60
  return /*#__PURE__*/_react["default"].createElement("blockquote", null, /*#__PURE__*/_react["default"].createElement("p", null, children));
86
-
87
61
  case 'paragraph':
88
62
  return /*#__PURE__*/_react["default"].createElement("p", null, children);
89
-
90
63
  case 'link':
91
64
  return /*#__PURE__*/_react["default"].createElement("a", {
92
65
  href: (0, _escapeHtml["default"])(node.url)
93
66
  }, children);
94
-
95
67
  default:
96
68
  return children;
97
69
  }
98
70
  });
99
71
  (0, _defineProperty2["default"])(this, "serialize", function (node) {
100
72
  var deserialized = _this.serializeEls(node);
101
-
102
73
  var html = _server["default"].renderToStaticMarkup( /*#__PURE__*/_react["default"].createElement('body', null, deserialized));
103
-
104
74
  var inner = html.slice(6, -7);
105
75
  return inner;
106
76
  });
107
77
  (0, _defineProperty2["default"])(this, "deserialize", function (html) {
108
78
  var body = _this.parseHtml(html);
109
-
110
79
  if (body.firstChild && body.firstChild.nodeType === Node.TEXT_NODE) {
111
- body = _this.parseHtml("<p>".concat(html, "</p>"));
80
+ body = _this.parseHtml("<span>".concat(html, "</span>"));
112
81
  }
113
-
114
82
  return _this.deserializeEls(body);
115
83
  });
116
84
  (0, _defineProperty2["default"])(this, "deserializeEls", function (element) {
117
85
  var markAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
118
-
119
86
  if (element.nodeType === Node.TEXT_NODE) {
120
87
  return (0, _slateHyperscript.jsx)('text', markAttributes, element.textContent);
121
88
  } else if (element.nodeType !== Node.ELEMENT_NODE) {
122
89
  return null;
123
90
  }
91
+ var nodeAttributes = _objectSpread({}, markAttributes);
124
92
 
125
- var nodeAttributes = _objectSpread({}, markAttributes); // define attributes for text nodes
126
-
127
-
93
+ // define attributes for text nodes
128
94
  if (element.nodeName === 'STRONG') {
129
95
  nodeAttributes.bold = true;
130
96
  }
131
-
132
97
  var nextFn = function nextFn(nodes) {
133
98
  var childNodes = Array.from(nodes);
134
99
  var children = Array.from(childNodes).map(function (node) {
135
100
  return _this.deserializeEls(node, nodeAttributes);
136
101
  }).flat();
137
-
138
102
  if (children.length === 0) {
139
103
  children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
140
104
  }
141
-
142
105
  return children;
143
106
  };
144
-
145
107
  var correctRule = _this.rules.reduce(function (res, rule) {
146
108
  return res || rule.deserialize(element, nextFn);
147
109
  }, null);
148
-
149
110
  if (correctRule) {
150
111
  return correctRule;
151
112
  }
152
-
153
113
  var childNodes = Array.from(element.childNodes);
154
114
  var children = Array.from(childNodes).map(function (node) {
155
115
  return _this.deserializeEls(node, nodeAttributes);
156
116
  }).flat();
157
-
158
117
  if (children.length === 0) {
159
118
  children.push((0, _slateHyperscript.jsx)('text', nodeAttributes, ''));
160
119
  }
161
-
162
120
  switch (element.nodeName) {
163
121
  case 'TABLE':
164
122
  return (0, _slateHyperscript.jsx)('element', {
165
123
  type: 'table'
166
124
  }, children);
167
-
168
125
  case 'TBODY':
169
126
  return (0, _slateHyperscript.jsx)('element', {
170
127
  type: 'tbody'
171
128
  }, children);
172
-
173
129
  case 'TR':
174
130
  return (0, _slateHyperscript.jsx)('element', {
175
131
  type: 'tr'
176
132
  }, children);
177
-
178
133
  case 'TD':
179
134
  return (0, _slateHyperscript.jsx)('element', {
180
135
  type: 'td'
181
136
  }, children);
182
-
183
137
  case 'BODY':
184
138
  return (0, _slateHyperscript.jsx)('fragment', {}, children);
185
-
186
139
  case 'BR':
187
140
  return '\n';
188
-
189
141
  case 'BLOCKQUOTE':
190
142
  return (0, _slateHyperscript.jsx)('element', {
191
143
  type: 'quote'
192
144
  }, children);
193
-
194
145
  case 'P':
195
146
  return (0, _slateHyperscript.jsx)('element', {
196
147
  type: 'paragraph'
197
148
  }, children);
198
-
199
149
  case 'A':
200
150
  return (0, _slateHyperscript.jsx)('element', {
201
151
  type: 'link',
202
152
  url: element.getAttribute('href')
203
153
  }, children);
204
-
205
154
  default:
206
155
  return children;
207
156
  }
@@ -212,4 +161,4 @@ var Html = /*#__PURE__*/(0, _createClass2["default"])(function Html(props) {
212
161
  });
213
162
  var _default = Html;
214
163
  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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"}
164
+ //# sourceMappingURL=test-serializer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test-serializer.js","names":["_react","_interopRequireDefault","require","_server","_escapeHtml","_slate","_slateHyperscript","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","allWhitespace","node","test","textContent","defaultParseHtml","html","DOMParser","Error","parsed","parseFromString","body","textNodes","document","createTreeWalker","NodeFilter","SHOW_TEXT","n","nextNode","nodeValue","parentNode","removeChild","Html","_createClass2","props","_this","_classCallCheck2","Text","isText","string","escapeHtml","text","bold","createElement","children","map","serializeEls","correctRule","rules","reduce","res","rule","serialize","type","href","url","deserialized","ReactServer","renderToStaticMarkup","React","inner","slice","parseHtml","firstChild","nodeType","Node","TEXT_NODE","concat","deserializeEls","element","markAttributes","undefined","jsx","ELEMENT_NODE","nodeAttributes","nodeName","nextFn","nodes","childNodes","Array","from","flat","deserialize","getAttribute","defaultBlock","_default","exports"],"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('body', null, deserialized));\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(`<span>${html}</span>`);\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
@@ -1,69 +1,47 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.withMask = exports.buildLayoutFromMarkup = void 0;
9
-
10
8
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
9
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
10
  var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
-
16
11
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
17
-
18
12
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
19
-
20
13
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
-
22
14
  var _react = _interopRequireDefault(require("react"));
23
-
24
15
  var _propTypes = _interopRequireDefault(require("prop-types"));
25
-
26
16
  var _mask = _interopRequireDefault(require("./mask"));
27
-
28
17
  var _componentize2 = _interopRequireDefault(require("./componentize"));
29
-
30
18
  var _serialization = require("./serialization");
31
-
32
19
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
33
-
34
20
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
35
-
36
21
  var buildLayoutFromMarkup = function buildLayoutFromMarkup(markup, type) {
37
22
  var _componentize = (0, _componentize2["default"])(markup, type),
38
- processed = _componentize.markup;
39
-
23
+ processed = _componentize.markup;
40
24
  var value = (0, _serialization.deserialize)(processed);
41
25
  return value;
42
26
  };
43
-
44
27
  exports.buildLayoutFromMarkup = buildLayoutFromMarkup;
45
-
46
28
  var withMask = function withMask(type, renderChildren) {
47
29
  var _class;
48
-
49
30
  return _class = /*#__PURE__*/function (_React$Component) {
50
31
  (0, _inherits2["default"])(WithMask, _React$Component);
51
-
52
32
  var _super = _createSuper(WithMask);
53
-
54
33
  function WithMask() {
55
34
  (0, _classCallCheck2["default"])(this, WithMask);
56
35
  return _super.apply(this, arguments);
57
36
  }
58
-
59
37
  (0, _createClass2["default"])(WithMask, [{
60
38
  key: "render",
61
39
  value: function render() {
62
40
  var _this$props = this.props,
63
- markup = _this$props.markup,
64
- layout = _this$props.layout,
65
- value = _this$props.value,
66
- onChange = _this$props.onChange;
41
+ markup = _this$props.markup,
42
+ layout = _this$props.layout,
43
+ value = _this$props.value,
44
+ onChange = _this$props.onChange;
67
45
  var maskLayout = layout ? layout : buildLayoutFromMarkup(markup, type);
68
46
  return /*#__PURE__*/_react["default"].createElement(_mask["default"], {
69
47
  layout: maskLayout,
@@ -79,7 +57,6 @@ var withMask = function withMask(type, renderChildren) {
79
57
  * At the start we'll probably work with markup
80
58
  */
81
59
  markup: _propTypes["default"].string,
82
-
83
60
  /**
84
61
  * 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`.
85
62
  */
@@ -88,6 +65,5 @@ var withMask = function withMask(type, renderChildren) {
88
65
  onChange: _propTypes["default"].func
89
66
  }), _class;
90
67
  };
91
-
92
68
  exports.withMask = withMask;
93
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZExheW91dEZyb21NYXJrdXAiLCJtYXJrdXAiLCJ0eXBlIiwiY29tcG9uZW50aXplIiwicHJvY2Vzc2VkIiwidmFsdWUiLCJkZXNlcmlhbGl6ZSIsIndpdGhNYXNrIiwicmVuZGVyQ2hpbGRyZW4iLCJwcm9wcyIsImxheW91dCIsIm9uQ2hhbmdlIiwibWFza0xheW91dCIsIlJlYWN0IiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwic3RyaW5nIiwib2JqZWN0IiwiZnVuYyJdLCJzb3VyY2VzIjpbIi4uL3NyYy93aXRoLW1hc2suanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IE1hc2sgZnJvbSAnLi9tYXNrJztcbmltcG9ydCBjb21wb25lbnRpemUgZnJvbSAnLi9jb21wb25lbnRpemUnO1xuaW1wb3J0IHsgZGVzZXJpYWxpemUgfSBmcm9tICcuL3NlcmlhbGl6YXRpb24nO1xuXG5leHBvcnQgY29uc3QgYnVpbGRMYXlvdXRGcm9tTWFya3VwID0gKG1hcmt1cCwgdHlwZSkgPT4ge1xuICBjb25zdCB7IG1hcmt1cDogcHJvY2Vzc2VkIH0gPSBjb21wb25lbnRpemUobWFya3VwLCB0eXBlKTtcbiAgY29uc3QgdmFsdWUgPSBkZXNlcmlhbGl6ZShwcm9jZXNzZWQpO1xuICByZXR1cm4gdmFsdWU7XG59O1xuXG5leHBvcnQgY29uc3Qgd2l0aE1hc2sgPSAodHlwZSwgcmVuZGVyQ2hpbGRyZW4pID0+IHtcbiAgcmV0dXJuIGNsYXNzIFdpdGhNYXNrIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgICAgLyoqXG4gICAgICAgKiBBdCB0aGUgc3RhcnQgd2UnbGwgcHJvYmFibHkgd29yayB3aXRoIG1hcmt1cFxuICAgICAgICovXG4gICAgICBtYXJrdXA6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgICAvKipcbiAgICAgICAqIE9uY2Ugd2Ugc3RhcnQgYXV0aG9yaW5nLCBpdCBtYXkgbWFrZSBzZW5zZSBmb3IgdXNlIHRvIHVzIGxheW91dCwgd2hpY2ggd2lsbCBiZSBhIHNpbXBsZSBqcyBvYmplY3QgdGhhdCBtYXBzIHRvIGBzbGF0ZS5WYWx1ZWAuXG4gICAgICAgKi9cbiAgICAgIGxheW91dDogUHJvcFR5cGVzLm9iamVjdCxcbiAgICAgIHZhbHVlOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgICAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jXG4gICAgfTtcblxuICAgIHJlbmRlcigpIHtcbiAgICAgIGNvbnN0IHsgbWFya3VwLCBsYXlvdXQsIHZhbHVlLCBvbkNoYW5nZSB9ID0gdGhpcy5wcm9wcztcblxuICAgICAgY29uc3QgbWFza0xheW91dCA9IGxheW91dCA/IGxheW91dCA6IGJ1aWxkTGF5b3V0RnJvbU1hcmt1cChtYXJrdXAsIHR5cGUpO1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPE1hc2tcbiAgICAgICAgICBsYXlvdXQ9e21hc2tMYXlvdXR9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgICAgICByZW5kZXJDaGlsZHJlbj17cmVuZGVyQ2hpbGRyZW4odGhpcy5wcm9wcyl9XG4gICAgICAgIC8+XG4gICAgICApO1xuICAgIH1cbiAgfTtcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7QUFFTyxJQUFNQSxxQkFBcUIsR0FBRyxTQUF4QkEscUJBQXdCLENBQUNDLE1BQUQsRUFBU0MsSUFBVCxFQUFrQjtFQUNyRCxvQkFBOEIsSUFBQUMseUJBQUEsRUFBYUYsTUFBYixFQUFxQkMsSUFBckIsQ0FBOUI7RUFBQSxJQUFnQkUsU0FBaEIsaUJBQVFILE1BQVI7O0VBQ0EsSUFBTUksS0FBSyxHQUFHLElBQUFDLDBCQUFBLEVBQVlGLFNBQVosQ0FBZDtFQUNBLE9BQU9DLEtBQVA7QUFDRCxDQUpNOzs7O0FBTUEsSUFBTUUsUUFBUSxHQUFHLFNBQVhBLFFBQVcsQ0FBQ0wsSUFBRCxFQUFPTSxjQUFQLEVBQTBCO0VBQUE7O0VBQ2hEO0lBQUE7O0lBQUE7O0lBQUE7TUFBQTtNQUFBO0lBQUE7O0lBQUE7TUFBQTtNQUFBLE9BY0Usa0JBQVM7UUFDUCxrQkFBNEMsS0FBS0MsS0FBakQ7UUFBQSxJQUFRUixNQUFSLGVBQVFBLE1BQVI7UUFBQSxJQUFnQlMsTUFBaEIsZUFBZ0JBLE1BQWhCO1FBQUEsSUFBd0JMLEtBQXhCLGVBQXdCQSxLQUF4QjtRQUFBLElBQStCTSxRQUEvQixlQUErQkEsUUFBL0I7UUFFQSxJQUFNQyxVQUFVLEdBQUdGLE1BQU0sR0FBR0EsTUFBSCxHQUFZVixxQkFBcUIsQ0FBQ0MsTUFBRCxFQUFTQyxJQUFULENBQTFEO1FBQ0Esb0JBQ0UsZ0NBQUMsZ0JBQUQ7VUFDRSxNQUFNLEVBQUVVLFVBRFY7VUFFRSxLQUFLLEVBQUVQLEtBRlQ7VUFHRSxRQUFRLEVBQUVNLFFBSFo7VUFJRSxjQUFjLEVBQUVILGNBQWMsQ0FBQyxLQUFLQyxLQUFOO1FBSmhDLEVBREY7TUFRRDtJQTFCSDtJQUFBO0VBQUEsRUFBOEJJLGlCQUFBLENBQU1DLFNBQXBDLHlEQUNxQjtJQUNqQjtBQUNOO0FBQ0E7SUFDTWIsTUFBTSxFQUFFYyxxQkFBQSxDQUFVQyxNQUpEOztJQUtqQjtBQUNOO0FBQ0E7SUFDTU4sTUFBTSxFQUFFSyxxQkFBQSxDQUFVRSxNQVJEO0lBU2pCWixLQUFLLEVBQUVVLHFCQUFBLENBQVVFLE1BVEE7SUFVakJOLFFBQVEsRUFBRUkscUJBQUEsQ0FBVUc7RUFWSCxDQURyQjtBQTRCRCxDQTdCTSJ9
69
+ //# sourceMappingURL=with-mask.js.map
@@ -1 +1 @@
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"}
1
+ {"version":3,"file":"with-mask.js","names":["_react","_interopRequireDefault","require","_propTypes","_mask","_componentize2","_serialization","_createSuper","Derived","hasNativeReflectConstruct","_isNativeReflectConstruct","_createSuperInternal","Super","_getPrototypeOf2","result","NewTarget","constructor","Reflect","construct","arguments","apply","_possibleConstructorReturn2","sham","Proxy","Boolean","prototype","valueOf","call","e","buildLayoutFromMarkup","markup","type","_componentize","componentize","processed","value","deserialize","exports","withMask","renderChildren","_class","_React$Component","_inherits2","WithMask","_super","_classCallCheck2","_createClass2","key","render","_this$props","props","layout","onChange","maskLayout","createElement","React","Component","_defineProperty2","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;\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"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pie-lib/mask-markup",
3
- "version": "2.0.0-beta.1",
3
+ "version": "2.0.0-beta.2",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "module": "src/index.js",
@@ -9,21 +9,21 @@
9
9
  },
10
10
  "dependencies": {
11
11
  "@material-ui/core": "^3.9.3",
12
- "@pie-lib/drag": "^1.1.52",
13
- "@pie-lib/math-rendering": "^2.5.0",
14
- "@pie-lib/render-ui": "^4.13.4",
12
+ "@pie-lib/drag": "^2.2.1",
13
+ "@pie-lib/math-rendering": "^2.5.17",
14
+ "@pie-lib/render-ui": "^4.14.28",
15
15
  "classnames": "^2.2.6",
16
16
  "debug": "^4.1.1",
17
17
  "escape-html": "^1.0.3",
18
18
  "immutable": ">=3.8.1",
19
19
  "prop-types": "^15.7.2",
20
20
  "react": "^16.8.1",
21
- "react-dnd-html5-backend": "^11.1.3",
22
- "slate": "^0.82.1",
21
+ "react-dnd-html5-backend": "^14.0.2",
22
+ "slate": "^0.94.1",
23
23
  "slate-html-serializer": "^0.8.13",
24
24
  "slate-hyperscript": "^0.77.0",
25
25
  "slate-prop-types": "^0.5.44",
26
- "slate-react": "^0.82.1",
26
+ "slate-react": "^0.97.2",
27
27
  "to-style": "^1.3.3"
28
28
  },
29
29
  "keywords": [],
@@ -6,6 +6,7 @@ import Chip from '@material-ui/core/Chip';
6
6
  import classnames from 'classnames';
7
7
  import ReactDOM from 'react-dom';
8
8
  import { renderMath } from '@pie-lib/math-rendering';
9
+ import { color } from '@pie-lib/render-ui';
9
10
 
10
11
  export const DRAG_TYPE = 'MaskBlank';
11
12
 
@@ -14,7 +15,7 @@ class BlankContentComp extends React.Component {
14
15
  disabled: PropTypes.bool,
15
16
  choice: PropTypes.object,
16
17
  classes: PropTypes.object,
17
- connectDragSource: PropTypes.func
18
+ connectDragSource: PropTypes.func,
18
19
  };
19
20
 
20
21
  componentDidUpdate() {
@@ -24,10 +25,14 @@ class BlankContentComp extends React.Component {
24
25
  render() {
25
26
  const { connectDragSource, choice, classes, disabled } = this.props;
26
27
 
28
+ // TODO the Chip element is causing drag problems on touch devices. Avoid using Chip and consider refactoring the code. Keep in mind that Chip is a span with a button role, which interferes with seamless touch device dragging.
29
+
27
30
  return connectDragSource(
28
31
  <span className={classnames(classes.choice, disabled && classes.disabled)}>
29
32
  <Chip
30
- ref={ref => {
33
+ clickable={false}
34
+ disabled={true}
35
+ ref={(ref) => {
31
36
  //eslint-disable-next-line
32
37
  this.rootRef = ReactDOM.findDOMNode(ref);
33
38
  }}
@@ -35,7 +40,7 @@ class BlankContentComp extends React.Component {
35
40
  label={
36
41
  <span
37
42
  className={classes.chipLabel}
38
- ref={ref => {
43
+ ref={(ref) => {
39
44
  if (ref) {
40
45
  ref.innerHTML = choice.value || ' ';
41
46
  }
@@ -47,16 +52,22 @@ class BlankContentComp extends React.Component {
47
52
  variant={disabled ? 'outlined' : undefined}
48
53
  />
49
54
  </span>,
50
- {}
55
+ {},
51
56
  );
52
57
  }
53
58
  }
54
59
 
55
- export const BlankContent = withStyles(theme => ({
60
+ export const BlankContent = withStyles((theme) => ({
56
61
  choice: {
57
- border: `solid 0px ${theme.palette.primary.main}`
62
+ border: `solid 0px ${theme.palette.primary.main}`,
63
+ borderRadius: theme.spacing.unit * 2,
64
+ margin: theme.spacing.unit / 2,
65
+ transform: 'translate(0, 0)',
58
66
  },
59
67
  chip: {
68
+ backgroundColor: color.background(),
69
+ border: `1px solid ${color.text()}`,
70
+ color: color.text(),
60
71
  alignItems: 'center',
61
72
  display: 'inline-flex',
62
73
  height: 'initial',
@@ -64,16 +75,19 @@ export const BlankContent = withStyles(theme => ({
64
75
  fontSize: 'inherit',
65
76
  whiteSpace: 'pre-wrap',
66
77
  maxWidth: '374px',
67
- margin: '4px'
78
+ // Added for touch devices, for image content.
79
+ // This will prevent the context menu from appearing and not allowing other interactions with the image.
80
+ // If interactions with the image in the token will be requested we should handle only the context Menu.
81
+ pointerEvents: 'none',
68
82
  },
69
83
  chipLabel: {
70
84
  whiteSpace: 'pre-wrap',
71
85
  '& img': {
72
86
  display: 'block',
73
- padding: '2px 0'
74
- }
87
+ padding: '2px 0',
88
+ },
75
89
  },
76
- disabled: {}
90
+ disabled: {},
77
91
  }))(BlankContentComp);
78
92
 
79
93
  const tileSource = {
@@ -83,14 +97,14 @@ const tileSource = {
83
97
  beginDrag(props) {
84
98
  return {
85
99
  choice: props.choice,
86
- instanceId: props.instanceId
100
+ instanceId: props.instanceId,
87
101
  };
88
- }
102
+ },
89
103
  };
90
104
 
91
105
  const DragDropTile = DragSource(DRAG_TYPE, tileSource, (connect, monitor) => ({
92
106
  connectDragSource: connect.dragSource(),
93
- isDragging: monitor.isDragging()
107
+ isDragging: monitor.isDragging(),
94
108
  }))(BlankContent);
95
109
 
96
110
  export default DragDropTile;
@@ -2,16 +2,15 @@ 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';
5
6
 
6
7
  export default class Choices extends React.Component {
7
8
  static propTypes = {
8
9
  disabled: PropTypes.bool,
9
10
  duplicates: PropTypes.bool,
10
- choices: PropTypes.arrayOf(
11
- PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })
12
- ),
11
+ choices: PropTypes.arrayOf(PropTypes.shape({ label: PropTypes.string, value: PropTypes.string })),
13
12
  value: PropTypes.object,
14
- choicePosition: PropTypes.string.isRequired
13
+ choicePosition: PropTypes.string.isRequired,
15
14
  };
16
15
 
17
16
  getStyleForWrapper = () => {
@@ -20,39 +19,44 @@ export default class Choices extends React.Component {
20
19
  switch (choicePosition) {
21
20
  case 'above':
22
21
  return {
23
- margin: '0 0 40px 0'
22
+ margin: '0 0 40px 0',
24
23
  };
24
+
25
25
  case 'below':
26
26
  return {
27
- margin: '40px 0 0 0'
27
+ margin: '40px 0 0 0',
28
28
  };
29
+
29
30
  case 'right':
30
31
  return {
31
- margin: '0 0 0 40px'
32
+ margin: '0 0 0 40px',
32
33
  };
34
+
33
35
  default:
34
36
  return {
35
- margin: '0 40px 0 0'
37
+ margin: '0 40px 0 0',
36
38
  };
37
39
  }
38
40
  };
39
41
 
40
42
  render() {
41
43
  const { disabled, duplicates, choices, value } = this.props;
42
- const filteredChoices = choices.filter(c => {
44
+ const filteredChoices = choices.filter((c) => {
43
45
  if (duplicates === true) {
44
46
  return true;
45
47
  }
46
- const foundChoice = findKey(value, v => v === c.id);
48
+ const foundChoice = findKey(value, (v) => v === c.id);
47
49
  return foundChoice === undefined;
48
50
  });
49
51
  const elementStyle = this.getStyleForWrapper();
50
52
 
51
53
  return (
52
54
  <div style={elementStyle}>
53
- {filteredChoices.map((c, index) => (
54
- <Choice key={`${c.value}-${index}`} disabled={disabled} choice={c} />
55
- ))}
55
+ <DragDroppablePlaceholder disabled={disabled}>
56
+ {filteredChoices.map((c, index) => (
57
+ <Choice key={`${c.value}-${index}`} disabled={disabled} choice={c} />
58
+ ))}
59
+ </DragDroppablePlaceholder>
56
60
  </div>
57
61
  );
58
62
  }