@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
@@ -2,29 +2,23 @@
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
8
10
  exports["default"] = exports.Toolbar = void 0;
9
11
 
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
-
20
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
-
22
12
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
23
13
 
24
- var _react = _interopRequireDefault(require("react"));
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _react = _interopRequireWildcard(require("react"));
25
17
 
26
18
  var _slate = require("slate");
27
19
 
20
+ var _slateReact = require("slate-react");
21
+
28
22
  var _Delete = _interopRequireDefault(require("@material-ui/icons/Delete"));
29
23
 
30
24
  var _IconButton = _interopRequireDefault(require("@material-ui/core/IconButton"));
@@ -35,31 +29,27 @@ var _classnames = _interopRequireDefault(require("classnames"));
35
29
 
36
30
  var _debug = _interopRequireDefault(require("debug"));
37
31
 
38
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
39
-
40
32
  var _debounce = _interopRequireDefault(require("lodash/debounce"));
41
33
 
42
34
  var _doneButton = require("./done-button");
43
35
 
44
- var _utils = require("../utils");
45
-
46
36
  var _styles = require("@material-ui/core/styles");
47
37
 
48
38
  var _defaultToolbar = _interopRequireDefault(require("./default-toolbar"));
49
39
 
50
40
  var _characters = require("../characters");
51
41
 
52
- 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; }
42
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
53
43
 
54
- 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; }
44
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
55
45
 
56
- 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); }; }
46
+ 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; }
57
47
 
58
- 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; } }
48
+ 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; }
59
49
 
60
50
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:toolbar');
61
51
 
