@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,16 +7,6 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports["default"] = exports.EditorAndToolbar = void 0;
9
9
 
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
15
-
16
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
17
-
18
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
19
-
20
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
11
 
22
12
  var _react = _interopRequireDefault(require("react"));
@@ -33,112 +23,203 @@ var _styles = require("@material-ui/core/styles");
33
23
 
34
24
  var _propTypes = _interopRequireDefault(require("prop-types"));
35
25
 
36
- var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
37
-
38
- var _slateDevEnvironment = require("slate-dev-environment");
39
-
40
26
  var _renderUi = require("@pie-lib/render-ui");
41
27
 
42
- 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); }; }
43
-
44
- 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; } }
45
-
46
28
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:toolbar:editor-and-toolbar');
47
-
48
- var EditorAndToolbar = /*#__PURE__*/function (_React$Component) {
49
- (0, _inherits2["default"])(EditorAndToolbar, _React$Component);
50
-
51
- var _super = _createSuper(EditorAndToolbar);
52
-
53
- function EditorAndToolbar() {
54
- (0, _classCallCheck2["default"])(this, EditorAndToolbar);
55
- return _super.apply(this, arguments);
56
- }
57
-
58
- (0, _createClass2["default"])(EditorAndToolbar, [{
59
- key: "componentDidMount",
60
- value:
61
- /** This is an interim fix until this PR is merged in slate:
62
- * https://github.com/ianstormtaylor/slate/pull/2236
63
- */
64
- function componentDidMount() {
65
- if (_slateDevEnvironment.IS_FIREFOX) {
66
- this.editorRef.tmp.isUpdatingSelection = true;
29
+ var style = {
30
+ root: {
31
+ position: 'relative',
32
+ padding: '0px',
33
+ border: '1px solid #ccc',
34
+ borderRadius: '4px',
35
+ cursor: 'text',
36
+ '& [data-slate-editor="true"]': {
37
+ wordBreak: 'break-word',
38
+ overflow: 'visible',
39
+ maxHeight: '500px',
40
+ // needed in order to be able to put the focus before a void element when it is the first one in the editor
41
+ padding: '5px'
42
+ },
43
+ '& [data-slate-void="true"]': {
44
+ // needed in order to be able to put the focus before a void element when it is the first one in the editor
45
+ padding: '1px'
46
+ }
47
+ },
48
+ children: {
49
+ padding: '10px 16px'
50
+ },
51
+ editorHolder: {
52
+ position: 'relative',
53
+ padding: '0px',
54
+ overflowY: 'scroll',
55
+ color: _renderUi.color.text(),
56
+ backgroundColor: _renderUi.color.background(),
57
+ '&::before': {
58
+ left: '0',
59
+ right: '0',
60
+ bottom: '0',
61
+ height: '1px',
62
+ content: '""',
63
+ position: 'absolute',
64
+ transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',
65
+ pointerEvents: 'none'
66
+ },
67
+ '&::after': {
68
+ left: '0',
69
+ right: '0',
70
+ bottom: '0',
71
+ height: '1px',
72
+ content: '""',
73
+ position: 'absolute',
74
+ transform: 'scaleX(0)',
75
+ transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',
76
+ backgroundColor: 'rgba(0, 0, 0, 0.42)'
77
+ },
78
+ '&:focus': {
79
+ '&::after': {
80
+ transform: 'scaleX(1)',
81
+ backgroundColor: _theme.primary,
82
+ height: '2px'
83
+ }
84
+ },
85
+ '&:hover': {
86
+ '&::after': {
87
+ transform: 'scaleX(1)',
88
+ backgroundColor: 'black',
89
+ height: '2px'
67
90
  }
68
91
  }
69
- }, {
70
- key: "render",
71
- value: function render() {
72
- var _classNames,
73
- _this = this,
74
- _classNames2;
75
-
76
- var _this$props = this.props,
77
- classes = _this$props.classes,
78
- children = _this$props.children,
79
- value = _this$props.value,
80
- plugins = _this$props.plugins,
81
- onChange = _this$props.onChange,
82
- getFocusedValue = _this$props.getFocusedValue,
83
- onDone = _this$props.onDone,
84
- focusedNode = _this$props.focusedNode,
85
- autoWidth = _this$props.autoWidth,
86
- readOnly = _this$props.readOnly,
87
- disableScrollbar = _this$props.disableScrollbar,
88
- disableUnderline = _this$props.disableUnderline,
89
- pluginProps = _this$props.pluginProps,
90
- toolbarOpts = _this$props.toolbarOpts,
91
- onDataChange = _this$props.onDataChange,
92
- toolbarRef = _this$props.toolbarRef;
93
- var inFocus = value.isFocused || focusedNode !== null && focusedNode !== undefined;
94
- var holderNames = (0, _classnames["default"])(classes.editorHolder, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.editorInFocus, inFocus), (0, _defineProperty2["default"])(_classNames, classes.readOnly, readOnly), (0, _defineProperty2["default"])(_classNames, classes.disabledUnderline, disableUnderline), (0, _defineProperty2["default"])(_classNames, classes.disabledScrollbar, disableScrollbar), _classNames));
95
- var clonedChildren = children;
96
-
97
- if (typeof children !== 'string') {
98
- clonedChildren = /*#__PURE__*/_react["default"].cloneElement(children, {
99
- ref: function ref(el) {
100
- return _this.editorRef = el;
101
- }
102
- });
92
+ },
93
+ disabledUnderline: {
94
+ '&::before': {
95
+ display: 'none'
96
+ },
97
+ '&::after': {
98
+ display: 'none'
99
+ }
100
+ },
101
+ disabledScrollbar: {
102
+ '&::-webkit-scrollbar': {
103
+ display: 'none'
104
+ },
105
+ scrollbarWidth: 'none',
106
+ '-ms-overflow-style': 'none'
107
+ },
108
+ readOnly: {
109
+ '&::before': {
110
+ background: 'transparent',
111
+ backgroundSize: '5px 1px',
112
+ backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',
113
+ backgroundRepeat: 'repeat-x',
114
+ backgroundPosition: 'left top'
115
+ },
116
+ '&::after': {
117
+ left: '0',
118
+ right: '0',
119
+ bottom: '0',
120
+ height: '1px',
121
+ content: '""',
122
+ position: 'absolute',
123
+ transform: 'scaleX(0)',
124
+ transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',
125
+ backgroundColor: 'rgba(0, 0, 0, 0)'
126
+ },
127
+ '&:hover': {
128
+ '&::after': {
129
+ transform: 'scaleX(0)',
130
+ backgroundColor: 'black',
131
+ height: '2px'
103
132
  }
104
-
105
- log('[render] inFocus: ', inFocus, 'value.isFocused:', value.isFocused, 'focused node: ', focusedNode);
106
- return /*#__PURE__*/_react["default"].createElement("div", {
107
- className: (0, _classnames["default"])((_classNames2 = {}, (0, _defineProperty2["default"])(_classNames2, classes.noBorder, toolbarOpts && toolbarOpts.noBorder), (0, _defineProperty2["default"])(_classNames2, classes.error, toolbarOpts && toolbarOpts.error), _classNames2), classes.root)
108
- }, /*#__PURE__*/_react["default"].createElement("div", {
109
- className: holderNames
110
- }, /*#__PURE__*/_react["default"].createElement("div", {
111
- className: (0, _classnames["default"])((0, _defineProperty2["default"])({}, classes.noPadding, toolbarOpts && toolbarOpts.noBorder), classes.children)
112
- }, clonedChildren)), /*#__PURE__*/_react["default"].createElement(_toolbar["default"], {
113
- autoWidth: autoWidth,
114
- plugins: plugins,
115
- focusedNode: focusedNode,
116
- value: value,
117
- isFocused: inFocus,
118
- onChange: onChange,
119
- getFocusedValue: getFocusedValue,
120
- onDone: onDone,
121
- onDataChange: onDataChange,
122
- toolbarRef: toolbarRef,
123
- pluginProps: pluginProps,
124
- toolbarOpts: toolbarOpts
125
- }));
126
133
  }
127
- }]);
128
- return EditorAndToolbar;
129
- }(_react["default"].Component);
134
+ },
135
+ editorInFocus: {
136
+ '&::after': {
137
+ transform: 'scaleX(1)',
138
+ backgroundColor: _theme.primary,
139
+ height: '2px'
140
+ },
141
+ '&:hover': {
142
+ '&::after': {
143
+ backgroundColor: _theme.primary
144
+ }
145
+ }
146
+ },
147
+ error: {
148
+ border: '2px solid red'
149
+ },
150
+ noBorder: {
151
+ border: 'none'
152
+ },
153
+ noPadding: {
154
+ padding: 0
155
+ }
156
+ };
157
+
158
+ var EditorAndToolbar = function EditorAndToolbar(props) {
159
+ var _classNames, _classNames2;
160
+
161
+ var editor = props.editor,
162
+ classes = props.classes,
163
+ children = props.children,
164
+ value = props.value,
165
+ plugins = props.plugins,
166
+ onChange = props.onChange,
167
+ getFocusedValue = props.getFocusedValue,
168
+ onDone = props.onDone,
169
+ focusedNode = props.focusedNode,
170
+ autoWidth = props.autoWidth,
171
+ readOnly = props.readOnly,
172
+ disableScrollbar = props.disableScrollbar,
173
+ disableUnderline = props.disableUnderline,
174
+ pluginProps = props.pluginProps,
175
+ toolbarOpts = props.toolbarOpts,
176
+ toolbarRef = props.toolbarRef,
177
+ isFocused = props.isFocused;
178
+ var holderNames = (0, _classnames["default"])(classes.editorHolder, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, classes.editorInFocus, isFocused), (0, _defineProperty2["default"])(_classNames, classes.readOnly, readOnly), (0, _defineProperty2["default"])(_classNames, classes.disabledUnderline, disableUnderline), (0, _defineProperty2["default"])(_classNames, classes.disabledScrollbar, disableScrollbar), _classNames));
179
+ var clonedChildren = children;
180
+ log('[render] inFocus: ', isFocused, 'value.isFocused:', value.isFocused, 'focused node: ', focusedNode);
181
+ return /*#__PURE__*/_react["default"].createElement("div", {
182
+ className: (0, _classnames["default"])((_classNames2 = {}, (0, _defineProperty2["default"])(_classNames2, classes.noBorder, toolbarOpts && toolbarOpts.noBorder), (0, _defineProperty2["default"])(_classNames2, classes.error, toolbarOpts && toolbarOpts.error), _classNames2), classes.root)
183
+ }, /*#__PURE__*/_react["default"].createElement("div", {
184
+ className: holderNames
185
+ }, /*#__PURE__*/_react["default"].createElement("div", {
186
+ className: (0, _classnames["default"])((0, _defineProperty2["default"])({}, classes.noPadding, toolbarOpts && toolbarOpts.noBorder), classes.children)
187
+ }, clonedChildren)), /*#__PURE__*/_react["default"].createElement(_toolbar["default"], {
188
+ editor: editor,
189
+ autoWidth: autoWidth,
190
+ plugins: plugins,
191
+ focusedNode: focusedNode,
192
+ value: value,
193
+ isFocused: isFocused,
194
+ onChange: onChange,
195
+ getFocusedValue: getFocusedValue,
196
+ onDone: onDone,
197
+ toolbarRef: toolbarRef,
198
+ pluginProps: pluginProps,
199
+ toolbarOpts: toolbarOpts
200
+ }));
201
+ };
130
202
 
