@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.
- package/CHANGELOG.md +0 -302
- package/lib/components.js +116 -0
- package/lib/components.js.map +1 -0
- package/lib/editor.js +418 -103
- package/lib/editor.js.map +1 -1
- package/lib/index.js +101 -155
- package/lib/index.js.map +1 -1
- package/lib/new-serialization.js +320 -0
- package/lib/new-serialization.js.map +1 -0
- package/lib/old-serialization.js +330 -0
- package/lib/parse-html.js +1 -1
- package/lib/parse-html.js.map +1 -1
- package/lib/plugins/characters/custom-popper.js +1 -1
- package/lib/plugins/characters/custom-popper.js.map +1 -1
- package/lib/plugins/characters/index.js +21 -19
- package/lib/plugins/characters/index.js.map +1 -1
- package/lib/plugins/characters/utils.js +1 -1
- package/lib/plugins/characters/utils.js.map +1 -1
- package/lib/plugins/hotKeys/index.js +67 -0
- package/lib/plugins/hotKeys/index.js.map +1 -0
- package/lib/plugins/image/alt-dialog.js +1 -6
- package/lib/plugins/image/alt-dialog.js.map +1 -1
- package/lib/plugins/image/component.js +70 -53
- package/lib/plugins/image/component.js.map +1 -1
- package/lib/plugins/image/image-toolbar.js +7 -9
- package/lib/plugins/image/image-toolbar.js.map +1 -1
- package/lib/plugins/image/index.js +83 -27
- package/lib/plugins/image/index.js.map +1 -1
- package/lib/plugins/image/insert-image-handler.js +72 -33
- package/lib/plugins/image/insert-image-handler.js.map +1 -1
- package/lib/plugins/index.js +23 -41
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/list/index.js +64 -100
- package/lib/plugins/list/index.js.map +1 -1
- package/lib/plugins/math/index.js +86 -60
- package/lib/plugins/math/index.js.map +1 -1
- package/lib/plugins/media/index.js +202 -132
- package/lib/plugins/media/index.js.map +1 -1
- package/lib/plugins/media/media-dialog.js +17 -16
- package/lib/plugins/media/media-dialog.js.map +1 -1
- package/lib/plugins/media/media-toolbar.js +3 -3
- package/lib/plugins/media/media-toolbar.js.map +1 -1
- package/lib/plugins/media/media-wrapper.js +21 -58
- package/lib/plugins/media/media-wrapper.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
- package/lib/plugins/respArea/icons/index.js +13 -15
- package/lib/plugins/respArea/icons/index.js.map +1 -1
- package/lib/plugins/respArea/index.js +87 -53
- package/lib/plugins/respArea/index.js.map +1 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
- package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
- package/lib/plugins/respArea/utils.js +17 -20
- package/lib/plugins/respArea/utils.js.map +1 -1
- package/lib/plugins/table/icons/index.js +1 -1
- package/lib/plugins/table/icons/index.js.map +1 -1
- package/lib/plugins/table/index.js +381 -212
- package/lib/plugins/table/index.js.map +1 -1
- package/lib/plugins/table/table-toolbar.js +5 -6
- package/lib/plugins/table/table-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/default-toolbar.js +55 -11
- package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/done-button.js +1 -1
- package/lib/plugins/toolbar/done-button.js.map +1 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/index.js +1 -2
- package/lib/plugins/toolbar/index.js.map +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
- package/lib/plugins/toolbar/toolbar.js +253 -239
- package/lib/plugins/toolbar/toolbar.js.map +1 -1
- package/lib/plugins/utils.js +27 -2
- package/lib/plugins/utils.js.map +1 -1
- package/lib/serialization.js +1 -1
- package/lib/serialization.js.map +1 -1
- package/lib/slate-editor.js +302 -0
- package/lib/test-serializer.js +189 -0
- package/lib/test-serializer.js.map +1 -0
- package/lib/theme.js +1 -1
- package/lib/theme.js.map +1 -1
- package/package.json +18 -14
- package/playground/image/data.js +20 -20
- package/playground/image/index.html +22 -20
- package/playground/image/index.jsx +12 -10
- package/playground/index.html +25 -23
- package/playground/mathquill/index.html +23 -20
- package/playground/mathquill/index.jsx +18 -22
- package/playground/prod-test/index.html +24 -20
- package/playground/prod-test/index.jsx +5 -3
- package/playground/schema-override/data.js +10 -10
- package/playground/schema-override/image-plugin.jsx +3 -4
- package/playground/schema-override/index.html +21 -19
- package/playground/schema-override/index.jsx +13 -14
- package/playground/serialization/data.js +10 -10
- package/playground/serialization/image-plugin.jsx +3 -4
- package/playground/serialization/index.html +22 -20
- package/playground/table-examples.html +5 -8
- package/playground/webpack.config.js +10 -10
- package/src/components.js +135 -0
- package/src/editor.jsx +478 -141
- package/src/index.jsx +71 -95
- package/src/new-serialization.jsx +291 -0
- package/src/parse-html.js +1 -1
- package/src/plugins/characters/custom-popper.js +7 -7
- package/src/plugins/characters/index.jsx +33 -34
- package/src/plugins/characters/utils.js +81 -81
- package/src/plugins/hotKeys/index.js +54 -0
- package/src/plugins/image/alt-dialog.jsx +4 -5
- package/src/plugins/image/component.jsx +106 -89
- package/src/plugins/image/image-toolbar.jsx +27 -19
- package/src/plugins/image/index.jsx +75 -43
- package/src/plugins/image/insert-image-handler.js +62 -27
- package/src/plugins/index.jsx +23 -41
- package/src/plugins/list/index.jsx +70 -95
- package/src/plugins/math/index.jsx +102 -82
- package/src/plugins/media/index.jsx +159 -124
- package/src/plugins/media/media-dialog.js +98 -71
- package/src/plugins/media/media-toolbar.jsx +8 -8
- package/src/plugins/media/media-wrapper.jsx +29 -30
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
- package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
- package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
- package/src/plugins/respArea/icons/index.jsx +11 -14
- package/src/plugins/respArea/index.jsx +92 -52
- package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
- package/src/plugins/respArea/utils.jsx +26 -35
- package/src/plugins/table/icons/index.jsx +17 -11
- package/src/plugins/table/index.jsx +288 -231
- package/src/plugins/table/table-toolbar.jsx +15 -11
- package/src/plugins/toolbar/default-toolbar.jsx +65 -19
- package/src/plugins/toolbar/done-button.jsx +4 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
- package/src/plugins/toolbar/index.jsx +2 -3
- package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
- package/src/plugins/toolbar/toolbar.jsx +244 -221
- package/src/plugins/utils.js +21 -4
- package/src/serialization.jsx +32 -32
- package/src/test-serializer.js +139 -0
- 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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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,
|
|
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,
|
|
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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"}
|