62
- var getCustomToolbar = function getCustomToolbar(plugin, node, value, handleDone, onDataChange) {
52
+ var getCustomToolbar = function getCustomToolbar(plugin, node, value, editor, handleDone) {
63
53
  if (!plugin) {
64
54
  return;
65
55
  }
@@ -78,225 +68,10 @@ var getCustomToolbar = function getCustomToolbar(plugin, node, value, handleDone
78
68
  return plugin.toolbar.CustomToolbarComp;
79
69
  } else if (typeof plugin.toolbar.customToolbar === 'function') {
80
70
  log('deprecated - use CustomToolbarComp');
81
- return plugin.toolbar.customToolbar(node, value, handleDone, onDataChange);
71
+ return plugin.toolbar.customToolbar(node, value, editor, handleDone);
82
72
  }
83
73
  };
84
74
 
85
- var Toolbar = /*#__PURE__*/function (_React$Component) {
86
- (0, _inherits2["default"])(Toolbar, _React$Component);
87
-
88
- var _super = _createSuper(Toolbar);
89
-
90
- function Toolbar(props) {
91
- var _this;
92
-
93
- (0, _classCallCheck2["default"])(this, Toolbar);
94
- _this = _super.call(this, props);
95
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hasMark", function (type) {
96
- var value = _this.props.value;
97
- return value.marks.some(function (mark) {
98
- return mark.type == type;
99
- });
100
- });
101
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "hasBlock", function (type) {
102
- var value = _this.props.value;
103
- return value.blocks.some(function (node) {
104
- return node.type == type;
105
- });
106
- });
107
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onToggle", function (plugin) {
108
- var _this$props = _this.props,
109
- value = _this$props.value,
110
- onChange = _this$props.onChange;
111
- if (!plugin.onToggle) return;
112
- var change = plugin.onToggle(value.change());
113
- onChange(change);
114
- });
115
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onClick", function (e) {
116
- log('[onClick]');
117
- e.preventDefault();
118
- });
119
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onButtonClick", function (fn) {
120
- return function (e) {
121
- e.preventDefault();
122
- fn();
123
- };
124
- });
125
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onToolbarDone", function (change, finishEditing) {
126
- log('[onToolbarDone] change: ', change, 'finishEditing: ', finishEditing);
127
- var _this$props2 = _this.props,
128
- onChange = _this$props2.onChange,
129
- onDone = _this$props2.onDone; // use handler only if this is an actual Slate Change
130
-
131
- if (change instanceof _slate.Change) {
132
- onChange(change, function () {
133
- if (finishEditing) {
134
- onDone();
135
- }
136
- });
137
- } else {
138
- if (finishEditing) {
139
- log('[onToolbarChange] call onDone');
140
- onDone();
141
- }
142
- }
143
- });
144
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDeleteClick", (0, _debounce["default"])(function (e, plugin, node, value, onChange) {
145
- return plugin.deleteNode(e, node, value, onChange);
146
- }, 500));
147
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "onDeleteMouseDown", function (e, plugin, node, value, onChange) {
148
- e.persist();
149
-
150
- _this.onDeleteClick(e, plugin, node, value, onChange);
151
- });
152
- _this.state = {
153
- change: null
154
- };
155
- return _this;
156
- }
157
-
158
- (0, _createClass2["default"])(Toolbar, [{
159
- key: "componentWillUnmount",
160
- value: function componentWillUnmount() {
161
- (0, _characters.removeDialogs)();
162
- }
163
- }, {
164
- key: "render",
165
- value: function render() {
166
- var _this2 = this,
167
- _classNames;
168
-
169
- var _this$props3 = this.props,
170
- classes = _this$props3.classes,
171
- plugins = _this$props3.plugins,
172
- pluginProps = _this$props3.pluginProps,
173
- toolbarOpts = _this$props3.toolbarOpts,
174
- value = _this$props3.value,
175
- autoWidth = _this$props3.autoWidth,
176
- onChange = _this$props3.onChange,
177
- getFocusedValue = _this$props3.getFocusedValue,
178
- isFocused = _this$props3.isFocused,
179
- onDone = _this$props3.onDone,
180
- toolbarRef = _this$props3.toolbarRef;
181
- var node = (0, _utils.findSingleNode)(value);
182
- var parentNode = (0, _utils.findParentNode)(value, node);
183
- log(' --------------> [render] node: ', node);
184
- log('[render] node: ', node);
185
- var plugin = plugins.find(function (p) {
186
- if (!node) {
187
- return;
188
- }
189
-
190
- if (p.toolbar) {
191
- return p.toolbar.supports && p.toolbar.supports(node, value);
192
- }
193
- });
194
- var parentPlugin = plugins.find(function (p) {
195
- if (!parentNode) {
196
- return;
197
- }
198
-
199
- if (p.toolbar) {
200
- return p.toolbar.supports && p.toolbar.supports(parentNode, value);
201
- }
202
- });
203
- log('[render] plugin: ', plugin);
204
-
205
- var handleDone = function handleDone(change, done) {
206
- var handler = onDone;
207
-
208
- if (plugin && plugin.toolbar && plugin.toolbar.customToolbar) {
209
- handler = _this2.onToolbarDone;
210
- }
211
-
212
- handler(change, done);
213
-
214
- if (parentPlugin && parentPlugin.handleDone) {
215
- parentPlugin.handleDone(value, node, plugin, onChange);
216
- }
217
- };
218
-
219
- var handleDataChange = function handleDataChange(key, data) {
220
- _this2.props.onDataChange(key, data);
221
- };
222
-
223
- var CustomToolbar = getCustomToolbar(plugin, node, value, handleDone, this.props.onDataChange);
224
- var filteredPlugins = plugin && plugin.filterPlugins ? plugin.filterPlugins(node, plugins) : plugins;
225
- log('[render] CustomToolbar: ', CustomToolbar);
226
- var parentExtraStyles = parentPlugin && parentPlugin.pluginStyles ? parentPlugin.pluginStyles(node, parentNode, plugin) : {};
227
- var pluginExtraStyles = plugin && plugin.pluginStyles ? plugin.pluginStyles(node, parentNode, plugin) : {};
228
-
229
- var extraStyles = _objectSpread(_objectSpread({}, pluginExtraStyles), parentExtraStyles);
230
-
231
- var deletable = node && plugin && plugin.deleteNode;
232
- var customToolbarShowDone = node && plugin && plugin.toolbar && plugin.toolbar.showDone && !toolbarOpts.alwaysVisible; // If there is a toolbarOpts we check if the showDone is not equal to false
233
-
234
- var defaultToolbarShowDone = !toolbarOpts || toolbarOpts.showDone !== false;
235
- var hasDoneButton = defaultToolbarShowDone || customToolbarShowDone;
236
- var names = (0, _classnames["default"])(classes.toolbar, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.toolbarWithNoDone, !hasDoneButton), (0, _defineProperty2["default"])(_classNames, classes.toolbarTop, toolbarOpts.position === 'top'), (0, _defineProperty2["default"])(_classNames, classes.toolbarRight, toolbarOpts.alignment === 'right'), (0, _defineProperty2["default"])(_classNames, classes.focused, toolbarOpts.alwaysVisible || isFocused), (0, _defineProperty2["default"])(_classNames, classes.autoWidth, autoWidth), (0, _defineProperty2["default"])(_classNames, classes.fullWidth, !autoWidth), _classNames));
237
- return /*#__PURE__*/_react["default"].createElement("div", {
238
- className: names,
239
- style: extraStyles,
240
- onClick: this.onClick,
241
- ref: toolbarRef
242
- }, CustomToolbar ? /*#__PURE__*/_react["default"].createElement(CustomToolbar, {
243
- node: node,
244
- value: value,
245
- onToolbarDone: this.onToolbarDone,
246
- onDataChange: handleDataChange,
247
- pluginProps: pluginProps
248
- }) : /*#__PURE__*/_react["default"].createElement(_defaultToolbar["default"], {
249
- plugins: filteredPlugins,
250
- pluginProps: pluginProps,
251
- value: value,
252
- onChange: onChange,
253
- getFocusedValue: getFocusedValue,
254
- showDone: defaultToolbarShowDone,
255
- onDone: handleDone,
256
- deletable: deletable
257
- }), /*#__PURE__*/_react["default"].createElement("div", {
258
- className: classes.shared
259
- }, deletable && /*#__PURE__*/_react["default"].createElement(_IconButton["default"], {
260
- "aria-label": "Delete",
261
- className: classes.iconRoot,
262
- onMouseDown: function onMouseDown(e) {
263
- return _this2.onDeleteMouseDown(e, plugin, node, value, onChange);
264
- },
265
- classes: {
266
- root: classes.iconRoot
267
- }
268
- }, /*#__PURE__*/_react["default"].createElement(_Delete["default"], null)), customToolbarShowDone && /*#__PURE__*/_react["default"].createElement(_doneButton.DoneButton, {
269
- onClick: handleDone
270
- })));
271
- }
272
- }]);
273
- return Toolbar;
274
- }(_react["default"].Component);
275
-
276
- exports.Toolbar = Toolbar;
277
- (0, _defineProperty2["default"])(Toolbar, "propTypes", {
278
- zIndex: _propTypes["default"].number,
279
- value: _slatePropTypes["default"].value.isRequired,
280
- plugins: _propTypes["default"].array,
281
- plugin: _propTypes["default"].object,
282
- onImageClick: _propTypes["default"].func,
283
- onDone: _propTypes["default"].func.isRequired,
284
- toolbarRef: _propTypes["default"].func.isRequired,
285
- classes: _propTypes["default"].object.isRequired,
286
- isFocused: _propTypes["default"].bool,
287
- autoWidth: _propTypes["default"].bool,
288
- onChange: _propTypes["default"].func.isRequired,
289
- getFocusedValue: _propTypes["default"].func.isRequired,
290
- pluginProps: _propTypes["default"].object,
291
- toolbarOpts: _propTypes["default"].shape({
292
- position: _propTypes["default"].oneOf(['bottom', 'top']),
293
- alignment: _propTypes["default"].oneOf(['left', 'right']),
294
- alwaysVisible: _propTypes["default"].bool,
295
- ref: _propTypes["default"].func,
296
- showDone: _propTypes["default"].bool
297
- }),
298
- onDataChange: _propTypes["default"].func
299
- });
300
75
  var style = {
301
76
  toolbar: {
302
77
  position: 'absolute',
@@ -343,9 +118,248 @@ var style = {
343
118
  }
344
119
  };
345
120
 
121
+ var Toolbar = function Toolbar(props) {
122
+ var _classNames;
123
+
124
+ (0, _react.useEffect)(function () {
125
+ return function () {
126
+ return (0, _characters.removeDialogs)();
127
+ };
128
+ }, []);
129
+
130
+ var hasMark = function hasMark(type) {
131
+ var value = props.value;
132
+ return value.marks.some(function (mark) {
133
+ return mark.type === type;
134
+ });
135
+ };
136
+
137
+ var hasBlock = function hasBlock(type) {
138
+ var value = props.value;
139
+ return value.blocks.some(function (node) {
140
+ return node.type === type;
141
+ });
142
+ };
143
+
144
+ var onToggle = function onToggle(plugin) {
145
+ var value = props.value,
146
+ onChange = props.onChange;
147
+ if (!plugin.onToggle) return;
148
+ var change = plugin.onToggle(value.change());
149
+ onChange(change);
150
+ };
151
+
152
+ var onClick = function onClick(e) {
153
+ log('[onClick]');
154
+ e.preventDefault();
155
+ };
156
+
157
+ var onButtonClick = function onButtonClick(fn) {
158
+ return function (e) {
159
+ e.preventDefault();
160
+ fn();
161
+ };
162
+ };
163
+
164
+ var onToolbarDone = function onToolbarDone(change, finishEditing) {
165
+ log('[onToolbarDone] change: ', change, 'finishEditing: ', finishEditing);
166
+ var onChange = props.onChange,
167
+ onDone = props.onDone;
168
+
169
+ if (change) {
170
+ onChange(change, function () {
171
+ if (finishEditing) {
172
+ onDone();
173
+ }
174
+ });
175
+ } else {
176
+ if (finishEditing) {
177
+ log('[onToolbarChange] call onDone');
178
+ onDone();
179
+ }
180
+ }
181
+ };
182
+
183
+ var onDeleteClick = (0, _debounce["default"])(function (e, plugin, node, value, onChange) {
184
+ return plugin.deleteNode(e, node, value, onChange);
185
+ }, 500);
186
+
187
+ var onDeleteMouseDown = function onDeleteMouseDown(e, plugin, node, value, onChange) {
188
+ e.persist();
189
+ onDeleteClick(e, plugin, node, value, onChange);
190
+ };
191
+
192
+ var classes = props.classes,
193
+ plugins = props.plugins,
194
+ pluginProps = props.pluginProps,
195
+ toolbarOpts = props.toolbarOpts,
196
+ value = props.value,
197
+ autoWidth = props.autoWidth,
198
+ onChange = props.onChange,
199
+ getFocusedValue = props.getFocusedValue,
200
+ isFocused = props.isFocused,
201
+ onDone = props.onDone,
202
+ toolbarRef = props.toolbarRef;
203
+ var editor = (0, _slateReact.useSlate)();
204
+ var selection = (0, _slateReact.useSlateSelection)();
205
+
206
+ var getNode = function getNode(editor, selection, depth) {
207
+ if (!selection) {
208
+ return null;
209
+ }
210
+
211
+ var _Editor$node = _slate.Editor.node(editor, selection, depth ? {
212
+ depth: depth
213
+ } : undefined),
214
+ _Editor$node2 = (0, _slicedToArray2["default"])(_Editor$node, 2),
215
+ node = _Editor$node2[0],
216
+ path = _Editor$node2[1];
217
+
218
+ if (!node) {
219
+ return null;
220
+ }
221
+
222
+ if (!_slate.Text.isText(node)) {
223
+ return [node, path];
224
+ }
225
+
226
+ return getNode(editor, selection, path.length - 1);
227
+ };
228
+
229
+ var getParentNode = function getParentNode(editor, path) {
230
+ return Array.isArray(path) && path.length > 0 && _slate.Editor.parent(editor, path);
231
+ };
232
+
233
+ var _ref = getNode(editor, selection) || [],
234
+ _ref2 = (0, _slicedToArray2["default"])(_ref, 2),
235
+ node = _ref2[0],
236
+ nodePath = _ref2[1];
237
+
238
+ var _ref3 = getParentNode(editor, nodePath) || [],
239
+ _ref4 = (0, _slicedToArray2["default"])(_ref3, 1),
240
+ parentNode = _ref4[0];
241
+
242
+ log(' --------------> [render] node: ', node);
243
+ log('[render] node: ', node);
244
+ var plugin = plugins.find(function (p) {
245
+ if (!node) {
246
+ return;
247
+ }
248
+
249
+ if (p.toolbar) {
250
+ return p.supports && p.supports(node, editor, value);
251
+ }
252
+ });
253
+ var parentPlugin = plugins.find(function (p) {
254
+ if (!parentNode) {
255
+ return;
256
+ }
257
+
258
+ if (p.toolbar) {
259
+ return p.supports && p.supports(parentNode, editor, value);
260
+ }
261
+ });
262
+ log('[render] plugin: ', plugin);
263
+
264
+ var handleDone = function handleDone(editor) {
265
+ var handler = onDone;
266
+
267
+ if (plugin && plugin.toolbar && plugin.toolbar.customToolbar) {
268
+ handler = onToolbarDone;
269
+ }
270
+
271
+ handler(editor);
272
+
273
+ if (parentPlugin && parentPlugin.handleDone) {
274
+ parentPlugin.handleDone(editor, node, plugin);
275
+ }
276
+ };
277
+
278
+ var CustomToolbar = getCustomToolbar(plugin, node, value, editor, handleDone);
279
+ var filteredPlugins = plugin && plugin.filterPlugins ? plugin.filterPlugins(node, plugins) : plugins;
280
+ log('[render] CustomToolbar: ', CustomToolbar);
281
+ var parentExtraStyles = parentPlugin && parentPlugin.pluginStyles ? parentPlugin.pluginStyles(node, parentNode, plugin) : {};
282
+ var pluginExtraStyles = plugin && plugin.pluginStyles ? plugin.pluginStyles(node, parentNode, plugin) : {};
283
+
284
+ var extraStyles = _objectSpread(_objectSpread({}, pluginExtraStyles), parentExtraStyles);
285
+
286
+ var deletable = node && plugin && typeof plugin.deleteNode === 'function';
287
+ var customToolbarShowDone = node && plugin && plugin.toolbar && plugin.toolbar.showDone && !toolbarOpts.alwaysVisible; // If there is a toolbarOpts we check if the showDone is not equal to false
288
+
289
+ var defaultToolbarShowDone = !toolbarOpts || toolbarOpts.showDone !== false;
290
+ var hasDoneButton = defaultToolbarShowDone || customToolbarShowDone;
291
+ var names = (0, _classnames["default"])(classes.toolbar, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.toolbarWithNoDone, !hasDoneButton), (0, _defineProperty2["default"])(_classNames, classes.toolbarTop, toolbarOpts.position === 'top'), (0, _defineProperty2["default"])(_classNames, classes.toolbarRight, toolbarOpts.alignment === 'right'), (0, _defineProperty2["default"])(_classNames, classes.focused, toolbarOpts.alwaysVisible || isFocused), (0, _defineProperty2["default"])(_classNames, classes.autoWidth, autoWidth), (0, _defineProperty2["default"])(_classNames, classes.fullWidth, !autoWidth), _classNames));
292
+ return /*#__PURE__*/_react["default"].createElement("div", {
293
+ className: names,
294
+ style: extraStyles,
295
+ onClick: onClick,
296
+ ref: toolbarRef
297
+ }, CustomToolbar ? /*#__PURE__*/_react["default"].createElement(CustomToolbar, {
298
+ editor: editor,
299
+ node: node,
300
+ nodePath: nodePath,
301
+ value: value,
302
+ onToolbarDone: onToolbarDone,
303
+ pluginProps: pluginProps
304
+ }) : /*#__PURE__*/_react["default"].createElement(_defaultToolbar["default"], {
305
+ editor: editor,
306
+ nodePath: nodePath,
307
+ plugins: filteredPlugins,
308
+ pluginProps: pluginProps,
309
+ value: value,
310
+ onChange: onChange,
311
+ getFocusedValue: getFocusedValue,
312
+ showDone: defaultToolbarShowDone,
313
+ onDone: handleDone,
314
+ deletable: deletable
315
+ }), /*#__PURE__*/_react["default"].createElement("div", {
316
+ className: classes.shared
317
+ }, deletable && /*#__PURE__*/_react["default"].createElement(_IconButton["default"], {
318
+ "aria-label": "Delete",
319
+ className: classes.iconRoot,
320
+ onMouseDown: function onMouseDown(e) {
321
+ return onDeleteMouseDown(e, plugin, node, value, onChange);
322
+ },
323
+ classes: {
324
+ root: classes.iconRoot
325
+ }
326
+ }, /*#__PURE__*/_react["default"].createElement(_Delete["default"], null)), customToolbarShowDone && /*#__PURE__*/_react["default"].createElement(_doneButton.DoneButton, {
327
+ onClick: handleDone
328
+ })));
329
+ };
330
+
331
+ exports.Toolbar = Toolbar;
332
+ Toolbar.propTypes = {
333
+ editor: _propTypes["default"].object.isRequired,
334
+ zIndex: _propTypes["default"].number,
335
+ value: _propTypes["default"].arrayOf(_propTypes["default"].shape({
336
+ type: _propTypes["default"].string,
337
+ children: _propTypes["default"].array,
338
+ data: _propTypes["default"].object
339
+ })),
340
+ plugins: _propTypes["default"].array,
341
+ plugin: _propTypes["default"].object,
342
+ onImageClick: _propTypes["default"].func,
343
+ onDone: _propTypes["default"].func.isRequired,
344
+ toolbarRef: _propTypes["default"].func.isRequired,
345
+ classes: _propTypes["default"].object.isRequired,
346
+ isFocused: _propTypes["default"].bool,
347
+ autoWidth: _propTypes["default"].bool,
348
+ onChange: _propTypes["default"].func.isRequired,
349
+ getFocusedValue: _propTypes["default"].func.isRequired,
350
+ pluginProps: _propTypes["default"].object,
351
+ toolbarOpts: _propTypes["default"].shape({
352
+ position: _propTypes["default"].oneOf(['bottom', 'top']),
353
+ alignment: _propTypes["default"].oneOf(['left', 'right']),
354
+ alwaysVisible: _propTypes["default"].bool,
355
+ ref: _propTypes["default"].func,
356
+ showDone: _propTypes["default"].bool
357
+ })
358
+ };
359
+
346
360
  var _default = (0, _styles.withStyles)(style, {
347
361
  index: 1000
348
362
  })(Toolbar);