131
203
  exports.EditorAndToolbar = EditorAndToolbar;
132
- (0, _defineProperty2["default"])(EditorAndToolbar, "propTypes", {
204
+ EditorAndToolbar.propTypes = {
133
205
  children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired,
134
- value: _slatePropTypes["default"].value.isRequired,
206
+ value: _propTypes["default"].arrayOf(_propTypes["default"].shape({
207
+ type: _propTypes["default"].string,
208
+ children: _propTypes["default"].array,
209
+ data: _propTypes["default"].object
210
+ })),
211
+ editor: _propTypes["default"].object.isRequired,
212
+ isFocused: _propTypes["default"].bool,
135
213
  plugins: _propTypes["default"].array.isRequired,
136
214
  onChange: _propTypes["default"].func.isRequired,
137
215
  getFocusedValue: _propTypes["default"].func.isRequired,
138
216
  onDone: _propTypes["default"].func.isRequired,
139
- onDataChange: _propTypes["default"].func,
140
217
  toolbarRef: _propTypes["default"].func,
141
- focusedNode: _slatePropTypes["default"].node,
218
+ focusedNode: _propTypes["default"].shape({
219
+ type: _propTypes["default"].string,
220
+ children: _propTypes["default"].array,
221
+ data: _propTypes["default"].object
222
+ }),
142
223
  readOnly: _propTypes["default"].bool,
143
224
  disableScrollbar: _propTypes["default"].bool,
144
225
  disableUnderline: _propTypes["default"].bool,
@@ -146,141 +227,14 @@ exports.EditorAndToolbar = EditorAndToolbar;
146
227
  classes: _propTypes["default"].object.isRequired,
147
228
  pluginProps: _propTypes["default"].object,
148
229
  toolbarOpts: _propTypes["default"].shape({
149
- position: _propTypes["default"].oneOf(['bottom', 'top']),
150
230
  alwaysVisible: _propTypes["default"].bool,
151
- error: _propTypes["default"].string
231
+ error: _propTypes["default"].string,
232
+ noBorder: _propTypes["default"].bool,
233
+ position: _propTypes["default"].oneOf(['bottom', 'top'])
152
234
  })
153
- });
154
-
155
- var style = function style(theme) {
156
- return {
157
- root: {
158
- position: 'relative',
159
- padding: '0px',
160
- border: '1px solid #ccc',
161
- borderRadius: '4px',
162
- cursor: 'text',
163
- '& [data-slate-editor="true"]': {
164
- wordBreak: 'break-word',
165
- overflow: 'visible',
166
- maxHeight: '500px',
167
- // needed in order to be able to put the focus before a void element when it is the first one in the editor
168
- padding: '5px'
169
- }
170
- },
171
- children: {
172
- padding: '10px 16px'
173
- },
174
- editorHolder: {
175
- position: 'relative',
176
- padding: '0px',
177
- overflowY: 'scroll',
178
- color: _renderUi.color.text(),
179
- backgroundColor: _renderUi.color.background(),
180
- '&::before': {
181
- left: '0',
182
- right: '0',
183
- bottom: '0',
184
- height: '1px',
185
- content: '""',
186
- position: 'absolute',
187
- transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',
188
- pointerEvents: 'none',
189
- backgroundColor: 'rgba(0, 0, 0, 0.42)'
190
- },
191
- '&::after': {
192
- left: '0',
193
- right: '0',
194
- bottom: '0',
195
- height: '1px',
196
- content: '""',
197
- position: 'absolute',
198
- transform: 'scaleX(0)',
199
- transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',
200
- backgroundColor: 'rgba(0, 0, 0, 0.42)'
201
- },
202
- '&:focus': {
203
- '&::after': {
204
- transform: 'scaleX(1)',
205
- backgroundColor: _theme.primary,
206
- height: '2px'
207
- }
208
- },
209
- '&:hover': {
210
- '&::after': {
211
- transform: 'scaleX(1)',
212
- backgroundColor: theme.palette.common.black,
213
- height: '2px'
214
- }
215
- }
216
- },
217
- disabledUnderline: {
218
- '&::before': {
219
- display: 'none'
220
- },
221
- '&::after': {
222
- display: 'none'
223
- }
224
- },
225
- disabledScrollbar: {
226
- '&::-webkit-scrollbar': {
227
- display: 'none'
228
- },
229
- scrollbarWidth: 'none',
230
- '-ms-overflow-style': 'none'
231
- },
232
- readOnly: {
233
- '&::before': {
234
- background: 'transparent',
235
- backgroundSize: '5px 1px',
236
- backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',
237
- backgroundRepeat: 'repeat-x',
238
- backgroundPosition: 'left top'
239
- },
240
- '&::after': {
241
- left: '0',
242
- right: '0',
243
- bottom: '0',
244
- height: '1px',
245
- content: '""',
246
- position: 'absolute',
247
- transform: 'scaleX(0)',
248
- transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',
249
- backgroundColor: 'rgba(0, 0, 0, 0)'
250
- },
251
- '&:hover': {
252
- '&::after': {
253
- transform: 'scaleX(0)',
254
- backgroundColor: theme.palette.common.black,
255
- height: '2px'
256
- }
257
- }
258
- },
259
- editorInFocus: {
260
- '&::after': {
261
- transform: 'scaleX(1)',
262
- backgroundColor: _theme.primary,
263
- height: '2px'
264
- },
265
- '&:hover': {
266
- '&::after': {
267
- backgroundColor: _theme.primary
268
- }
269
- }
270
- },
271
- error: {
272
- border: "2px solid ".concat(theme.palette.error.main)
273
- },
274
- noBorder: {
275
- border: 'none'
276
- },
277
- noPadding: {
278
- padding: 0
279
- }
280
- };
281
235
  };
282
236
 
283
237
  var _default = (0, _styles.withStyles)(style)(EditorAndToolbar);
284
238
 
285
239
  exports["default"] = _default;
286
- //# sourceMappingURL=editor-and-toolbar.js.map
240
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","style","root","position","padding","border","borderRadius","cursor","wordBreak","overflow","maxHeight","children","editorHolder","overflowY","color","text","backgroundColor","background","left","right","bottom","height","content","transition","pointerEvents","transform","primary","disabledUnderline","display","disabledScrollbar","scrollbarWidth","readOnly","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","editorInFocus","error","noBorder","noPadding","EditorAndToolbar","props","editor","classes","value","plugins","onChange","getFocusedValue","onDone","focusedNode","autoWidth","disableScrollbar","disableUnderline","pluginProps","toolbarOpts","toolbarRef","isFocused","holderNames","classNames","clonedChildren","propTypes","PropTypes","oneOfType","arrayOf","node","isRequired","shape","type","string","array","data","object","bool","func","alwaysVisible","oneOf","withStyles"],"sources":["../../../src/plugins/toolbar/editor-and-toolbar.jsx"],"sourcesContent":["import React from 'react';\n\nimport Toolbar from './toolbar';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { primary } from '../../theme';\nimport { withStyles } from '@material-ui/core/styles';\nimport PropTypes from 'prop-types';\nimport { color } from '@pie-lib/render-ui';\n\nconst log = debug('@pie-lib:editable-html:plugins:toolbar:editor-and-toolbar');\n\nconst style = {\n  root: {\n    position: 'relative',\n    padding: '0px',\n    border: '1px solid #ccc',\n    borderRadius: '4px',\n    cursor: 'text',\n    '& [data-slate-editor=\"true\"]': {\n      wordBreak: 'break-word',\n      overflow: 'visible',\n      maxHeight: '500px',\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '5px'\n    },\n    '& [data-slate-void=\"true\"]': {\n      // needed in order to be able to put the focus before a void element when it is the first one in the editor\n      padding: '1px'\n    }\n  },\n  children: {\n    padding: '10px 16px'\n  },\n  editorHolder: {\n    position: 'relative',\n    padding: '0px',\n    overflowY: 'scroll',\n    color: color.text(),\n    backgroundColor: color.background(),\n    '&::before': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n      pointerEvents: 'none',\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition:\n        'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0.42)'\n    },\n    '&:focus': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: primary,\n        height: '2px'\n      }\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(1)',\n        backgroundColor: 'black',\n        height: '2px'\n      }\n    }\n  },\n  disabledUnderline: {\n    '&::before': {\n      display: 'none'\n    },\n    '&::after': {\n      display: 'none'\n    }\n  },\n  disabledScrollbar: {\n    '&::-webkit-scrollbar': {\n      display: 'none'\n    },\n    scrollbarWidth: 'none',\n    '-ms-overflow-style': 'none'\n  },\n  readOnly: {\n    '&::before': {\n      background: 'transparent',\n      backgroundSize: '5px 1px',\n      backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n      backgroundRepeat: 'repeat-x',\n      backgroundPosition: 'left top'\n    },\n    '&::after': {\n      left: '0',\n      right: '0',\n      bottom: '0',\n      height: '1px',\n      content: '\"\"',\n      position: 'absolute',\n      transform: 'scaleX(0)',\n      transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n      backgroundColor: 'rgba(0, 0, 0, 0)'\n    },\n    '&:hover': {\n      '&::after': {\n        transform: 'scaleX(0)',\n        backgroundColor: 'black',\n        height: '2px'\n      }\n    }\n  },\n  editorInFocus: {\n    '&::after': {\n      transform: 'scaleX(1)',\n      backgroundColor: primary,\n      height: '2px'\n    },\n    '&:hover': {\n      '&::after': {\n        backgroundColor: primary\n      }\n    }\n  },\n  error: {\n    border: '2px solid red'\n  },\n  noBorder: {\n    border: 'none'\n  },\n  noPadding: {\n    padding: 0\n  }\n};\n\nexport const EditorAndToolbar = props => {\n  const {\n    editor,\n    classes,\n    children,\n    value,\n    plugins,\n    onChange,\n    getFocusedValue,\n    onDone,\n    focusedNode,\n    autoWidth,\n    readOnly,\n    disableScrollbar,\n    disableUnderline,\n    pluginProps,\n    toolbarOpts,\n    toolbarRef,\n    isFocused\n  } = props;\n\n  const holderNames = classNames(classes.editorHolder, {\n    [classes.editorInFocus]: isFocused,\n    [classes.readOnly]: readOnly,\n    [classes.disabledUnderline]: disableUnderline,\n    [classes.disabledScrollbar]: disableScrollbar\n  });\n  let clonedChildren = children;\n\n  log(\n    '[render] inFocus: ',\n    isFocused,\n    'value.isFocused:',\n    value.isFocused,\n    'focused node: ',\n    focusedNode\n  );\n\n  return (\n    <div\n      className={classNames(\n        {\n          [classes.noBorder]: toolbarOpts && toolbarOpts.noBorder,\n          [classes.error]: toolbarOpts && toolbarOpts.error\n        },\n        classes.root\n      )}\n    >\n      <div className={holderNames}>\n        <div\n          className={classNames(\n            {\n              [classes.noPadding]: toolbarOpts && toolbarOpts.noBorder\n            },\n            classes.children\n          )}\n        >\n          {clonedChildren}\n        </div>\n      </div>\n      <Toolbar\n        editor={editor}\n        autoWidth={autoWidth}\n        plugins={plugins}\n        focusedNode={focusedNode}\n        value={value}\n        isFocused={isFocused}\n        onChange={onChange}\n        getFocusedValue={getFocusedValue}\n        onDone={onDone}\n        toolbarRef={toolbarRef}\n        pluginProps={pluginProps}\n        toolbarOpts={toolbarOpts}\n      />\n    </div>\n  );\n};\n\nEditorAndToolbar.propTypes = {\n  children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n  value: PropTypes.arrayOf(\n    PropTypes.shape({\n      type: PropTypes.string,\n      children: PropTypes.array,\n      data: PropTypes.object\n    })\n  ),\n  editor: PropTypes.object.isRequired,\n  isFocused: PropTypes.bool,\n  plugins: PropTypes.array.isRequired,\n  onChange: PropTypes.func.isRequired,\n  getFocusedValue: PropTypes.func.isRequired,\n  onDone: PropTypes.func.isRequired,\n  toolbarRef: PropTypes.func,\n  focusedNode: PropTypes.shape({\n    type: PropTypes.string,\n    children: PropTypes.array,\n    data: PropTypes.object\n  }),\n  readOnly: PropTypes.bool,\n  disableScrollbar: PropTypes.bool,\n  disableUnderline: PropTypes.bool,\n  autoWidth: PropTypes.bool,\n  classes: PropTypes.object.isRequired,\n  pluginProps: PropTypes.object,\n  toolbarOpts: PropTypes.shape({\n    alwaysVisible: PropTypes.bool,\n    error: PropTypes.string,\n    noBorder: PropTypes.bool,\n    position: PropTypes.oneOf(['bottom', 'top'])\n  })\n};\n\nexport default withStyles(style)(EditorAndToolbar);\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/toolbar/editor-and-toolbar.jsx"],"names":["log","EditorAndToolbar","IS_FIREFOX","editorRef","tmp","isUpdatingSelection","props","classes","children","value","plugins","onChange","getFocusedValue","onDone","focusedNode","autoWidth","readOnly","disableScrollbar","disableUnderline","pluginProps","toolbarOpts","onDataChange","toolbarRef","inFocus","isFocused","undefined","holderNames","editorHolder","editorInFocus","disabledUnderline","disabledScrollbar","clonedChildren","React","cloneElement","ref","el","noBorder","error","root","noPadding","Component","PropTypes","oneOfType","arrayOf","node","isRequired","SlatePropTypes","array","func","bool","object","shape","position","oneOf","alwaysVisible","string","style","theme","padding","border","borderRadius","cursor","wordBreak","overflow","maxHeight","overflowY","color","text","backgroundColor","background","left","right","bottom","height","content","transition","pointerEvents","transform","primary","palette","common","black","display","scrollbarWidth","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","main"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;AAEA,IAAMA,GAAG,GAAG,uBAAM,2DAAN,CAAZ;;IAEaC,gB;;;;;;;;;;;;;AAwBX;AACF;AACA;AACE,iCAAoB;AAClB,UAAIC,+BAAJ,EAAgB;AACd,aAAKC,SAAL,CAAeC,GAAf,CAAmBC,mBAAnB,GAAyC,IAAzC;AACD;AACF;;;WAED,kBAAS;AAAA;AAAA;AAAA;;AACP,wBAiBI,KAAKC,KAjBT;AAAA,UACEC,OADF,eACEA,OADF;AAAA,UAEEC,QAFF,eAEEA,QAFF;AAAA,UAGEC,KAHF,eAGEA,KAHF;AAAA,UAIEC,OAJF,eAIEA,OAJF;AAAA,UAKEC,QALF,eAKEA,QALF;AAAA,UAMEC,eANF,eAMEA,eANF;AAAA,UAOEC,MAPF,eAOEA,MAPF;AAAA,UAQEC,WARF,eAQEA,WARF;AAAA,UASEC,SATF,eASEA,SATF;AAAA,UAUEC,QAVF,eAUEA,QAVF;AAAA,UAWEC,gBAXF,eAWEA,gBAXF;AAAA,UAYEC,gBAZF,eAYEA,gBAZF;AAAA,UAaEC,WAbF,eAaEA,WAbF;AAAA,UAcEC,WAdF,eAcEA,WAdF;AAAA,UAeEC,YAfF,eAeEA,YAfF;AAAA,UAgBEC,UAhBF,eAgBEA,UAhBF;AAmBA,UAAMC,OAAO,GAAGd,KAAK,CAACe,SAAN,IAAoBV,WAAW,KAAK,IAAhB,IAAwBA,WAAW,KAAKW,SAA5E;AACA,UAAMC,WAAW,GAAG,4BAAWnB,OAAO,CAACoB,YAAnB,mEACjBpB,OAAO,CAACqB,aADS,EACOL,OADP,iDAEjBhB,OAAO,CAACS,QAFS,EAEEA,QAFF,iDAGjBT,OAAO,CAACsB,iBAHS,EAGWX,gBAHX,iDAIjBX,OAAO,CAACuB,iBAJS,EAIWb,gBAJX,gBAApB;AAMA,UAAIc,cAAc,GAAGvB,QAArB;;AAEA,UAAI,OAAOA,QAAP,KAAoB,QAAxB,EAAkC;AAChCuB,QAAAA,cAAc,gBAAGC,kBAAMC,YAAN,CAAmBzB,QAAnB,EAA6B;AAC5C0B,UAAAA,GAAG,EAAE,aAACC,EAAD;AAAA,mBAAS,KAAI,CAAChC,SAAL,GAAiBgC,EAA1B;AAAA;AADuC,SAA7B,CAAjB;AAGD;;AAEDnC,MAAAA,GAAG,CAAC,oBAAD,EAAuBuB,OAAvB,EAAgC,kBAAhC,EAAoDd,KAAK,CAACe,SAA1D,EAAqE,gBAArE,EAAuFV,WAAvF,CAAH;AAEA,0BACE;AACE,QAAA,SAAS,EAAE,+FAENP,OAAO,CAAC6B,QAFF,EAEahB,WAAW,IAAIA,WAAW,CAACgB,QAFxC,kDAGN7B,OAAO,CAAC8B,KAHF,EAGUjB,WAAW,IAAIA,WAAW,CAACiB,KAHrC,kBAKT9B,OAAO,CAAC+B,IALC;AADb,sBASE;AAAK,QAAA,SAAS,EAAEZ;AAAhB,sBACE;AACE,QAAA,SAAS,EAAE,iEAENnB,OAAO,CAACgC,SAFF,EAEcnB,WAAW,IAAIA,WAAW,CAACgB,QAFzC,GAIT7B,OAAO,CAACC,QAJC;AADb,SAQGuB,cARH,CADF,CATF,eAqBE,gCAAC,mBAAD;AACE,QAAA,SAAS,EAAEhB,SADb;AAEE,QAAA,OAAO,EAAEL,OAFX;AAGE,QAAA,WAAW,EAAEI,WAHf;AAIE,QAAA,KAAK,EAAEL,KAJT;AAKE,QAAA,SAAS,EAAEc,OALb;AAME,QAAA,QAAQ,EAAEZ,QANZ;AAOE,QAAA,eAAe,EAAEC,eAPnB;AAQE,QAAA,MAAM,EAAEC,MARV;AASE,QAAA,YAAY,EAAEQ,YAThB;AAUE,QAAA,UAAU,EAAEC,UAVd;AAWE,QAAA,WAAW,EAAEH,WAXf;AAYE,QAAA,WAAW,EAAEC;AAZf,QArBF,CADF;AAsCD;;;EA5GmCY,kBAAMQ,S;;;iCAA/BvC,gB,eACQ;AACjBO,EAAAA,QAAQ,EAAEiC,sBAAUC,SAAV,CAAoB,CAACD,sBAAUE,OAAV,CAAkBF,sBAAUG,IAA5B,CAAD,EAAoCH,sBAAUG,IAA9C,CAApB,EAAyEC,UADlE;AAEjBpC,EAAAA,KAAK,EAAEqC,2BAAerC,KAAf,CAAqBoC,UAFX;AAGjBnC,EAAAA,OAAO,EAAE+B,sBAAUM,KAAV,CAAgBF,UAHR;AAIjBlC,EAAAA,QAAQ,EAAE8B,sBAAUO,IAAV,CAAeH,UAJR;AAKjBjC,EAAAA,eAAe,EAAE6B,sBAAUO,IAAV,CAAeH,UALf;AAMjBhC,EAAAA,MAAM,EAAE4B,sBAAUO,IAAV,CAAeH,UANN;AAOjBxB,EAAAA,YAAY,EAAEoB,sBAAUO,IAPP;AAQjB1B,EAAAA,UAAU,EAAEmB,sBAAUO,IARL;AASjBlC,EAAAA,WAAW,EAAEgC,2BAAeF,IATX;AAUjB5B,EAAAA,QAAQ,EAAEyB,sBAAUQ,IAVH;AAWjBhC,EAAAA,gBAAgB,EAAEwB,sBAAUQ,IAXX;AAYjB/B,EAAAA,gBAAgB,EAAEuB,sBAAUQ,IAZX;AAajBlC,EAAAA,SAAS,EAAE0B,sBAAUQ,IAbJ;AAcjB1C,EAAAA,OAAO,EAAEkC,sBAAUS,MAAV,CAAiBL,UAdT;AAejB1B,EAAAA,WAAW,EAAEsB,sBAAUS,MAfN;AAgBjB9B,EAAAA,WAAW,EAAEqB,sBAAUU,KAAV,CAAgB;AAC3BC,IAAAA,QAAQ,EAAEX,sBAAUY,KAAV,CAAgB,CAAC,QAAD,EAAW,KAAX,CAAhB,CADiB;AAE3BC,IAAAA,aAAa,EAAEb,sBAAUQ,IAFE;AAG3BZ,IAAAA,KAAK,EAAEI,sBAAUc;AAHU,GAAhB;AAhBI,C;;AA8GrB,IAAMC,KAAK,GAAG,SAARA,KAAQ,CAACC,KAAD;AAAA,SAAY;AACxBnB,IAAAA,IAAI,EAAE;AACJc,MAAAA,QAAQ,EAAE,UADN;AAEJM,MAAAA,OAAO,EAAE,KAFL;AAGJC,MAAAA,MAAM,EAAE,gBAHJ;AAIJC,MAAAA,YAAY,EAAE,KAJV;AAKJC,MAAAA,MAAM,EAAE,MALJ;AAMJ,sCAAgC;AAC9BC,QAAAA,SAAS,EAAE,YADmB;AAE9BC,QAAAA,QAAQ,EAAE,SAFoB;AAG9BC,QAAAA,SAAS,EAAE,OAHmB;AAI9B;AACAN,QAAAA,OAAO,EAAE;AALqB;AAN5B,KADkB;AAexBlD,IAAAA,QAAQ,EAAE;AACRkD,MAAAA,OAAO,EAAE;AADD,KAfc;AAkBxB/B,IAAAA,YAAY,EAAE;AACZyB,MAAAA,QAAQ,EAAE,UADE;AAEZM,MAAAA,OAAO,EAAE,KAFG;AAGZO,MAAAA,SAAS,EAAE,QAHC;AAIZC,MAAAA,KAAK,EAAEA,gBAAMC,IAAN,EAJK;AAKZC,MAAAA,eAAe,EAAEF,gBAAMG,UAAN,EALL;AAMZ,mBAAa;AACXC,QAAAA,IAAI,EAAE,GADK;AAEXC,QAAAA,KAAK,EAAE,GAFI;AAGXC,QAAAA,MAAM,EAAE,GAHG;AAIXC,QAAAA,MAAM,EAAE,KAJG;AAKXC,QAAAA,OAAO,EAAE,IALE;AAMXtB,QAAAA,QAAQ,EAAE,UANC;AAOXuB,QAAAA,UAAU,EAAE,yDAPD;AAQXC,QAAAA,aAAa,EAAE,MARJ;AASXR,QAAAA,eAAe,EAAE;AATN,OAND;AAiBZ,kBAAY;AACVE,QAAAA,IAAI,EAAE,GADI;AAEVC,QAAAA,KAAK,EAAE,GAFG;AAGVC,QAAAA,MAAM,EAAE,GAHE;AAIVC,QAAAA,MAAM,EAAE,KAJE;AAKVC,QAAAA,OAAO,EAAE,IALC;AAMVtB,QAAAA,QAAQ,EAAE,UANA;AAOVyB,QAAAA,SAAS,EAAE,WAPD;AAQVF,QAAAA,UAAU,EAAE,mFARF;AASVP,QAAAA,eAAe,EAAE;AATP,OAjBA;AA4BZ,iBAAW;AACT,oBAAY;AACVS,UAAAA,SAAS,EAAE,WADD;AAEVT,UAAAA,eAAe,EAAEU,cAFP;AAGVL,UAAAA,MAAM,EAAE;AAHE;AADH,OA5BC;AAmCZ,iBAAW;AACT,oBAAY;AACVI,UAAAA,SAAS,EAAE,WADD;AAEVT,UAAAA,eAAe,EAAEX,KAAK,CAACsB,OAAN,CAAcC,MAAd,CAAqBC,KAF5B;AAGVR,UAAAA,MAAM,EAAE;AAHE;AADH;AAnCC,KAlBU;AA6DxB5C,IAAAA,iBAAiB,EAAE;AACjB,mBAAa;AACXqD,QAAAA,OAAO,EAAE;AADE,OADI;AAIjB,kBAAY;AACVA,QAAAA,OAAO,EAAE;AADC;AAJK,KA7DK;AAqExBpD,IAAAA,iBAAiB,EAAE;AACjB,8BAAwB;AACtBoD,QAAAA,OAAO,EAAE;AADa,OADP;AAIjBC,MAAAA,cAAc,EAAE,MAJC;AAKjB,4BAAsB;AALL,KArEK;AA4ExBnE,IAAAA,QAAQ,EAAE;AACR,mBAAa;AACXqD,QAAAA,UAAU,EAAE,aADD;AAEXe,QAAAA,cAAc,EAAE,SAFL;AAGXC,QAAAA,eAAe,EAAE,oEAHN;AAIXC,QAAAA,gBAAgB,EAAE,UAJP;AAKXC,QAAAA,kBAAkB,EAAE;AALT,OADL;AAQR,kBAAY;AACVjB,QAAAA,IAAI,EAAE,GADI;AAEVC,QAAAA,KAAK,EAAE,GAFG;AAGVC,QAAAA,MAAM,EAAE,GAHE;AAIVC,QAAAA,MAAM,EAAE,KAJE;AAKVC,QAAAA,OAAO,EAAE,IALC;AAMVtB,QAAAA,QAAQ,EAAE,UANA;AAOVyB,QAAAA,SAAS,EAAE,WAPD;AAQVF,QAAAA,UAAU,EAAE,iFARF;AASVP,QAAAA,eAAe,EAAE;AATP,OARJ;AAmBR,iBAAW;AACT,oBAAY;AACVS,UAAAA,SAAS,EAAE,WADD;AAEVT,UAAAA,eAAe,EAAEX,KAAK,CAACsB,OAAN,CAAcC,MAAd,CAAqBC,KAF5B;AAGVR,UAAAA,MAAM,EAAE;AAHE;AADH;AAnBH,KA5Ec;AAuGxB7C,IAAAA,aAAa,EAAE;AACb,kBAAY;AACViD,QAAAA,SAAS,EAAE,WADD;AAEVT,QAAAA,eAAe,EAAEU,cAFP;AAGVL,QAAAA,MAAM,EAAE;AAHE,OADC;AAMb,iBAAW;AACT,oBAAY;AACVL,UAAAA,eAAe,EAAEU;AADP;AADH;AANE,KAvGS;AAmHxBzC,IAAAA,KAAK,EAAE;AACLsB,MAAAA,MAAM,sBAAeF,KAAK,CAACsB,OAAN,CAAc1C,KAAd,CAAoBmD,IAAnC;AADD,KAnHiB;AAsHxBpD,IAAAA,QAAQ,EAAE;AACRuB,MAAAA,MAAM,EAAE;AADA,KAtHc;AAyHxBpB,IAAAA,SAAS,EAAE;AACTmB,MAAAA,OAAO,EAAE;AADA;AAzHa,GAAZ;AAAA,CAAd;;eA8He,wBAAWF,KAAX,EAAkBvD,gBAAlB,C","sourcesContent":["import React from 'react';\nimport Toolbar from './toolbar';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { primary } from '../../theme';\nimport { withStyles } from '@material-ui/core/styles';\nimport PropTypes from 'prop-types';\nimport SlatePropTypes from 'slate-prop-types';\nimport { IS_FIREFOX } from 'slate-dev-environment';\nimport { color } from '@pie-lib/render-ui';\n\nconst log = debug('@pie-lib:editable-html:plugins:toolbar:editor-and-toolbar');\n\nexport class EditorAndToolbar extends React.Component {\n static propTypes = {\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n value: SlatePropTypes.value.isRequired,\n plugins: PropTypes.array.isRequired,\n onChange: PropTypes.func.isRequired,\n getFocusedValue: PropTypes.func.isRequired,\n onDone: PropTypes.func.isRequired,\n onDataChange: PropTypes.func,\n toolbarRef: PropTypes.func,\n focusedNode: SlatePropTypes.node,\n readOnly: PropTypes.bool,\n disableScrollbar: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n autoWidth: PropTypes.bool,\n classes: PropTypes.object.isRequired,\n pluginProps: PropTypes.object,\n toolbarOpts: PropTypes.shape({\n position: PropTypes.oneOf(['bottom', 'top']),\n alwaysVisible: PropTypes.bool,\n error: PropTypes.string,\n }),\n };\n\n /** This is an interim fix until this PR is merged in slate:\n * https://github.com/ianstormtaylor/slate/pull/2236\n */\n componentDidMount() {\n if (IS_FIREFOX) {\n this.editorRef.tmp.isUpdatingSelection = true;\n }\n }\n\n render() {\n const {\n classes,\n children,\n value,\n plugins,\n onChange,\n getFocusedValue,\n onDone,\n focusedNode,\n autoWidth,\n readOnly,\n disableScrollbar,\n disableUnderline,\n pluginProps,\n toolbarOpts,\n onDataChange,\n toolbarRef,\n } = this.props;\n\n const inFocus = value.isFocused || (focusedNode !== null && focusedNode !== undefined);\n const holderNames = classNames(classes.editorHolder, {\n [classes.editorInFocus]: inFocus,\n [classes.readOnly]: readOnly,\n [classes.disabledUnderline]: disableUnderline,\n [classes.disabledScrollbar]: disableScrollbar,\n });\n let clonedChildren = children;\n\n if (typeof children !== 'string') {\n clonedChildren = React.cloneElement(children, {\n ref: (el) => (this.editorRef = el),\n });\n }\n\n log('[render] inFocus: ', inFocus, 'value.isFocused:', value.isFocused, 'focused node: ', focusedNode);\n\n return (\n <div\n className={classNames(\n {\n [classes.noBorder]: toolbarOpts && toolbarOpts.noBorder,\n [classes.error]: toolbarOpts && toolbarOpts.error,\n },\n classes.root,\n )}\n >\n <div className={holderNames}>\n <div\n className={classNames(\n {\n [classes.noPadding]: toolbarOpts && toolbarOpts.noBorder,\n },\n classes.children,\n )}\n >\n {clonedChildren}\n </div>\n </div>\n <Toolbar\n autoWidth={autoWidth}\n plugins={plugins}\n focusedNode={focusedNode}\n value={value}\n isFocused={inFocus}\n onChange={onChange}\n getFocusedValue={getFocusedValue}\n onDone={onDone}\n onDataChange={onDataChange}\n toolbarRef={toolbarRef}\n pluginProps={pluginProps}\n toolbarOpts={toolbarOpts}\n />\n </div>\n );\n }\n}\n\nconst style = (theme) => ({\n root: {\n position: 'relative',\n padding: '0px',\n border: '1px solid #ccc',\n borderRadius: '4px',\n cursor: 'text',\n '& [data-slate-editor=\"true\"]': {\n wordBreak: 'break-word',\n overflow: 'visible',\n maxHeight: '500px',\n // needed in order to be able to put the focus before a void element when it is the first one in the editor\n padding: '5px',\n },\n },\n children: {\n padding: '10px 16px',\n },\n editorHolder: {\n position: 'relative',\n padding: '0px',\n overflowY: 'scroll',\n color: color.text(),\n backgroundColor: color.background(),\n '&::before': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n pointerEvents: 'none',\n backgroundColor: 'rgba(0, 0, 0, 0.42)',\n },\n '&::after': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transform: 'scaleX(0)',\n transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n backgroundColor: 'rgba(0, 0, 0, 0.42)',\n },\n '&:focus': {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: primary,\n height: '2px',\n },\n },\n '&:hover': {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: theme.palette.common.black,\n height: '2px',\n },\n },\n },\n disabledUnderline: {\n '&::before': {\n display: 'none',\n },\n '&::after': {\n display: 'none',\n },\n },\n disabledScrollbar: {\n '&::-webkit-scrollbar': {\n display: 'none',\n },\n scrollbarWidth: 'none',\n '-ms-overflow-style': 'none',\n },\n readOnly: {\n '&::before': {\n background: 'transparent',\n backgroundSize: '5px 1px',\n backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n backgroundRepeat: 'repeat-x',\n backgroundPosition: 'left top',\n },\n '&::after': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transform: 'scaleX(0)',\n transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n backgroundColor: 'rgba(0, 0, 0, 0)',\n },\n '&:hover': {\n '&::after': {\n transform: 'scaleX(0)',\n backgroundColor: theme.palette.common.black,\n height: '2px',\n },\n },\n },\n editorInFocus: {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: primary,\n height: '2px',\n },\n '&:hover': {\n '&::after': {\n backgroundColor: primary,\n },\n },\n },\n error: {\n border: `2px solid ${theme.palette.error.main}`,\n },\n noBorder: {\n border: 'none',\n },\n noPadding: {\n padding: 0,\n },\n});\n\nexport default withStyles(style)(EditorAndToolbar);\n"],"file":"editor-and-toolbar.js"}
1
+ {"version":3,"file":"editor-and-toolbar.js","names":["log","debug","style","root","position","padding","border","borderRadius","cursor","wordBreak","overflow","maxHeight","children","editorHolder","overflowY","color","text","backgroundColor","background","left","right","bottom","height","content","transition","pointerEvents","transform","primary","disabledUnderline","display","disabledScrollbar","scrollbarWidth","readOnly","backgroundSize","backgroundImage","backgroundRepeat","backgroundPosition","editorInFocus","error","noBorder","noPadding","EditorAndToolbar","props","editor","classes","value","plugins","onChange","getFocusedValue","onDone","focusedNode","autoWidth","disableScrollbar","disableUnderline","pluginProps","toolbarOpts","toolbarRef","isFocused","holderNames","classNames","clonedChildren","propTypes","PropTypes","oneOfType","arrayOf","node","isRequired","shape","type","string","array","data","object","bool","func","alwaysVisible","oneOf","withStyles"],"sources":["../../../src/plugins/toolbar/editor-and-toolbar.jsx"],"sourcesContent":["import React from 'react';\n\nimport Toolbar from './toolbar';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { primary } from '../../theme';\nimport { withStyles } from '@material-ui/core/styles';\nimport PropTypes from 'prop-types';\nimport { color } from '@pie-lib/render-ui';\n\nconst log = debug('@pie-lib:editable-html:plugins:toolbar:editor-and-toolbar');\n\nconst style = {\n root: {\n position: 'relative',\n padding: '0px',\n border: '1px solid #ccc',\n borderRadius: '4px',\n cursor: 'text',\n '& [data-slate-editor=\"true\"]': {\n wordBreak: 'break-word',\n overflow: 'visible',\n maxHeight: '500px',\n // needed in order to be able to put the focus before a void element when it is the first one in the editor\n padding: '5px'\n },\n '& [data-slate-void=\"true\"]': {\n // needed in order to be able to put the focus before a void element when it is the first one in the editor\n padding: '1px'\n }\n },\n children: {\n padding: '10px 16px'\n },\n editorHolder: {\n position: 'relative',\n padding: '0px',\n overflowY: 'scroll',\n color: color.text(),\n backgroundColor: color.background(),\n '&::before': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transition: 'background-color 200ms cubic-bezier(0.4, 0, 0.2, 1) 0ms',\n pointerEvents: 'none',\n backgroundColor: 'rgba(0, 0, 0, 0.42)'\n },\n '&::after': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transform: 'scaleX(0)',\n transition:\n 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 200ms linear',\n backgroundColor: 'rgba(0, 0, 0, 0.42)'\n },\n '&:focus': {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: primary,\n height: '2px'\n }\n },\n '&:hover': {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: 'black',\n height: '2px'\n }\n }\n },\n disabledUnderline: {\n '&::before': {\n display: 'none'\n },\n '&::after': {\n display: 'none'\n }\n },\n disabledScrollbar: {\n '&::-webkit-scrollbar': {\n display: 'none'\n },\n scrollbarWidth: 'none',\n '-ms-overflow-style': 'none'\n },\n readOnly: {\n '&::before': {\n background: 'transparent',\n backgroundSize: '5px 1px',\n backgroundImage: 'linear-gradient(to right, rgba(0, 0, 0, 0.42) 33%, transparent 0%)',\n backgroundRepeat: 'repeat-x',\n backgroundPosition: 'left top'\n },\n '&::after': {\n left: '0',\n right: '0',\n bottom: '0',\n height: '1px',\n content: '\"\"',\n position: 'absolute',\n transform: 'scaleX(0)',\n transition: 'transform 200ms cubic-bezier(0.0, 0.0, 0.2, 1) 0ms, background-color 0ms linear',\n backgroundColor: 'rgba(0, 0, 0, 0)'\n },\n '&:hover': {\n '&::after': {\n transform: 'scaleX(0)',\n backgroundColor: 'black',\n height: '2px'\n }\n }\n },\n editorInFocus: {\n '&::after': {\n transform: 'scaleX(1)',\n backgroundColor: primary,\n height: '2px'\n },\n '&:hover': {\n '&::after': {\n backgroundColor: primary\n }\n }\n },\n error: {\n border: '2px solid red'\n },\n noBorder: {\n border: 'none'\n },\n noPadding: {\n padding: 0\n }\n};\n\nexport const EditorAndToolbar = props => {\n const {\n editor,\n classes,\n children,\n value,\n plugins,\n onChange,\n getFocusedValue,\n onDone,\n focusedNode,\n autoWidth,\n readOnly,\n disableScrollbar,\n disableUnderline,\n pluginProps,\n toolbarOpts,\n toolbarRef,\n isFocused\n } = props;\n\n const holderNames = classNames(classes.editorHolder, {\n [classes.editorInFocus]: isFocused,\n [classes.readOnly]: readOnly,\n [classes.disabledUnderline]: disableUnderline,\n [classes.disabledScrollbar]: disableScrollbar\n });\n let clonedChildren = children;\n\n log(\n '[render] inFocus: ',\n isFocused,\n 'value.isFocused:',\n value.isFocused,\n 'focused node: ',\n focusedNode\n );\n\n return (\n <div\n className={classNames(\n {\n [classes.noBorder]: toolbarOpts && toolbarOpts.noBorder,\n [classes.error]: toolbarOpts && toolbarOpts.error\n },\n classes.root\n )}\n >\n <div className={holderNames}>\n <div\n className={classNames(\n {\n [classes.noPadding]: toolbarOpts && toolbarOpts.noBorder\n },\n classes.children\n )}\n >\n {clonedChildren}\n </div>\n </div>\n <Toolbar\n editor={editor}\n autoWidth={autoWidth}\n plugins={plugins}\n focusedNode={focusedNode}\n value={value}\n isFocused={isFocused}\n onChange={onChange}\n getFocusedValue={getFocusedValue}\n onDone={onDone}\n toolbarRef={toolbarRef}\n pluginProps={pluginProps}\n toolbarOpts={toolbarOpts}\n />\n </div>\n );\n};\n\nEditorAndToolbar.propTypes = {\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n value: PropTypes.arrayOf(\n PropTypes.shape({\n type: PropTypes.string,\n children: PropTypes.array,\n data: PropTypes.object\n })\n ),\n editor: PropTypes.object.isRequired,\n isFocused: PropTypes.bool,\n plugins: PropTypes.array.isRequired,\n onChange: PropTypes.func.isRequired,\n getFocusedValue: PropTypes.func.isRequired,\n onDone: PropTypes.func.isRequired,\n toolbarRef: PropTypes.func,\n focusedNode: PropTypes.shape({\n type: PropTypes.string,\n children: PropTypes.array,\n data: PropTypes.object\n }),\n readOnly: PropTypes.bool,\n disableScrollbar: PropTypes.bool,\n disableUnderline: PropTypes.bool,\n autoWidth: PropTypes.bool,\n classes: PropTypes.object.isRequired,\n pluginProps: PropTypes.object,\n toolbarOpts: PropTypes.shape({\n alwaysVisible: PropTypes.bool,\n error: PropTypes.string,\n noBorder: PropTypes.bool,\n position: PropTypes.oneOf(['bottom', 'top'])\n })\n};\n\nexport default withStyles(style)(EditorAndToolbar);\n"],"mappings":"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"}
@@ -25,10 +25,9 @@ function ToolbarPlugin(opts) {
25
25
  mainEditorRef: opts.mainEditorRef,
26
26
  disableScrollbar: opts.disableScrollbar,
27
27
  disableUnderline: opts.disableUnderline,
28
- autoWidth: opts.autoWidth,
29
28
  onDone: opts.onDone
30
29
  }));
31
30
  }
32
31
  };
