@pie-lib/editable-html 9.5.13 → 10.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 (144) hide show
  1. package/CHANGELOG.md +0 -302
  2. package/lib/components.js +116 -0
  3. package/lib/components.js.map +1 -0
  4. package/lib/editor.js +418 -103
  5. package/lib/editor.js.map +1 -1
  6. package/lib/index.js +101 -155
  7. package/lib/index.js.map +1 -1
  8. package/lib/new-serialization.js +320 -0
  9. package/lib/new-serialization.js.map +1 -0
  10. package/lib/old-serialization.js +330 -0
  11. package/lib/parse-html.js +1 -1
  12. package/lib/parse-html.js.map +1 -1
  13. package/lib/plugins/characters/custom-popper.js +1 -1
  14. package/lib/plugins/characters/custom-popper.js.map +1 -1
  15. package/lib/plugins/characters/index.js +21 -19
  16. package/lib/plugins/characters/index.js.map +1 -1
  17. package/lib/plugins/characters/utils.js +1 -1
  18. package/lib/plugins/characters/utils.js.map +1 -1
  19. package/lib/plugins/hotKeys/index.js +67 -0
  20. package/lib/plugins/hotKeys/index.js.map +1 -0
  21. package/lib/plugins/image/alt-dialog.js +1 -6
  22. package/lib/plugins/image/alt-dialog.js.map +1 -1
  23. package/lib/plugins/image/component.js +70 -53
  24. package/lib/plugins/image/component.js.map +1 -1
  25. package/lib/plugins/image/image-toolbar.js +7 -9
  26. package/lib/plugins/image/image-toolbar.js.map +1 -1
  27. package/lib/plugins/image/index.js +83 -27
  28. package/lib/plugins/image/index.js.map +1 -1
  29. package/lib/plugins/image/insert-image-handler.js +72 -33
  30. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  31. package/lib/plugins/index.js +23 -41
  32. package/lib/plugins/index.js.map +1 -1
  33. package/lib/plugins/list/index.js +64 -100
  34. package/lib/plugins/list/index.js.map +1 -1
  35. package/lib/plugins/math/index.js +86 -60
  36. package/lib/plugins/math/index.js.map +1 -1
  37. package/lib/plugins/media/index.js +202 -132
  38. package/lib/plugins/media/index.js.map +1 -1
  39. package/lib/plugins/media/media-dialog.js +17 -16
  40. package/lib/plugins/media/media-dialog.js.map +1 -1
  41. package/lib/plugins/media/media-toolbar.js +3 -3
  42. package/lib/plugins/media/media-toolbar.js.map +1 -1
  43. package/lib/plugins/media/media-wrapper.js +21 -58
  44. package/lib/plugins/media/media-wrapper.js.map +1 -1
  45. package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
  46. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  47. package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
  48. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  49. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
  50. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  51. package/lib/plugins/respArea/icons/index.js +13 -15
  52. package/lib/plugins/respArea/icons/index.js.map +1 -1
  53. package/lib/plugins/respArea/index.js +87 -53
  54. package/lib/plugins/respArea/index.js.map +1 -1
  55. package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
  56. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  57. package/lib/plugins/respArea/utils.js +17 -20
  58. package/lib/plugins/respArea/utils.js.map +1 -1
  59. package/lib/plugins/table/icons/index.js +1 -1
  60. package/lib/plugins/table/icons/index.js.map +1 -1
  61. package/lib/plugins/table/index.js +381 -212
  62. package/lib/plugins/table/index.js.map +1 -1
  63. package/lib/plugins/table/table-toolbar.js +5 -6
  64. package/lib/plugins/table/table-toolbar.js.map +1 -1
  65. package/lib/plugins/toolbar/default-toolbar.js +55 -11
  66. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  67. package/lib/plugins/toolbar/done-button.js +1 -1
  68. package/lib/plugins/toolbar/done-button.js.map +1 -1
  69. package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
  70. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  71. package/lib/plugins/toolbar/index.js +1 -2
  72. package/lib/plugins/toolbar/index.js.map +1 -1
  73. package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
  74. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  75. package/lib/plugins/toolbar/toolbar.js +253 -239
  76. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  77. package/lib/plugins/utils.js +27 -2
  78. package/lib/plugins/utils.js.map +1 -1
  79. package/lib/serialization.js +1 -1
  80. package/lib/serialization.js.map +1 -1
  81. package/lib/slate-editor.js +302 -0
  82. package/lib/test-serializer.js +189 -0
  83. package/lib/test-serializer.js.map +1 -0
  84. package/lib/theme.js +1 -1
  85. package/lib/theme.js.map +1 -1
  86. package/package.json +18 -14
  87. package/playground/image/data.js +20 -20
  88. package/playground/image/index.html +22 -20
  89. package/playground/image/index.jsx +12 -10
  90. package/playground/index.html +25 -23
  91. package/playground/mathquill/index.html +23 -20
  92. package/playground/mathquill/index.jsx +18 -22
  93. package/playground/prod-test/index.html +24 -20
  94. package/playground/prod-test/index.jsx +5 -3
  95. package/playground/schema-override/data.js +10 -10
  96. package/playground/schema-override/image-plugin.jsx +3 -4
  97. package/playground/schema-override/index.html +21 -19
  98. package/playground/schema-override/index.jsx +13 -14
  99. package/playground/serialization/data.js +10 -10
  100. package/playground/serialization/image-plugin.jsx +3 -4
  101. package/playground/serialization/index.html +22 -20
  102. package/playground/table-examples.html +5 -8
  103. package/playground/webpack.config.js +10 -10
  104. package/src/components.js +135 -0
  105. package/src/editor.jsx +478 -141
  106. package/src/index.jsx +71 -95
  107. package/src/new-serialization.jsx +291 -0
  108. package/src/parse-html.js +1 -1
  109. package/src/plugins/characters/custom-popper.js +7 -7
  110. package/src/plugins/characters/index.jsx +33 -34
  111. package/src/plugins/characters/utils.js +81 -81
  112. package/src/plugins/hotKeys/index.js +54 -0
  113. package/src/plugins/image/alt-dialog.jsx +4 -5
  114. package/src/plugins/image/component.jsx +106 -89
  115. package/src/plugins/image/image-toolbar.jsx +27 -19
  116. package/src/plugins/image/index.jsx +75 -43
  117. package/src/plugins/image/insert-image-handler.js +62 -27
  118. package/src/plugins/index.jsx +23 -41
  119. package/src/plugins/list/index.jsx +70 -95
  120. package/src/plugins/math/index.jsx +102 -82
  121. package/src/plugins/media/index.jsx +159 -124
  122. package/src/plugins/media/media-dialog.js +98 -71
  123. package/src/plugins/media/media-toolbar.jsx +8 -8
  124. package/src/plugins/media/media-wrapper.jsx +29 -30
  125. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
  126. package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
  127. package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
  128. package/src/plugins/respArea/icons/index.jsx +11 -14
  129. package/src/plugins/respArea/index.jsx +92 -52
  130. package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
  131. package/src/plugins/respArea/utils.jsx +26 -35
  132. package/src/plugins/table/icons/index.jsx +17 -11
  133. package/src/plugins/table/index.jsx +288 -231
  134. package/src/plugins/table/table-toolbar.jsx +15 -11
  135. package/src/plugins/toolbar/default-toolbar.jsx +65 -19
  136. package/src/plugins/toolbar/done-button.jsx +4 -4
  137. package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
  138. package/src/plugins/toolbar/index.jsx +2 -3
  139. package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
  140. package/src/plugins/toolbar/toolbar.jsx +244 -221
  141. package/src/plugins/utils.js +21 -4
  142. package/src/serialization.jsx +32 -32
  143. package/src/test-serializer.js +139 -0
  144. package/src/test-serializer.js.rej +20 -0