349
363
 
350
364
  exports["default"] = _default;
351
- //# sourceMappingURL=toolbar.js.map
365
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","getCustomToolbar","plugin","node","value","editor","handleDone","toolbar","CustomToolbarComp","customToolbar","style","position","zIndex","cursor","justifyContent","background","minWidth","margin","padding","boxShadow","boxSizing","display","toolbarWithNoDone","toolbarTop","top","toolbarRight","right","fullWidth","width","autoWidth","focused","iconRoot","height","verticalAlign","label","color","shared","Toolbar","props","useEffect","removeCharacterDialogs","hasMark","type","marks","some","mark","hasBlock","blocks","onToggle","onChange","change","onClick","e","preventDefault","onButtonClick","fn","onToolbarDone","finishEditing","onDone","onDeleteClick","debounce","deleteNode","onDeleteMouseDown","persist","classes","plugins","pluginProps","toolbarOpts","getFocusedValue","isFocused","toolbarRef","useSlate","selection","useSlateSelection","getNode","depth","Editor","undefined","path","Text","isText","length","getParentNode","Array","isArray","parent","nodePath","parentNode","find","p","supports","parentPlugin","handler","CustomToolbar","filteredPlugins","filterPlugins","parentExtraStyles","pluginStyles","pluginExtraStyles","extraStyles","deletable","customToolbarShowDone","showDone","alwaysVisible","defaultToolbarShowDone","hasDoneButton","names","classNames","alignment","root","propTypes","PropTypes","object","isRequired","number","arrayOf","shape","string","children","array","data","onImageClick","func","bool","oneOf","ref","withStyles","index"],"sources":["../../../src/plugins/toolbar/toolbar.jsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport { Change, Editor, Element as SlateElement, Text, Node } from 'slate';\nimport { useSlate, useSlateSelection } from \"slate-react\";\nimport Delete from '@material-ui/icons/Delete';\nimport IconButton from '@material-ui/core/IconButton';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport debounce from 'lodash/debounce';\n\nimport { DoneButton } from './done-button';\n\nimport { withStyles } from '@material-ui/core/styles';\nimport DefaultToolbar from './default-toolbar';\nimport { removeDialogs as removeCharacterDialogs } from '../characters';\n\nconst log = debug('@pie-lib:editable-html:plugins:toolbar');\n\nconst getCustomToolbar = (plugin, node, value, editor, handleDone) => {\n  if (!plugin) {\n    return;\n  }\n  if (!plugin.toolbar) {\n    return;\n  }\n  if (plugin.toolbar.CustomToolbarComp) {\n    /**\n     * Using a pre-defined Component should be preferred\n     * as the rendering of it (and it's children) can be optimized by React.\n     * If you keep re-defining the comp with an inline function\n     * then react will have to re-render.\n     */\n    return plugin.toolbar.CustomToolbarComp;\n  } else if (typeof plugin.toolbar.customToolbar === 'function') {\n    log('deprecated - use CustomToolbarComp');\n    return plugin.toolbar.customToolbar(node, value, editor, handleDone);\n  }\n};\n\nconst style = {\n  toolbar: {\n    position: 'absolute',\n    zIndex: 10,\n    cursor: 'pointer',\n    justifyContent: 'space-between',\n    background: 'var(--editable-html-toolbar-bg, #efefef)',\n    minWidth: '280px',\n    margin: '5px 0 0 0',\n    padding: '2px',\n    boxShadow:\n      '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',\n    boxSizing: 'border-box',\n    display: 'none'\n  },\n  toolbarWithNoDone: {\n    minWidth: '265px'\n  },\n  toolbarTop: {\n    top: '-45px'\n  },\n  toolbarRight: {\n    right: 0\n  },\n  fullWidth: {\n    width: '100%'\n  },\n  autoWidth: {\n    width: 'auto'\n  },\n  focused: {\n    display: 'flex'\n  },\n  iconRoot: {\n    width: '28px',\n    height: '28px',\n    padding: '4px',\n    verticalAlign: 'top'\n  },\n  label: {\n    color: 'var(--editable-html-toolbar-check, #00bb00)'\n  },\n  shared: {\n    display: 'flex'\n  }\n};\n\nexport const Toolbar = props => {\n  useEffect(() => {\n    return () => removeCharacterDialogs();\n  }, []);\n\n  const hasMark = type => {\n    const { value } = props;\n    return value.marks.some(mark => mark.type === type);\n  };\n\n  const hasBlock = type => {\n    const { value } = props;\n    return value.blocks.some(node => node.type === type);\n  };\n\n  const onToggle = plugin => {\n    const { value, onChange } = props;\n\n    if (!plugin.onToggle) return;\n\n    const change = plugin.onToggle(value.change());\n    onChange(change);\n  };\n\n  const onClick = e => {\n    log('[onClick]');\n    e.preventDefault();\n  };\n\n  const onButtonClick = fn => {\n    return e => {\n      e.preventDefault();\n      fn();\n    };\n  };\n\n  const onToolbarDone = (change, finishEditing) => {\n    log('[onToolbarDone] change: ', change, 'finishEditing: ', finishEditing);\n    const { onChange, onDone } = props;\n\n    if (change) {\n      onChange(change, () => {\n        if (finishEditing) {\n          onDone();\n        }\n      });\n    } else {\n      if (finishEditing) {\n        log('[onToolbarChange] call onDone');\n        onDone();\n      }\n    }\n  };\n\n  const onDeleteClick = debounce(\n    (e, plugin, node, value, onChange) => plugin.deleteNode(e, node, value, onChange),\n    500\n  );\n\n  const onDeleteMouseDown = (e, plugin, node, value, onChange) => {\n    e.persist();\n    onDeleteClick(e, plugin, node, value, onChange);\n  };\n\n  const {\n    classes,\n    plugins,\n    pluginProps,\n    toolbarOpts,\n    value,\n    autoWidth,\n    onChange,\n    getFocusedValue,\n    isFocused,\n    onDone,\n    toolbarRef\n  } = props;\n\n  const editor = useSlate();\n  const selection = useSlateSelection();\n  const getNode = (editor, selection, depth) => {\n    if (!selection) {\n      return null;\n    }\n\n    const [node, path] = Editor.node(editor, selection, depth ? { depth } : undefined);\n\n    if (!node) {\n      return null;\n    }\n\n    if (!Text.isText(node)) {\n      return [node, path];\n    }\n\n    return getNode(editor, selection, path.length - 1);\n  };\n  const getParentNode = (editor, path) => Array.isArray(path) && path.length > 0 && Editor.parent(editor, path);\n\n  const [node, nodePath] = getNode(editor, selection) || [];\n  const [parentNode] = getParentNode(editor, nodePath) || [];\n\n  log(' --------------> [render] node: ', node);\n  log('[render] node: ', node);\n\n  const plugin = plugins.find(p => {\n    if (!node) {\n      return;\n    }\n\n    if (p.toolbar) {\n      return p.supports && p.supports(node, editor, value);\n    }\n  });\n  const parentPlugin = plugins.find(p => {\n    if (!parentNode) {\n      return;\n    }\n\n    if (p.toolbar) {\n      return p.supports && p.supports(parentNode, editor, value);\n    }\n  });\n\n  log('[render] plugin: ', plugin);\n\n  const handleDone = editor => {\n    let handler = onDone;\n\n    if (plugin && plugin.toolbar && plugin.toolbar.customToolbar) {\n      handler = onToolbarDone;\n    }\n\n    handler(editor);\n\n    if (parentPlugin && parentPlugin.handleDone) {\n      parentPlugin.handleDone(editor, node, plugin);\n    }\n  };\n\n  const CustomToolbar = getCustomToolbar(plugin, node, value, editor, handleDone);\n\n  const filteredPlugins =\n    plugin && plugin.filterPlugins ? plugin.filterPlugins(node, plugins) : plugins;\n\n  log('[render] CustomToolbar: ', CustomToolbar);\n  const parentExtraStyles =\n    parentPlugin && parentPlugin.pluginStyles\n      ? parentPlugin.pluginStyles(node, parentNode, plugin)\n      : {};\n  const pluginExtraStyles =\n    plugin && plugin.pluginStyles ? plugin.pluginStyles(node, parentNode, plugin) : {};\n  const extraStyles = {\n    ...pluginExtraStyles,\n    ...parentExtraStyles\n  };\n\n  const deletable = node && plugin && typeof plugin.deleteNode === 'function';\n  const customToolbarShowDone =\n    node && plugin && plugin.toolbar && plugin.toolbar.showDone && !toolbarOpts.alwaysVisible;\n\n  // If there is a toolbarOpts we check if the showDone is not equal to false\n  const defaultToolbarShowDone = !toolbarOpts || toolbarOpts.showDone !== false;\n\n  const hasDoneButton = defaultToolbarShowDone || customToolbarShowDone;\n\n  const names = classNames(classes.toolbar, {\n    [classes.toolbarWithNoDone]: !hasDoneButton,\n    [classes.toolbarTop]: toolbarOpts.position === 'top',\n    [classes.toolbarRight]: toolbarOpts.alignment === 'right',\n    [classes.focused]: toolbarOpts.alwaysVisible || isFocused,\n    [classes.autoWidth]: autoWidth,\n    [classes.fullWidth]: !autoWidth\n  });\n\n  return (\n    <div className={names} style={extraStyles} onClick={onClick} ref={toolbarRef}>\n      {CustomToolbar ? (\n        <CustomToolbar\n          editor={editor}\n          node={node}\n          nodePath={nodePath}\n          value={value}\n          onToolbarDone={onToolbarDone}\n          pluginProps={pluginProps}\n        />\n      ) : (\n        <DefaultToolbar\n          editor={editor}\n          nodePath={nodePath}\n          plugins={filteredPlugins}\n          pluginProps={pluginProps}\n          value={value}\n          onChange={onChange}\n          getFocusedValue={getFocusedValue}\n          showDone={defaultToolbarShowDone}\n          onDone={handleDone}\n          deletable={deletable}\n        />\n      )}\n\n      <div className={classes.shared}>\n        {deletable && (\n          <IconButton\n            aria-label=\"Delete\"\n            className={classes.iconRoot}\n            onMouseDown={e => onDeleteMouseDown(e, plugin, node, value, onChange)}\n            classes={{\n              root: classes.iconRoot\n            }}\n          >\n            <Delete />\n          </IconButton>\n        )}\n        {customToolbarShowDone && <DoneButton onClick={handleDone} />}\n      </div>\n    </div>\n  );\n};\n\nToolbar.propTypes = {\n  editor: PropTypes.object.isRequired,\n  zIndex: PropTypes.number,\n  value: PropTypes.arrayOf(\n    PropTypes.shape({\n      type: PropTypes.string,\n      children: PropTypes.array,\n      data: PropTypes.object\n    })\n  ),\n  plugins: PropTypes.array,\n  plugin: PropTypes.object,\n  onImageClick: PropTypes.func,\n  onDone: PropTypes.func.isRequired,\n  toolbarRef: PropTypes.func.isRequired,\n  classes: PropTypes.object.isRequired,\n  isFocused: PropTypes.bool,\n  autoWidth: PropTypes.bool,\n  onChange: PropTypes.func.isRequired,\n  getFocusedValue: PropTypes.func.isRequired,\n  pluginProps: PropTypes.object,\n  toolbarOpts: PropTypes.shape({\n    position: PropTypes.oneOf(['bottom', 'top']),\n    alignment: PropTypes.oneOf(['left', 'right']),\n    alwaysVisible: PropTypes.bool,\n    ref: PropTypes.func,\n    showDone: PropTypes.bool\n  })\n};\n\nexport default withStyles(style, { index: 1000 })(Toolbar);\n"],"mappings":"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"}