33
32
  }
34
- //# sourceMappingURL=index.js.map
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJUb29sYmFyUGx1Z2luIiwib3B0cyIsInJlbmRlckVkaXRvciIsInByb3BzIiwibWFpbkVkaXRvclJlZiIsImRpc2FibGVTY3JvbGxiYXIiLCJkaXNhYmxlVW5kZXJsaW5lIiwib25Eb25lIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BsdWdpbnMvdG9vbGJhci9pbmRleC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IEVkaXRvckFuZFRvb2xiYXIgZnJvbSAnLi9lZGl0b3ItYW5kLXRvb2xiYXInO1xuXG4vKipcbiAqIEFkZHMgYSB0b29sYmFyIHdoaWNoIGlzIHNob3duIHdoZW4gdGhlIGVkaXRvciBpcyBmb2N1c2VkLlxuICogQHBhcmFtIHsqfSBvcHRzXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIFRvb2xiYXJQbHVnaW4ob3B0cykge1xuICByZXR1cm4ge1xuICAgIC8qIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSAqL1xuICAgIHJlbmRlckVkaXRvcjogcHJvcHMgPT4gKFxuICAgICAgPEVkaXRvckFuZFRvb2xiYXJcbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgICBtYWluRWRpdG9yUmVmPXtvcHRzLm1haW5FZGl0b3JSZWZ9XG4gICAgICAgIGRpc2FibGVTY3JvbGxiYXI9e29wdHMuZGlzYWJsZVNjcm9sbGJhcn1cbiAgICAgICAgZGlzYWJsZVVuZGVybGluZT17b3B0cy5kaXNhYmxlVW5kZXJsaW5lfVxuICAgICAgICBvbkRvbmU9e29wdHMub25Eb25lfVxuICAgICAgLz5cbiAgICApXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDZSxTQUFTQSxhQUFULENBQXVCQyxJQUF2QixFQUE2QjtFQUMxQyxPQUFPO0lBQ0w7SUFDQUMsWUFBWSxFQUFFLHNCQUFBQyxLQUFLO01BQUEsb0JBQ2pCLGdDQUFDLDRCQUFELGdDQUNNQSxLQUROO1FBRUUsYUFBYSxFQUFFRixJQUFJLENBQUNHLGFBRnRCO1FBR0UsZ0JBQWdCLEVBQUVILElBQUksQ0FBQ0ksZ0JBSHpCO1FBSUUsZ0JBQWdCLEVBQUVKLElBQUksQ0FBQ0ssZ0JBSnpCO1FBS0UsTUFBTSxFQUFFTCxJQUFJLENBQUNNO01BTGYsR0FEaUI7SUFBQTtFQUZkLENBQVA7QUFZRCJ9
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/toolbar/index.jsx"],"names":["ToolbarPlugin","opts","renderEditor","props","mainEditorRef","disableScrollbar","disableUnderline","autoWidth","onDone"],"mappings":";;;;;;;;;;;AAAA;;AAEA;;AAEA;AACA;AACA;AACA;AACe,SAASA,aAAT,CAAuBC,IAAvB,EAA6B;AAC1C,SAAO;AACL;AACAC,IAAAA,YAAY,EAAE,sBAACC,KAAD;AAAA,0BACZ,gCAAC,4BAAD,gCACMA,KADN;AAEE,QAAA,aAAa,EAAEF,IAAI,CAACG,aAFtB;AAGE,QAAA,gBAAgB,EAAEH,IAAI,CAACI,gBAHzB;AAIE,QAAA,gBAAgB,EAAEJ,IAAI,CAACK,gBAJzB;AAKE,QAAA,SAAS,EAAEL,IAAI,CAACM,SALlB;AAME,QAAA,MAAM,EAAEN,IAAI,CAACO;AANf,SADY;AAAA;AAFT,GAAP;AAaD","sourcesContent":["import React from 'react';\n\nimport EditorAndToolbar from './editor-and-toolbar';\n\n/**\n * Adds a toolbar which is shown when the editor is focused.\n * @param {*} opts\n */\nexport default function ToolbarPlugin(opts) {\n return {\n /* eslint-disable-next-line */\n renderEditor: (props) => (\n <EditorAndToolbar\n {...props}\n mainEditorRef={opts.mainEditorRef}\n disableScrollbar={opts.disableScrollbar}\n disableUnderline={opts.disableUnderline}\n autoWidth={opts.autoWidth}\n onDone={opts.onDone}\n />\n ),\n };\n}\n"],"file":"index.js"}
1
+ {"version":3,"file":"index.js","names":["ToolbarPlugin","opts","renderEditor","props","mainEditorRef","disableScrollbar","disableUnderline","onDone"],"sources":["../../../src/plugins/toolbar/index.jsx"],"sourcesContent":["import React from 'react';\n\nimport EditorAndToolbar from './editor-and-toolbar';\n\n/**\n * Adds a toolbar which is shown when the editor is focused.\n * @param {*} opts\n */\nexport default function ToolbarPlugin(opts) {\n return {\n /* eslint-disable-next-line */\n renderEditor: props => (\n <EditorAndToolbar\n {...props}\n mainEditorRef={opts.mainEditorRef}\n disableScrollbar={opts.disableScrollbar}\n disableUnderline={opts.disableUnderline}\n onDone={opts.onDone}\n />\n )\n };\n}\n"],"mappings":";;;;;;;;;;;AAAA;;AAEA;;AAEA;AACA;AACA;AACA;AACe,SAASA,aAAT,CAAuBC,IAAvB,EAA6B;EAC1C,OAAO;IACL;IACAC,YAAY,EAAE,sBAAAC,KAAK;MAAA,oBACjB,gCAAC,4BAAD,gCACMA,KADN;QAEE,aAAa,EAAEF,IAAI,CAACG,aAFtB;QAGE,gBAAgB,EAAEH,IAAI,CAACI,gBAHzB;QAIE,gBAAgB,EAAEJ,IAAI,CAACK,gBAJzB;QAKE,MAAM,EAAEL,IAAI,CAACM;MALf,GADiB;IAAA;EAFd,CAAP;AAYD"}
@@ -158,4 +158,4 @@ exports.RawMarkButton = RawMarkButton;
158
158
  });