@@ -7,18 +7,18 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.serialization = exports["default"] = void 0;
9
9
 
10
- var _react = _interopRequireDefault(require("react"));
11
-
12
- var _slate = require("slate");
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
11
 
14
- var _immutable = _interopRequireDefault(require("immutable"));
12
+ var _react = _interopRequireDefault(require("react"));
15
13
 
16
14
  var _propTypes = _interopRequireDefault(require("prop-types"));
17
15
 
18
- var _slateEditList = _interopRequireDefault(require("slate-edit-list"));
19
-
20
16
  var _debug = _interopRequireDefault(require("debug"));
21
17
 
18
+ var _slate = require("slate");
19
+
20
+ var _slateHyperscript = require("slate-hyperscript");
21
+
22
22
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:list');
23
23
 
24
24
  var b = function b(type, next, childNodes) {
@@ -32,22 +32,27 @@ var b = function b(type, next, childNodes) {
32
32
  var serialization = {
33
33
  deserialize: function deserialize(el, next) {
34
34
  var name = el.tagName.toLowerCase();
35
+ var children = el.children.length ? Array.from(el.children) : el.childNodes;
35
36
 
36
37
  if (name === 'li') {
37
- return b('list_item', next, el.childNodes);
38
+ return (0, _slateHyperscript.jsx)('element', {
39
+ type: 'li'
40
+ }, next(children));
38
41
  }
39
42
 
40
43
  if (name === 'ul') {
41
- return b('ul_list', next, el.children.length ? Array.from(el.children) : el.childNodes);
44
+ return (0, _slateHyperscript.jsx)('element', {
45
+ type: 'ul'
46
+ }, next(children));
42
47
  }
43
48
 
44
49
  if (name === 'ol') {
45
- return b('ol_list', next, el.children.length ? Array.from(el.children) : el.childNodes);
50
+ return (0, _slateHyperscript.jsx)('element', {
51
+ type: 'ol'
52
+ }, next(children));
46
53
  }
47
54
  },
48
55
  serialize: function serialize(object, children) {
49
- if (object.object !== 'block') return;
50
-
51
56
  if (object.type === 'list_item') {
52
57
  return /*#__PURE__*/_react["default"].createElement("li", null, children);
53
58
  }
@@ -63,91 +68,67 @@ var serialization = {
63
68
  };
64
69
  exports.serialization = serialization;
65
70
 
66
- var createEditList = function createEditList() {
67
- var core = (0, _slateEditList["default"])({
68
- typeDefault: 'span'
69
- }); // fix outdated schema
71
+ var isBlockActive = function isBlockActive(editor, format) {
72
+ var selection = editor.selection;
73
+ if (!selection) return false;
70
74
 
71
- if (core.schema && core.schema.blocks) {
72
- Object.keys(core.schema.blocks).forEach(function (key) {
73
- var block = core.schema.blocks[key];
75
+ var _Array$from = Array.from(_slate.Editor.nodes(editor, {
76
+ at: _slate.Editor.unhangRange(editor, selection),
77
+ match: function match(node) {
78
+ return !_slate.Editor.isEditor(node) && _slate.Element.isElement(node) && node.type === format;
79
+ }
80
+ })),
81
+ _Array$from2 = (0, _slicedToArray2["default"])(_Array$from, 1),
82
+ match = _Array$from2[0];
74
83
 
75
- if (block.parent) {
76
- return;
77
- }
84
+ return !!match;
85
+ };
78
86
 
79
- block.nodes[0] = {
80
- type: block.nodes[0].types[0]
81
- };
87
+ var createEditList = function createEditList() {
88
+ var core = {
89
+ changes: {}
90
+ };
91
+
92
+ core.changes.wrapInList = function (editor, format) {
93
+ var isActive = isBlockActive(editor, format);
94
+ var isList = LIST_TYPES.includes(format);
95
+
96
+ _slate.Transforms.unwrapNodes(editor, {
97
+ match: function match(n) {
98
+ return !_slate.Editor.isEditor(n) && _slate.Element.isElement(n) && LIST_TYPES.includes(n.type);
99
+ },
100
+ split: true
82
101
  });
83
- }
84
- /**
85
- * This override of the core.changes.wrapInList is needed because the version
86
- * of immutable that we have does not support getting the element at a specific
87
- * index with a square bracket (list[0]). We have to use the list.get function instead
88
- */
89
102
 
90
- /**
91
- * Returns the highest list of blocks that cover the current selection
92
- */
103
+ var newProperties = {
104
+ type: isActive ? 'paragraph' : isList ? 'list_item' : format
105
+ };
93
106
 
107
+ _slate.Transforms.setNodes(editor, newProperties);
94
108
 
95
- var getHighestSelectedBlocks = function getHighestSelectedBlocks(value) {
96
- var range = value.selection;
97
- var document = value.document;
98
- var startBlock = document.getClosestBlock(range.startKey);
99
- var endBlock = document.getClosestBlock(range.endKey);
109
+ if (!isActive && isList) {
110
+ var block = {
111
+ type: format,
112
+ children: []
113
+ };
100
114
 
101
- if (startBlock === endBlock) {
102
- return _immutable["default"].List([startBlock]);
115
+ _slate.Transforms.wrapNodes(editor, block);
103
116
  }
104
-
105
- var ancestor = document.getCommonAncestor(startBlock.key, endBlock.key);
106
- var startPath = ancestor.getPath(startBlock.key);
107
- var endPath = ancestor.getPath(endBlock.key);
108
- return ancestor.nodes.slice(startPath.get(0), endPath.get(0) + 1);
109
- };
110
- /**
111
- * Wrap the blocks in the current selection in a new list. Selected
112
- * lists are merged together.
113
- */
114
-
115
-
116
- core.changes.wrapInList = function (change, type, data) {
117
- var selectedBlocks = getHighestSelectedBlocks(change.value); // Wrap in container
118
-
119
- change.wrapBlock({
120
- type: type,
121
- data: _slate.Data.create(data)
122
- }, {
123
- normalize: false
124
- }); // Wrap in list items
125
-
126
- selectedBlocks.forEach(function (node) {
127
- if (core.utils.isList(node)) {
128
- // Merge its items with the created list
129
- node.nodes.forEach(function (_ref) {
130
- var key = _ref.key;
131
- return change.unwrapNodeByKey(key, {
132
- normalize: false
133
- });
134
- });
135
- } else if (node.type !== 'list_item') {
136
- change.wrapBlockByKey(node.key, 'list_item', {
137
- normalize: false
138
- });
139
- }
140
- });
141
- return change.normalize();
142
117
  };
143
118
 
144
119
  return core;
145
120
  };
146
121
 
122
+ var LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];
123
+
147
124
  var _default = function _default(options) {
148
125
  var type = options.type,
149
126
  icon = options.icon;
150
- var core = createEditList(); // eslint-disable-next-line react/display-name
127
+ var core = createEditList();
128
+
129
+ core.supports = function (node) {
130
+ return LIST_TYPES.includes(node.type);
131
+ };
151
132
 
152
133
  core.renderNode = function (props) {
153
134
  var node = props.node,
@@ -170,26 +151,9 @@ var _default = function _default(options) {
170
151
  isMark: false,
171
152
  type: type,
172
153
  icon: icon,
173
- isActive: function isActive(value, type) {
174
- if (!core.utils.isSelectionInList(value)) {
175
- return false;
176
- }
177
-
178
- var current = core.utils.getCurrentList(value);
179
- return current ? current.type === type : false;
180
- },
181
- onClick: function onClick(value, onChange) {
182
- log('[onClick]', value);
183
- var inList = core.utils.isSelectionInList(value);
184
-
185
- if (inList) {
186
- var change = value.change().call(core.changes.unwrapList);
187
- onChange(change);
188
- } else {
189
- var _change = value.change().call(core.changes.wrapInList, type);
190
-
191
- onChange(_change);
192
- }
154
+ isActive: isBlockActive,
155
+ onClick: function onClick(editor) {
156
+ core.changes.wrapInList(editor, type);
193
157
  }
194
158
  };
195
159
  core.renderNode.propTypes = {
@@ -201,4 +165,4 @@ var _default = function _default(options) {
201
165
  };
202
166
 
203
167
  exports["default"] = _default;
204
- //# sourceMappingURL=index.js.map
168
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","jsx","serialize","isBlockActive","editor","format","selection","Editor","at","unhangRange","match","node","isEditor","SlateElement","isElement","createEditList","core","changes","wrapInList","isActive","isList","LIST_TYPES","includes","Transforms","unwrapNodes","n","split","newProperties","setNodes","block","wrapNodes","options","icon","supports","renderNode","props","attributes","toolbar","isMark","onClick","propTypes","PropTypes","func"],"sources":["../../../src/plugins/list/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { Editor, Element as SlateElement, Transforms } from 'slate';\nimport { jsx } from \"slate-hyperscript\";\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n  object: 'block',\n  type,\n  nodes: next(childNodes)\n});\n\nexport const serialization = {\n  deserialize(el, next) {\n    const name = el.tagName.toLowerCase();\n    const children = el.children.length ? Array.from(el.children) : el.childNodes;\n\n    if (name === 'li') {\n      return jsx(\n        'element',\n        {\n          type: 'li'\n        },\n        next(children)\n      );\n    }\n\n    if (name === 'ul') {\n      return jsx(\n        'element',\n        {\n          type: 'ul'\n        },\n        next(children)\n      );\n    }\n\n    if (name === 'ol') {\n      return jsx(\n        'element',\n        {\n          type: 'ol'\n        },\n        next(children)\n      );\n    }\n  },\n  serialize(object, children) {\n    if (object.type === 'list_item') {\n      return <li>{children}</li>;\n    }\n\n    if (object.type === 'ul_list') {\n      return <ul>{children}</ul>;\n    }\n\n    if (object.type === 'ol_list') {\n      return <ol>{children}</ol>;\n    }\n  }\n};\n\nconst isBlockActive = (editor, format) => {\n  const { selection } = editor;\n  if (!selection) return false;\n\n  const [match] = Array.from(\n    Editor.nodes(editor, {\n      at: Editor.unhangRange(editor, selection),\n      match: node => !Editor.isEditor(node) && SlateElement.isElement(node) && node.type === format\n    })\n  );\n\n  return !!match;\n};\n\nconst createEditList = () => {\n  const core = {\n    changes: {}\n  };\n\n  core.changes.wrapInList = (editor, format) => {\n    const isActive = isBlockActive(editor, format);\n    const isList = LIST_TYPES.includes(format);\n\n    Transforms.unwrapNodes(editor, {\n      match: n =>\n        !Editor.isEditor(n) &&\n        SlateElement.isElement(n) &&\n        LIST_TYPES.includes(n.type),\n      split: true\n    });\n\n    const newProperties = {\n      type: isActive ? 'paragraph' : isList ? 'list_item' : format\n    };\n\n    Transforms.setNodes(editor, newProperties);\n\n    if (!isActive && isList) {\n      const block = { type: format, children: [] };\n      Transforms.wrapNodes(editor, block);\n    }\n  };\n\n  return core;\n};\n\nconst LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];\n\nexport default options => {\n  const { type, icon } = options;\n\n  const core = createEditList();\n\n  core.supports = node => LIST_TYPES.includes(node.type);\n\n  core.renderNode = props => {\n    const { node, attributes, children } = props;\n\n    switch (node.type) {\n      case 'ul_list':\n        return <ul {...attributes}>{children}</ul>;\n      case 'ol_list':\n        return <ol {...attributes}>{children}</ol>;\n      case 'list_item':\n        return <li {...attributes}>{children}</li>;\n    }\n  };\n\n  core.toolbar = {\n    isMark: false,\n    type,\n    icon,\n    isActive: isBlockActive,\n    onClick: editor => {\n      core.changes.wrapInList(editor, type);\n    }\n  };\n\n  core.renderNode.propTypes = {\n    node: PropTypes.object,\n    attributes: PropTypes.object,\n    children: PropTypes.func\n  };\n\n  return core;\n};\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/list/index.jsx"],"names":["log","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","serialize","createEditList","core","typeDefault","schema","blocks","Object","keys","forEach","key","block","parent","types","getHighestSelectedBlocks","value","range","selection","document","startBlock","getClosestBlock","startKey","endBlock","endKey","Immutable","List","ancestor","getCommonAncestor","startPath","getPath","endPath","slice","get","changes","wrapInList","change","data","selectedBlocks","wrapBlock","Data","create","normalize","node","utils","isList","_ref","unwrapNodeByKey","wrapBlockByKey","options","icon","renderNode","props","attributes","toolbar","isMark","isActive","isSelectionInList","current","getCurrentList","onClick","onChange","inList","call","unwrapList","propTypes","PropTypes","func"],"mappings":"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","sourcesContent":["import React from 'react';\nimport { Data } from 'slate';\nimport Immutable from 'immutable';\nimport PropTypes from 'prop-types';\nimport EditList from 'slate-edit-list';\nimport debug from 'debug';\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n object: 'block',\n type,\n nodes: next(childNodes),\n});\n\nexport const serialization = {\n deserialize(el, next) {\n const name = el.tagName.toLowerCase();\n\n if (name === 'li') {\n return b('list_item', next, el.childNodes);\n }\n\n if (name === 'ul') {\n return b('ul_list', next, el.children.length ? Array.from(el.children) : el.childNodes);\n }\n\n if (name === 'ol') {\n return b('ol_list', next, el.children.length ? Array.from(el.children) : el.childNodes);\n }\n },\n serialize(object, children) {\n if (object.object !== 'block') return;\n\n if (object.type === 'list_item') {\n return <li>{children}</li>;\n }\n\n if (object.type === 'ul_list') {\n return <ul>{children}</ul>;\n }\n\n if (object.type === 'ol_list') {\n return <ol>{children}</ol>;\n }\n },\n};\n\nconst createEditList = () => {\n const core = EditList({\n typeDefault: 'span',\n });\n\n // fix outdated schema\n if (core.schema && core.schema.blocks) {\n Object.keys(core.schema.blocks).forEach((key) => {\n const block = core.schema.blocks[key];\n\n if (block.parent) {\n return;\n }\n\n block.nodes[0] = { type: block.nodes[0].types[0] };\n });\n }\n\n /**\n * This override of the core.changes.wrapInList is needed because the version\n * of immutable that we have does not support getting the element at a specific\n * index with a square bracket (list[0]). We have to use the list.get function instead\n */\n\n /**\n * Returns the highest list of blocks that cover the current selection\n */\n const getHighestSelectedBlocks = (value) => {\n const range = value.selection;\n const document = value.document;\n\n const startBlock = document.getClosestBlock(range.startKey);\n const endBlock = document.getClosestBlock(range.endKey);\n\n if (startBlock === endBlock) {\n return Immutable.List([startBlock]);\n }\n\n const ancestor = document.getCommonAncestor(startBlock.key, endBlock.key);\n const startPath = ancestor.getPath(startBlock.key);\n const endPath = ancestor.getPath(endBlock.key);\n\n return ancestor.nodes.slice(startPath.get(0), endPath.get(0) + 1);\n };\n\n /**\n * Wrap the blocks in the current selection in a new list. Selected\n * lists are merged together.\n */\n core.changes.wrapInList = function(change, type, data) {\n const selectedBlocks = getHighestSelectedBlocks(change.value);\n\n // Wrap in container\n change.wrapBlock({ type: type, data: Data.create(data) }, { normalize: false });\n\n // Wrap in list items\n selectedBlocks.forEach(function(node) {\n if (core.utils.isList(node)) {\n // Merge its items with the created list\n node.nodes.forEach(function(_ref) {\n const key = _ref.key;\n return change.unwrapNodeByKey(key, { normalize: false });\n });\n } else if (node.type !== 'list_item') {\n change.wrapBlockByKey(node.key, 'list_item', {\n normalize: false,\n });\n }\n });\n\n return change.normalize();\n };\n\n return core;\n};\n\nexport default (options) => {\n const { type, icon } = options;\n\n const core = createEditList();\n\n // eslint-disable-next-line react/display-name\n core.renderNode = (props) => {\n const { node, attributes, children } = props;\n\n switch (node.type) {\n case 'ul_list':\n return <ul {...attributes}>{children}</ul>;\n case 'ol_list':\n return <ol {...attributes}>{children}</ol>;\n case 'list_item':\n return <li {...attributes}>{children}</li>;\n }\n };\n\n core.toolbar = {\n isMark: false,\n type,\n icon,\n isActive: (value, type) => {\n if (!core.utils.isSelectionInList(value)) {\n return false;\n }\n const current = core.utils.getCurrentList(value);\n return current ? current.type === type : false;\n },\n onClick: (value, onChange) => {\n log('[onClick]', value);\n const inList = core.utils.isSelectionInList(value);\n if (inList) {\n const change = value.change().call(core.changes.unwrapList);\n onChange(change);\n } else {\n const change = value.change().call(core.changes.wrapInList, type);\n onChange(change);\n }\n },\n };\n\n core.renderNode.propTypes = {\n node: PropTypes.object,\n attributes: PropTypes.object,\n children: PropTypes.func,\n };\n\n return core;\n};\n"],"file":"index.js"}
1
+ {"version":3,"file":"index.js","names":["log","debug","b","type","next","childNodes","object","nodes","serialization","deserialize","el","name","tagName","toLowerCase","children","length","Array","from","jsx","serialize","isBlockActive","editor","format","selection","Editor","at","unhangRange","match","node","isEditor","SlateElement","isElement","createEditList","core","changes","wrapInList","isActive","isList","LIST_TYPES","includes","Transforms","unwrapNodes","n","split","newProperties","setNodes","block","wrapNodes","options","icon","supports","renderNode","props","attributes","toolbar","isMark","onClick","propTypes","PropTypes","func"],"sources":["../../../src/plugins/list/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport debug from 'debug';\nimport { Editor, Element as SlateElement, Transforms } from 'slate';\nimport { jsx } from \"slate-hyperscript\";\n\nconst log = debug('@pie-lib:editable-html:plugins:list');\n\nconst b = (type, next, childNodes) => ({\n object: 'block',\n type,\n nodes: next(childNodes)\n});\n\nexport const serialization = {\n deserialize(el, next) {\n const name = el.tagName.toLowerCase();\n const children = el.children.length ? Array.from(el.children) : el.childNodes;\n\n if (name === 'li') {\n return jsx(\n 'element',\n {\n type: 'li'\n },\n next(children)\n );\n }\n\n if (name === 'ul') {\n return jsx(\n 'element',\n {\n type: 'ul'\n },\n next(children)\n );\n }\n\n if (name === 'ol') {\n return jsx(\n 'element',\n {\n type: 'ol'\n },\n next(children)\n );\n }\n },\n serialize(object, children) {\n if (object.type === 'list_item') {\n return <li>{children}</li>;\n }\n\n if (object.type === 'ul_list') {\n return <ul>{children}</ul>;\n }\n\n if (object.type === 'ol_list') {\n return <ol>{children}</ol>;\n }\n }\n};\n\nconst isBlockActive = (editor, format) => {\n const { selection } = editor;\n if (!selection) return false;\n\n const [match] = Array.from(\n Editor.nodes(editor, {\n at: Editor.unhangRange(editor, selection),\n match: node => !Editor.isEditor(node) && SlateElement.isElement(node) && node.type === format\n })\n );\n\n return !!match;\n};\n\nconst createEditList = () => {\n const core = {\n changes: {}\n };\n\n core.changes.wrapInList = (editor, format) => {\n const isActive = isBlockActive(editor, format);\n const isList = LIST_TYPES.includes(format);\n\n Transforms.unwrapNodes(editor, {\n match: n =>\n !Editor.isEditor(n) &&\n SlateElement.isElement(n) &&\n LIST_TYPES.includes(n.type),\n split: true\n });\n\n const newProperties = {\n type: isActive ? 'paragraph' : isList ? 'list_item' : format\n };\n\n Transforms.setNodes(editor, newProperties);\n\n if (!isActive && isList) {\n const block = { type: format, children: [] };\n Transforms.wrapNodes(editor, block);\n }\n };\n\n return core;\n};\n\nconst LIST_TYPES = ['ol_list', 'ul_list', 'list_item'];\n\nexport default options => {\n const { type, icon } = options;\n\n const core = createEditList();\n\n core.supports = node => LIST_TYPES.includes(node.type);\n\n core.renderNode = props => {\n const { node, attributes, children } = props;\n\n switch (node.type) {\n case 'ul_list':\n return <ul {...attributes}>{children}</ul>;\n case 'ol_list':\n return <ol {...attributes}>{children}</ol>;\n case 'list_item':\n return <li {...attributes}>{children}</li>;\n }\n };\n\n core.toolbar = {\n isMark: false,\n type,\n icon,\n isActive: isBlockActive,\n onClick: editor => {\n core.changes.wrapInList(editor, type);\n }\n };\n\n core.renderNode.propTypes = {\n node: PropTypes.object,\n attributes: PropTypes.object,\n children: PropTypes.func\n };\n\n return core;\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AAEA,IAAMA,GAAG,GAAG,IAAAC,iBAAA,EAAM,qCAAN,CAAZ;;AAEA,IAAMC,CAAC,GAAG,SAAJA,CAAI,CAACC,IAAD,EAAOC,IAAP,EAAaC,UAAb;EAAA,OAA6B;IACrCC,MAAM,EAAE,OAD6B;IAErCH,IAAI,EAAJA,IAFqC;IAGrCI,KAAK,EAAEH,IAAI,CAACC,UAAD;EAH0B,CAA7B;AAAA,CAAV;;AAMO,IAAMG,aAAa,GAAG;EAC3BC,WAD2B,uBACfC,EADe,EACXN,IADW,EACL;IACpB,IAAMO,IAAI,GAAGD,EAAE,CAACE,OAAH,CAAWC,WAAX,EAAb;IACA,IAAMC,QAAQ,GAAGJ,EAAE,CAACI,QAAH,CAAYC,MAAZ,GAAqBC,KAAK,CAACC,IAAN,CAAWP,EAAE,CAACI,QAAd,CAArB,GAA+CJ,EAAE,CAACL,UAAnE;;IAEA,IAAIM,IAAI,KAAK,IAAb,EAAmB;MACjB,OAAO,IAAAO,qBAAA,EACL,SADK,EAEL;QACEf,IAAI,EAAE;MADR,CAFK,EAKLC,IAAI,CAACU,QAAD,CALC,CAAP;IAOD;;IAED,IAAIH,IAAI,KAAK,IAAb,EAAmB;MACjB,OAAO,IAAAO,qBAAA,EACL,SADK,EAEL;QACEf,IAAI,EAAE;MADR,CAFK,EAKLC,IAAI,CAACU,QAAD,CALC,CAAP;IAOD;;IAED,IAAIH,IAAI,KAAK,IAAb,EAAmB;MACjB,OAAO,IAAAO,qBAAA,EACL,SADK,EAEL;QACEf,IAAI,EAAE;MADR,CAFK,EAKLC,IAAI,CAACU,QAAD,CALC,CAAP;IAOD;EACF,CAlC0B;EAmC3BK,SAnC2B,qBAmCjBb,MAnCiB,EAmCTQ,QAnCS,EAmCC;IAC1B,IAAIR,MAAM,CAACH,IAAP,KAAgB,WAApB,EAAiC;MAC/B,oBAAO,4CAAKW,QAAL,CAAP;IACD;;IAED,IAAIR,MAAM,CAACH,IAAP,KAAgB,SAApB,EAA+B;MAC7B,oBAAO,4CAAKW,QAAL,CAAP;IACD;;IAED,IAAIR,MAAM,CAACH,IAAP,KAAgB,SAApB,EAA+B;MAC7B,oBAAO,4CAAKW,QAAL,CAAP;IACD;EACF;AA/C0B,CAAtB;;;AAkDP,IAAMM,aAAa,GAAG,SAAhBA,aAAgB,CAACC,MAAD,EAASC,MAAT,EAAoB;EACxC,IAAQC,SAAR,GAAsBF,MAAtB,CAAQE,SAAR;EACA,IAAI,CAACA,SAAL,EAAgB,OAAO,KAAP;;EAEhB,kBAAgBP,KAAK,CAACC,IAAN,CACdO,aAAA,CAAOjB,KAAP,CAAac,MAAb,EAAqB;IACnBI,EAAE,EAAED,aAAA,CAAOE,WAAP,CAAmBL,MAAnB,EAA2BE,SAA3B,CADe;IAEnBI,KAAK,EAAE,eAAAC,IAAI;MAAA,OAAI,CAACJ,aAAA,CAAOK,QAAP,CAAgBD,IAAhB,CAAD,IAA0BE,cAAA,CAAaC,SAAb,CAAuBH,IAAvB,CAA1B,IAA0DA,IAAI,CAACzB,IAAL,KAAcmB,MAA5E;IAAA;EAFQ,CAArB,CADc,CAAhB;EAAA;EAAA,IAAOK,KAAP;;EAOA,OAAO,CAAC,CAACA,KAAT;AACD,CAZD;;AAcA,IAAMK,cAAc,GAAG,SAAjBA,cAAiB,GAAM;EAC3B,IAAMC,IAAI,GAAG;IACXC,OAAO,EAAE;EADE,CAAb;;EAIAD,IAAI,CAACC,OAAL,CAAaC,UAAb,GAA0B,UAACd,MAAD,EAASC,MAAT,EAAoB;IAC5C,IAAMc,QAAQ,GAAGhB,aAAa,CAACC,MAAD,EAASC,MAAT,CAA9B;IACA,IAAMe,MAAM,GAAGC,UAAU,CAACC,QAAX,CAAoBjB,MAApB,CAAf;;IAEAkB,iBAAA,CAAWC,WAAX,CAAuBpB,MAAvB,EAA+B;MAC7BM,KAAK,EAAE,eAAAe,CAAC;QAAA,OACN,CAAClB,aAAA,CAAOK,QAAP,CAAgBa,CAAhB,CAAD,IACAZ,cAAA,CAAaC,SAAb,CAAuBW,CAAvB,CADA,IAEAJ,UAAU,CAACC,QAAX,CAAoBG,CAAC,CAACvC,IAAtB,CAHM;MAAA,CADqB;MAK7BwC,KAAK,EAAE;IALsB,CAA/B;;IAQA,IAAMC,aAAa,GAAG;MACpBzC,IAAI,EAAEiC,QAAQ,GAAG,WAAH,GAAiBC,MAAM,GAAG,WAAH,GAAiBf;IADlC,CAAtB;;IAIAkB,iBAAA,CAAWK,QAAX,CAAoBxB,MAApB,EAA4BuB,aAA5B;;IAEA,IAAI,CAACR,QAAD,IAAaC,MAAjB,EAAyB;MACvB,IAAMS,KAAK,GAAG;QAAE3C,IAAI,EAAEmB,MAAR;QAAgBR,QAAQ,EAAE;MAA1B,CAAd;;MACA0B,iBAAA,CAAWO,SAAX,CAAqB1B,MAArB,EAA6ByB,KAA7B;IACD;EACF,CAtBD;;EAwBA,OAAOb,IAAP;AACD,CA9BD;;AAgCA,IAAMK,UAAU,GAAG,CAAC,SAAD,EAAY,SAAZ,EAAuB,WAAvB,CAAnB;;eAEe,kBAAAU,OAAO,EAAI;EACxB,IAAQ7C,IAAR,GAAuB6C,OAAvB,CAAQ7C,IAAR;EAAA,IAAc8C,IAAd,GAAuBD,OAAvB,CAAcC,IAAd;EAEA,IAAMhB,IAAI,GAAGD,cAAc,EAA3B;;EAEAC,IAAI,CAACiB,QAAL,GAAgB,UAAAtB,IAAI;IAAA,OAAIU,UAAU,CAACC,QAAX,CAAoBX,IAAI,CAACzB,IAAzB,CAAJ;EAAA,CAApB;;EAEA8B,IAAI,CAACkB,UAAL,GAAkB,UAAAC,KAAK,EAAI;IACzB,IAAQxB,IAAR,GAAuCwB,KAAvC,CAAQxB,IAAR;IAAA,IAAcyB,UAAd,GAAuCD,KAAvC,CAAcC,UAAd;IAAA,IAA0BvC,QAA1B,GAAuCsC,KAAvC,CAA0BtC,QAA1B;;IAEA,QAAQc,IAAI,CAACzB,IAAb;MACE,KAAK,SAAL;QACE,oBAAO,sCAAQkD,UAAR,EAAqBvC,QAArB,CAAP;;MACF,KAAK,SAAL;QACE,oBAAO,sCAAQuC,UAAR,EAAqBvC,QAArB,CAAP;;MACF,KAAK,WAAL;QACE,oBAAO,sCAAQuC,UAAR,EAAqBvC,QAArB,CAAP;IANJ;EAQD,CAXD;;EAaAmB,IAAI,CAACqB,OAAL,GAAe;IACbC,MAAM,EAAE,KADK;IAEbpD,IAAI,EAAJA,IAFa;IAGb8C,IAAI,EAAJA,IAHa;IAIbb,QAAQ,EAAEhB,aAJG;IAKboC,OAAO,EAAE,iBAAAnC,MAAM,EAAI;MACjBY,IAAI,CAACC,OAAL,CAAaC,UAAb,CAAwBd,MAAxB,EAAgClB,IAAhC;IACD;EAPY,CAAf;EAUA8B,IAAI,CAACkB,UAAL,CAAgBM,SAAhB,GAA4B;IAC1B7B,IAAI,EAAE8B,qBAAA,CAAUpD,MADU;IAE1B+C,UAAU,EAAEK,qBAAA,CAAUpD,MAFI;IAG1BQ,QAAQ,EAAE4C,qBAAA,CAAUC;EAHM,CAA5B;EAMA,OAAO1B,IAAP;AACD,C"}
@@ -13,23 +13,27 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
13
13
 
14
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
15
15
 
16
- var _Functions = _interopRequireDefault(require("@material-ui/icons/Functions"));
16
+ var _react = _interopRequireDefault(require("react"));
17
17
 
18
18
  var _slate = require("slate");
19
19
 
20
+ var _slateReact = require("slate-react");
21
+
22
+ var _slateHyperscript = require("slate-hyperscript");
23
+
24
+ var _Functions = _interopRequireDefault(require("@material-ui/icons/Functions"));
25
+
20
26
  var _mathToolbar = require("@pie-lib/math-toolbar");
21
27
 
22
28
  var _mathRendering = require("@pie-lib/math-rendering");
23
29
 
24
- var _react = _interopRequireDefault(require("react"));
25
-
26
30
  var _debug = _interopRequireDefault(require("debug"));
27
31
 
28
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
29
-
30
32
  var _propTypes = _interopRequireDefault(require("prop-types"));
31
33
 
32
- var _serialization = require("../../serialization");
34
+ var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
35
+
36
+ var _newSerialization = require("../../new-serialization");
33
37
 
34
38
  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; }
35
39
 
@@ -52,10 +56,11 @@ function generateAdditionalKeys() {
52
56
 
53
57
  var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
54
58
  var node = props.node,
55
- value = props.value,
56
59
  onFocus = props.onFocus,
57
60
  onBlur = props.onBlur,
58
- onClick = props.onClick;
61
+ onClick = props.onClick,
62
+ editor = props.editor,
63
+ nodePath = props.nodePath;
59
64
 
60
65
  var _ref = props || {},
61
66
  pluginProps = _ref.pluginProps;
@@ -70,36 +75,34 @@ var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
70
75
  controlledKeypadMode = _ref3$controlledKeypa === void 0 ? true : _ref3$controlledKeypa;
71
76
 
72
77
  var onDone = function onDone(latex) {
73
- var update = _objectSpread(_objectSpread({}, node.data.toObject()), {}, {
78
+ var update = _objectSpread(_objectSpread({}, node.data), {}, {
74
79
  latex: latex
75
80
  });
76
81
 
77
- var change = value.change().setNodeByKey(node.key, {
78
- data: update
82
+ editor.apply({
83
+ type: 'set_node',
84
+ path: nodePath,
85
+ properties: {
86
+ data: node.data
87
+ },
88
+ newProperties: {
89
+ data: update
90
+ }
79
91
  });
80
- var nextText = value.document.getNextText(node.key);
81
- change.moveFocusTo(nextText.key, 0).moveAnchorTo(nextText.key, 0);
82
- props.onToolbarDone(change, false);
83
- };
84
92
 
85
- var onChange = function onChange(latex) {
86
- var update = _objectSpread(_objectSpread({}, node.data.toObject()), {}, {
87
- latex: latex
88
- });
93
+ _slateReact.ReactEditor.focus(editor);
89
94
 
90
- var change = value.change().setNodeByKey(node.key, {
91
- data: update
95
+ _slate.Transforms.move(editor, {
96
+ distance: 1,
97
+ unit: 'offset'
92
98
  });
93
- log('call onToolbarChange:', change);
94
- props.onDataChange(node.key, update);
95
99
  };
96
100
 
97
- var latex = node.data.get('latex');
101
+ var latex = node.data.latex;
98
102
  return /*#__PURE__*/_react["default"].createElement(_mathToolbar.MathToolbar, {
99
103
  autoFocus: true,
100
104
  additionalKeys: generateAdditionalKeys(customKeys),
101
105
  latex: latex,
102
- onChange: onChange,
103
106
  onDone: onDone,
104
107
  onBlur: onBlur,
105
108
  onFocus: onFocus,
@@ -124,34 +127,39 @@ var CustomToolbarComp = /*#__PURE__*/_react["default"].memo(function (props) {
124
127
  controlledKeypadModeNext = _next$pluginProps$mat.controlledKeypadMode;
125
128
  var keypadModeChanged = keypadMode !== keypadModeNext;
126
129
  var controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;
127
- var equal = node.equals(nodeNext);
130
+ var equal = (0, _isEqual["default"])(node, nodeNext);
128
131
  return equal && !keypadModeChanged && !controlledKeypadModeChanged;
129
132
  });
130
133
 
131
134
  exports.CustomToolbarComp = CustomToolbarComp;
132
135
  CustomToolbarComp.propTypes = {
133
- node: _slatePropTypes["default"].node.isRequired,
134
- value: _slatePropTypes["default"].value,
136
+ editor: _propTypes["default"].object,
137
+ node: _propTypes["default"].shape({
138
+ type: _propTypes["default"].string,
139
+ children: _propTypes["default"].array,
140
+ data: _propTypes["default"].object
141
+ }).isRequired,
142
+ value: _propTypes["default"].arrayOf(_propTypes["default"].shape({
143
+ type: _propTypes["default"].string,
144
+ children: _propTypes["default"].array,
145
+ data: _propTypes["default"].object
146
+ })).isRequired,
135
147
  onToolbarDone: _propTypes["default"].func,
136
- onDataChange: _propTypes["default"].func,
137
148
  onFocus: _propTypes["default"].func,
138
149
  onClick: _propTypes["default"].func,
139
150
  onBlur: _propTypes["default"].func
140
151
  };
152
+ var mathTypes = ['math', 'mathml'];
141
153
 
142
154
  function MathPlugin() {
143
155
  return {
144
156
  name: 'math',
145
157
  toolbar: {
146
158
  icon: /*#__PURE__*/_react["default"].createElement(_Functions["default"], null),
147
- onClick: function onClick(value, onChange) {
159
+ onClick: function onClick(editor) {
148
160
  log('[insertMath]');
149
161
  var math = inlineMath();
150
- var change = value.change().insertInline(math);
151
- onChange(change);
152
- },
153
- supports: function supports(node) {
154
- return node && node.object === 'inline' && node.type === 'math';
162
+ editor.insertNode(math);
155
163
  },
156
164
 
157
165
  /**
@@ -163,6 +171,23 @@ function MathPlugin() {
163
171
  */
164
172
  CustomToolbarComp: CustomToolbarComp
165
173
  },
174
+ rules: function rules(editor) {
175
+ var isVoid = editor.isVoid,
176
+ isInline = editor.isInline;
177
+
178
+ editor.isVoid = function (element) {
179
+ return mathTypes.includes(element.type) ? true : isVoid(element);
180
+ };
181
+
182
+ editor.isInline = function (element) {
183
+ return mathTypes.includes(element.type) ? true : isInline(element);
184
+ };
185
+
186
+ return editor;
187
+ },
188
+ supports: function supports(node) {
189
+ return mathTypes.includes(node.type);
190
+ },
166
191
  schema: {
167
192
  document: {
168
193
  match: [{
@@ -189,12 +214,13 @@ function MathPlugin() {
189
214
 
190
215
 
191
216
  if (props.node.type === 'mathml') {
192
- var html = props.node.data.get('html');
193
- return /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, props.attributes, {
217
+ var html = props.node.data.html;
218
+ return /*#__PURE__*/_react["default"].createElement("span", null, /*#__PURE__*/_react["default"].createElement("span", (0, _extends2["default"])({}, props.attributes, {
219
+ contentEditable: false,
194
220
  dangerouslySetInnerHTML: {
195
221
  __html: html
196
222
  }
197
- }));
223
+ })), props.children);
198
224
  }
199
225
  }
200
226
  };
@@ -206,14 +232,15 @@ MathPlugin.DOLLAR = 'dollar';
206
232
  MathPlugin.DOUBLE_DOLLAR = 'double_dollar';
207
233
 
208
234
  var inlineMath = function inlineMath() {
209
- return _slate.Inline.create({
210
- object: 'inline',
235
+ return {
211
236
  type: 'math',
212
- isVoid: true,
213
237
  data: {
214
238
  latex: ''
215
- }
216
- });
239
+ },
240
+ children: [{
241
+ text: ''
242
+ }]
243
+ };
217
244
  };
218
245
 
219
246
  exports.inlineMath = inlineMath;
@@ -258,7 +285,7 @@ var lessThanHandling = function lessThanHandling(input) {
258
285
  };
259
286
 
260
287
  var serialization = {
261
- deserialize: function deserialize(el) {
288
+ deserialize: function deserialize(el, children) {
262
289
  var tagName = getTagName(el);
263
290
  /**
264
291
  * This is used for when there's a wrapper over the mathml element.
@@ -268,7 +295,7 @@ var serialization = {
268
295
  * This is for legacy content only since our math rendering is valid for the core slate rules
269
296
  */
270
297
 
271
- var hasMathChild = _serialization.BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';
298
+ var hasMathChild = _newSerialization.BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';
272
299
  log('[deserialize] name: ', tagName);
273
300
  /**
274
301
  * This is here in order to be able to render mathml content
@@ -276,14 +303,12 @@ var serialization = {
276
303
 
277
304
  if (tagName === 'math' || el.dataset && el.dataset.type === 'mathml' || hasMathChild) {
278
305
  var newHtml = hasMathChild ? el.innerHTML : el.outerHTML;
279
- return {
280
- object: 'inline',
281
- isVoid: true,
306
+ return (0, _slateHyperscript.jsx)('element', {
282
307
  type: 'mathml',
283
308
  data: {
284
309
  html: newHtml
285
310
  }
286
- };
311
+ });
287
312
  }
288
313
 
289
314
  if (el.nodeType === TEXT_NODE) {
@@ -304,24 +329,23 @@ var serialization = {
304
329
  wrapType = _unWrapMath.wrapType;
305
330
 
306
331
  log('[deserialize]: noBrackets: ', unwrapped, wrapType);
307
- return {
308
- object: 'inline',
332
+ return (0, _slateHyperscript.jsx)('element', {
309
333
  type: 'math',
310
- isVoid: true,
311
- nodes: [],
312
334
  data: {
313
335
  latex: unwrapped,
314
336
  wrapper: wrapType
315
337
  }
316
- };
338
+ });
317
339
  }
318
340
  },
319
341
  serialize: function serialize(object) {
320
342
  if (object.type === 'math') {
321
- var l = object.data.get('latex');
322
- var wrapper = object.data.get('wrapper');
323
- log('[serialize] latex: ', l);
324
- var decoded = htmlDecode(lessThanHandling(l));
343
+ var _ref4 = object.data || {},
344
+ latex = _ref4.latex,
345
+ wrapper = _ref4.wrapper;
346
+
347
+ log('[serialize] latex: ', latex);
348
+ var decoded = htmlDecode(lessThanHandling(latex));
325
349
  return /*#__PURE__*/_react["default"].createElement("span", {
326
350
  "data-latex": "",
327
351
  "data-raw": decoded
@@ -333,7 +357,9 @@ var serialization = {
333
357
 
334
358
 
335
359
  if (object.type === 'mathml') {
336
- var html = object.data.get('html');
360
+ var _ref5 = object.data || {},
361
+ html = _ref5.html;
362
+
337
363
  return /*#__PURE__*/_react["default"].createElement("span", {
338
364
  "data-type": "mathml",
339
365
  dangerouslySetInnerHTML: {
@@ -344,4 +370,4 @@ var serialization = {
344
370
  }
345
371
  };
346
372
  exports.serialization = serialization;
347
- //# sourceMappingURL=index.js.map
373
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","TEXT_NODE","generateAdditionalKeys","keyData","map","key","name","latex","write","label","CustomToolbarComp","React","memo","props","node","onFocus","onBlur","onClick","editor","nodePath","pluginProps","math","keypadMode","customKeys","controlledKeypadMode","onDone","update","data","apply","type","path","properties","newProperties","ReactEditor","focus","Transforms","move","distance","unit","prev","next","nodeNext","keypadModeNext","controlledKeypadModeNext","keypadModeChanged","controlledKeypadModeChanged","equal","isEqual","propTypes","PropTypes","object","shape","string","children","array","isRequired","value","arrayOf","onToolbarDone","func","mathTypes","MathPlugin","toolbar","icon","inlineMath","insertNode","rules","isVoid","isInline","element","includes","supports","schema","document","match","pluginStyles","parentNode","p","position","top","renderNode","html","attributes","__html","ROUND_BRACKETS","SQUARE_BRACKETS","DOLLAR","DOUBLE_DOLLAR","text","htmlDecode","input","doc","DOMParser","parseFromString","documentElement","textContent","getTagName","el","tagName","toLowerCase","lessThanHandling","arrowSplit","split","length","reduce","st","part","serialization","deserialize","hasMathChild","BLOCK_TAGS","childNodes","firstChild","dataset","newHtml","innerHTML","outerHTML","jsx","nodeType","hasLatex","hasAttribute","unWrapMath","unwrapped","wrapType","wrapper","serialize","decoded","wrapMath"],"sources":["../../../src/plugins/math/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Editor, Inline, Transforms } from 'slate';\nimport { ReactEditor } from 'slate-react';\nimport { jsx } from 'slate-hyperscript';\nimport Functions from '@material-ui/icons/Functions';\nimport { MathPreview, MathToolbar } from '@pie-lib/math-toolbar';\nimport { wrapMath, unWrapMath } from '@pie-lib/math-rendering';\nimport debug from 'debug';\nimport PropTypes from 'prop-types';\nimport isEqual from 'lodash/isEqual';\n\nimport { BLOCK_TAGS } from '../../new-serialization';\nconst log = debug('@pie-lib:editable-html:plugins:math');\n\nconst TEXT_NODE = 3;\n\nfunction generateAdditionalKeys(keyData = []) {\n  return keyData.map(key => ({\n    name: key,\n    latex: key,\n    write: key,\n    label: key\n  }));\n}\n\nexport const CustomToolbarComp = React.memo(\n  props => {\n    const { node, onFocus, onBlur, onClick, editor, nodePath } = props;\n    const { pluginProps } = props || {};\n    const { math } = pluginProps || {};\n    const { keypadMode, customKeys, controlledKeypadMode = true } = math || {};\n\n    const onDone = latex => {\n      const update = {\n        ...node.data,\n        latex\n      };\n      editor.apply({\n        type: 'set_node',\n        path: nodePath,\n        properties: {\n          data: node.data\n        },\n        newProperties: { data: update }\n      });\n      ReactEditor.focus(editor);\n      Transforms.move(editor, { distance: 1, unit: 'offset' });\n    };\n\n    const latex = node.data.latex;\n\n    return (\n      <MathToolbar\n        autoFocus\n        additionalKeys={generateAdditionalKeys(customKeys)}\n        latex={latex}\n        onDone={onDone}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        keypadMode={keypadMode}\n        controlledKeypadMode={controlledKeypadMode}\n      />\n    );\n  },\n  (prev, next) => {\n    const { node, pluginProps: { math: { keypadMode, controlledKeypadMode } = {} } = {} } = prev;\n    const {\n      node: nodeNext,\n      pluginProps: {\n        math: { keypadMode: keypadModeNext, controlledKeypadMode: controlledKeypadModeNext } = {}\n      } = {}\n    } = next;\n    const keypadModeChanged = keypadMode !== keypadModeNext;\n    const controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;\n\n    const equal = isEqual(node, nodeNext);\n    return equal && !keypadModeChanged && !controlledKeypadModeChanged;\n  }\n);\n\nCustomToolbarComp.propTypes = {\n  editor: PropTypes.object,\n  node: PropTypes.shape({\n    type: PropTypes.string,\n    children: PropTypes.array,\n    data: PropTypes.object\n  }).isRequired,\n  value: PropTypes.arrayOf(\n    PropTypes.shape({\n      type: PropTypes.string,\n      children: PropTypes.array,\n      data: PropTypes.object\n    })\n  ).isRequired,\n  onToolbarDone: PropTypes.func,\n  onFocus: PropTypes.func,\n  onClick: PropTypes.func,\n  onBlur: PropTypes.func\n};\n\nconst mathTypes = ['math', 'mathml'];\n\nexport default function MathPlugin() {\n  return {\n    name: 'math',\n    toolbar: {\n      icon: <Functions />,\n      onClick: editor => {\n        log('[insertMath]');\n        const math = inlineMath();\n\n        editor.insertNode(math);\n      },\n      /**\n       * Return a react component function\n       * @param node {Slate.Node}\n       * @param value {Slate.Value}\n       * @param onDone {(change?: Slate.Change, finishEditing :boolea) => void} - a function to call once the toolbar\n       *   has made any changes, call with the node.key and a data object.\n       */\n      CustomToolbarComp\n    },\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return mathTypes.includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return mathTypes.includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    supports: node => mathTypes.includes(node.type),\n    schema: {\n      document: { match: [{ type: 'math' }] }\n    },\n\n    pluginStyles: (node, parentNode, p) => {\n      if (p) {\n        return {\n          position: 'absolute',\n          top: 'initial'\n        };\n      }\n    },\n\n    renderNode: props => {\n      if (props.node.type === 'math') {\n        log('[renderNode]: data:', props.node.data);\n        return <MathPreview {...props} />;\n      }\n\n      /**\n       * Here for rendering mathml content\n       */\n      if (props.node.type === 'mathml') {\n        const { data: { html } } = props.node;\n\n        return (\n          <span>\n            <span {...props.attributes} contentEditable={false} dangerouslySetInnerHTML={{ __html: html }} />\n            {props.children}\n          </span>\n        );\n      }\n    }\n  };\n}\n\nMathPlugin.ROUND_BRACKETS = 'round_brackets';\nMathPlugin.SQUARE_BRACKETS = 'square_brackets';\nMathPlugin.DOLLAR = 'dollar';\nMathPlugin.DOUBLE_DOLLAR = 'double_dollar';\n\nexport const inlineMath = () => ({\n  type: 'math',\n  data: {\n    latex: ''\n  },\n  children: [{ text: '' }]\n});\n\nconst htmlDecode = input => {\n  const doc = new DOMParser().parseFromString(input, 'text/html');\n\n  return doc.documentElement.textContent;\n};\n\nconst getTagName = el => {\n  return ((el && el.tagName) || '').toLowerCase();\n};\n\n/**\n * Makes sure that strings that contain stuff like:\n * x<y are not transformed into x by the DOMParser because it thinks\n * that <y is the start of a dom element tag\n * @param input\n * @returns {*}\n */\nconst lessThanHandling = input => {\n  const arrowSplit = input.split('<');\n\n  // if we don't have at least 2 characters there's no point in checking\n  if (input.length > 2) {\n    return arrowSplit.reduce((st, part) => {\n      /*\n       We check if this element resulted is:\n       div - continuation of a beginning of a HTML element\n       /div - closing of a HTML tag\n       br/> - beginning and closing of a html TAG\n       */\n      if (part.match(/<[a-zA-Z/][\\s\\S]*>/gi)) {\n        return `${st}${st ? '<' : ''}${part}`;\n      }\n\n      return `${st}${st ? '&lt;' : ''}${part}`;\n    }, '');\n  }\n\n  return input;\n};\n\nexport const serialization = {\n  deserialize(el, children) {\n    const tagName = getTagName(el);\n    /**\n     * This is used for when there's a wrapper over the mathml element.\n     * Because of this slate rule: \"Only allow block nodes or inline and text nodes in blocks.\"\n     * The element that contains only the mathml is removed (along with the math) because it has\n     * an inline child and the block is of type block\n     * This is for legacy content only since our math rendering is valid for the core slate rules\n     */\n    const hasMathChild =\n      BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';\n    log('[deserialize] name: ', tagName);\n\n    /**\n     * This is here in order to be able to render mathml content\n     */\n    if (tagName === 'math' || (el.dataset && el.dataset.type === 'mathml') || hasMathChild) {\n      const newHtml = hasMathChild ? el.innerHTML : el.outerHTML;\n\n      return jsx('element', {\n        type: 'mathml',\n        data: {\n          html: newHtml\n        }\n      });\n    }\n\n    if (el.nodeType === TEXT_NODE) {\n      return;\n    }\n\n    if (tagName !== 'span') {\n      return;\n    }\n\n    const hasLatex = el.hasAttribute('data-latex') || el.hasAttribute('latex');\n\n    if (hasLatex) {\n      const latex = htmlDecode(el.innerHTML);\n      const { unwrapped, wrapType } = unWrapMath(latex);\n      log('[deserialize]: noBrackets: ', unwrapped, wrapType);\n\n      return jsx('element', {\n        type: 'math',\n        data: {\n          latex: unwrapped,\n          wrapper: wrapType\n        }\n      });\n    }\n  },\n  serialize(object) {\n    if (object.type === 'math') {\n      const { latex, wrapper } = object.data || {};\n      log('[serialize] latex: ', latex);\n      const decoded = htmlDecode(lessThanHandling(latex));\n      return (\n        <span data-latex=\"\" data-raw={decoded}>\n          {wrapMath(decoded, wrapper)}\n        </span>\n      );\n    }\n\n    /**\n     * Here for rendering mathml content\n     */\n    if (object.type === 'mathml') {\n      const { html } = object.data || {};\n\n      return <span data-type=\"mathml\" dangerouslySetInnerHTML={{ __html: html }} />;\n    }\n  }\n};\n"],"mappings":"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"}