159
159
  var MarkButton = (0, _reactJss["default"])(styles())(RawMarkButton);
160
160
  exports.MarkButton = MarkButton;
161
- //# sourceMappingURL=toolbar-buttons.js.map
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZXMiLCJidXR0b24iLCJjb2xvciIsImRpc3BsYXkiLCJwYWRkaW5nIiwiYWN0aXZlIiwiZGlzYWJsZWQiLCJvcGFjaXR5IiwiY3Vyc29yIiwibG9nIiwiZGVidWciLCJSYXdCdXR0b24iLCJwcm9wcyIsImUiLCJwcmV2ZW50RGVmYXVsdCIsIm9uQ2xpY2siLCJjbGFzc2VzIiwiY2hpbGRyZW4iLCJleHRyYVN0eWxlcyIsIm5hbWVzIiwiY2xhc3NOYW1lcyIsIlJlYWN0IiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwiZnVuYyIsImlzUmVxdWlyZWQiLCJvYmplY3QiLCJvbmVPZlR5cGUiLCJhcnJheU9mIiwibm9kZSIsImJvb2wiLCJCdXR0b24iLCJpbmplY3RTaGVldCIsIlJhd01hcmtCdXR0b24iLCJvblRvZ2dsZSIsIm1hcmsiLCJzdHJpbmciLCJNYXJrQnV0dG9uIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BsdWdpbnMvdG9vbGJhci90b29sYmFyLWJ1dHRvbnMuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgZGVidWcgZnJvbSAnZGVidWcnO1xuaW1wb3J0IGluamVjdFNoZWV0IGZyb20gJ3JlYWN0LWpzcyc7XG5pbXBvcnQgY2xhc3NOYW1lcyBmcm9tICdjbGFzc25hbWVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmNvbnN0IHN0eWxlcyA9ICgpID0+ICh7XG4gIGJ1dHRvbjoge1xuICAgIGNvbG9yOiAnZ3JleScsXG4gICAgZGlzcGxheTogJ2lubGluZS1mbGV4JyxcbiAgICBwYWRkaW5nOiAnMnB4JyxcbiAgICAnJiA6aG92ZXInOiB7XG4gICAgICBjb2xvcjogJ2JsYWNrJ1xuICAgIH1cbiAgfSxcbiAgYWN0aXZlOiB7XG4gICAgY29sb3I6ICdibGFjaydcbiAgfSxcbiAgZGlzYWJsZWQ6IHtcbiAgICBvcGFjaXR5OiAwLjcsXG4gICAgY3Vyc29yOiAnbm90LWFsbG93ZWQnLFxuICAgICcmIDpob3Zlcic6IHtcbiAgICAgIGNvbG9yOiAnZ3JleSdcbiAgICB9XG4gIH1cbn0pO1xuXG5jb25zdCBsb2cgPSBkZWJ1ZygncGllLWVsZW1lbnRzOmVkaXRhYmxlLWh0bWw6cmF3LWJ1dHRvbicpO1xuXG5leHBvcnQgY2xhc3MgUmF3QnV0dG9uIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBjaGlsZHJlbjogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLm5vZGUpLCBQcm9wVHlwZXMubm9kZV0pLmlzUmVxdWlyZWQsXG4gICAgYWN0aXZlOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBkaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gICAgZXh0cmFTdHlsZXM6IFByb3BUeXBlcy5vYmplY3RcbiAgfTtcblxuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIG9uQ2xpY2sgPSBlID0+IHtcbiAgICBsb2coJ1tvbkNsaWNrXScpO1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBjb25zdCB7IG9uQ2xpY2sgfSA9IHRoaXMucHJvcHM7XG4gICAgb25DbGljayhlKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBhY3RpdmUsIGNsYXNzZXMsIGNoaWxkcmVuLCBkaXNhYmxlZCwgZXh0cmFTdHlsZXMgfSA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgbmFtZXMgPSBjbGFzc05hbWVzKGNsYXNzZXMuYnV0dG9uLCB7XG4gICAgICBbY2xhc3Nlcy5hY3RpdmVdOiBhY3RpdmUsXG4gICAgICBbY2xhc3Nlcy5kaXNhYmxlZF06IGRpc2FibGVkXG4gICAgfSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBzdHlsZT17ZXh0cmFTdHlsZXN9IGNsYXNzTmFtZT17bmFtZXN9IG9uTW91c2VEb3duPXt0aGlzLm9uQ2xpY2t9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBjb25zdCBCdXR0b24gPSBpbmplY3RTaGVldChzdHlsZXMoKSkoUmF3QnV0dG9uKTtcblxuZXhwb3J0IGNsYXNzIFJhd01hcmtCdXR0b24gZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG9uVG9nZ2xlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIG1hcms6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgY2hpbGRyZW46IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5hcnJheU9mKFByb3BUeXBlcy5ub2RlKSwgUHJvcFR5cGVzLm5vZGVdKS5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBhY3RpdmU6IFByb3BUeXBlcy5ib29sXG4gIH07XG5cbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gIH1cblxuICBvblRvZ2dsZSA9IGUgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICB0aGlzLnByb3BzLm9uVG9nZ2xlKHRoaXMucHJvcHMubWFyayk7XG4gIH07XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgY2xhc3NlcywgY2hpbGRyZW4sIGFjdGl2ZSB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBuYW1lcyA9IGNsYXNzTmFtZXMoY2xhc3Nlcy5idXR0b24sIGFjdGl2ZSAmJiBjbGFzc2VzLmFjdGl2ZSk7XG4gICAgcmV0dXJuIChcbiAgICAgIDxzcGFuIGNsYXNzTmFtZT17bmFtZXN9IG9uTW91c2VEb3duPXt0aGlzLm9uVG9nZ2xlfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9zcGFuPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IE1hcmtCdXR0b24gPSBpbmplY3RTaGVldChzdHlsZXMoKSkoUmF3TWFya0J1dHRvbik7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVBLElBQU1BLE1BQU0sR0FBRyxTQUFUQSxNQUFTO0VBQUEsT0FBTztJQUNwQkMsTUFBTSxFQUFFO01BQ05DLEtBQUssRUFBRSxNQUREO01BRU5DLE9BQU8sRUFBRSxhQUZIO01BR05DLE9BQU8sRUFBRSxLQUhIO01BSU4sWUFBWTtRQUNWRixLQUFLLEVBQUU7TUFERztJQUpOLENBRFk7SUFTcEJHLE1BQU0sRUFBRTtNQUNOSCxLQUFLLEVBQUU7SUFERCxDQVRZO0lBWXBCSSxRQUFRLEVBQUU7TUFDUkMsT0FBTyxFQUFFLEdBREQ7TUFFUkMsTUFBTSxFQUFFLGFBRkE7TUFHUixZQUFZO1FBQ1ZOLEtBQUssRUFBRTtNQURHO0lBSEo7RUFaVSxDQUFQO0FBQUEsQ0FBZjs7QUFxQkEsSUFBTU8sR0FBRyxHQUFHLElBQUFDLGlCQUFBLEVBQU0sdUNBQU4sQ0FBWjs7SUFFYUMsUzs7Ozs7RUFVWCxtQkFBWUMsS0FBWixFQUFtQjtJQUFBOztJQUFBO0lBQ2pCLDBCQUFNQSxLQUFOO0lBRGlCLDRGQUlULFVBQUFDLENBQUMsRUFBSTtNQUNiSixHQUFHLENBQUMsV0FBRCxDQUFIO01BQ0FJLENBQUMsQ0FBQ0MsY0FBRjtNQUNBLElBQVFDLE9BQVIsR0FBb0IsTUFBS0gsS0FBekIsQ0FBUUcsT0FBUjtNQUNBQSxPQUFPLENBQUNGLENBQUQsQ0FBUDtJQUNELENBVGtCO0lBQUE7RUFFbEI7Ozs7V0FTRCxrQkFBUztNQUFBOztNQUNQLGtCQUE2RCxLQUFLRCxLQUFsRTtNQUFBLElBQVFQLE1BQVIsZUFBUUEsTUFBUjtNQUFBLElBQWdCVyxPQUFoQixlQUFnQkEsT0FBaEI7TUFB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
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/toolbar/toolbar-buttons.jsx"],"names":["styles","button","color","display","padding","active","disabled","opacity","cursor","log","RawButton","props","e","preventDefault","onClick","classes","children","extraStyles","names","React","Component","PropTypes","func","isRequired","object","oneOfType","arrayOf","node","bool","Button","RawMarkButton","onToggle","mark","string","MarkButton"],"mappings":"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","sourcesContent":["import React from 'react';\nimport debug from 'debug';\nimport injectSheet from 'react-jss';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\n\nconst styles = () => ({\n button: {\n color: 'grey',\n display: 'inline-flex',\n padding: '2px',\n '& :hover': {\n color: 'black',\n },\n },\n active: {\n color: 'black',\n },\n disabled: {\n opacity: 0.7,\n cursor: 'not-allowed',\n '& :hover': {\n color: 'grey',\n },\n },\n});\n\nconst log = debug('pie-elements:editable-html:raw-button');\n\nexport class RawButton extends React.Component {\n static propTypes = {\n onClick: PropTypes.func.isRequired,\n classes: PropTypes.object.isRequired,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n active: PropTypes.bool,\n disabled: PropTypes.bool,\n extraStyles: PropTypes.object,\n };\n\n constructor(props) {\n super(props);\n }\n\n onClick = (e) => {\n log('[onClick]');\n e.preventDefault();\n const { onClick } = this.props;\n onClick(e);\n };\n\n render() {\n const { active, classes, children, disabled, extraStyles } = this.props;\n const names = classNames(classes.button, {\n [classes.active]: active,\n [classes.disabled]: disabled,\n });\n\n return (\n <div style={extraStyles} className={names} onMouseDown={this.onClick}>\n {children}\n </div>\n );\n }\n}\n\nexport const Button = injectSheet(styles())(RawButton);\n\nexport class RawMarkButton extends React.Component {\n static propTypes = {\n onToggle: PropTypes.func.isRequired,\n mark: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n classes: PropTypes.object.isRequired,\n active: PropTypes.bool,\n };\n\n constructor(props) {\n super(props);\n }\n\n onToggle = (e) => {\n e.preventDefault();\n this.props.onToggle(this.props.mark);\n };\n\n render() {\n const { classes, children, active } = this.props;\n const names = classNames(classes.button, active && classes.active);\n return (\n <span className={names} onMouseDown={this.onToggle}>\n {children}\n </span>\n );\n }\n}\n\nexport const MarkButton = injectSheet(styles())(RawMarkButton);\n"],"file":"toolbar-buttons.js"}
1
+ {"version":3,"file":"toolbar-buttons.js","names":["styles","button","color","display","padding","active","disabled","opacity","cursor","log","debug","RawButton","props","e","preventDefault","onClick","classes","children","extraStyles","names","classNames","React","Component","PropTypes","func","isRequired","object","oneOfType","arrayOf","node","bool","Button","injectSheet","RawMarkButton","onToggle","mark","string","MarkButton"],"sources":["../../../src/plugins/toolbar/toolbar-buttons.jsx"],"sourcesContent":["import React from 'react';\nimport debug from 'debug';\nimport injectSheet from 'react-jss';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\n\nconst styles = () => ({\n button: {\n color: 'grey',\n display: 'inline-flex',\n padding: '2px',\n '& :hover': {\n color: 'black'\n }\n },\n active: {\n color: 'black'\n },\n disabled: {\n opacity: 0.7,\n cursor: 'not-allowed',\n '& :hover': {\n color: 'grey'\n }\n }\n});\n\nconst log = debug('pie-elements:editable-html:raw-button');\n\nexport class RawButton extends React.Component {\n static propTypes = {\n onClick: PropTypes.func.isRequired,\n classes: PropTypes.object.isRequired,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n active: PropTypes.bool,\n disabled: PropTypes.bool,\n extraStyles: PropTypes.object\n };\n\n constructor(props) {\n super(props);\n }\n\n onClick = e => {\n log('[onClick]');\n e.preventDefault();\n const { onClick } = this.props;\n onClick(e);\n };\n\n render() {\n const { active, classes, children, disabled, extraStyles } = this.props;\n const names = classNames(classes.button, {\n [classes.active]: active,\n [classes.disabled]: disabled\n });\n\n return (\n <div style={extraStyles} className={names} onMouseDown={this.onClick}>\n {children}\n </div>\n );\n }\n}\n\nexport const Button = injectSheet(styles())(RawButton);\n\nexport class RawMarkButton extends React.Component {\n static propTypes = {\n onToggle: PropTypes.func.isRequired,\n mark: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,\n classes: PropTypes.object.isRequired,\n active: PropTypes.bool\n };\n\n constructor(props) {\n super(props);\n }\n\n onToggle = e => {\n e.preventDefault();\n this.props.onToggle(this.props.mark);\n };\n\n render() {\n const { classes, children, active } = this.props;\n const names = classNames(classes.button, active && classes.active);\n return (\n <span className={names} onMouseDown={this.onToggle}>\n {children}\n </span>\n );\n }\n}\n\nexport const MarkButton = injectSheet(styles())(RawMarkButton);\n"],"mappings":"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"}