@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
|
@@ -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
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
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
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
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
|
-
|
|
129
|
-
|
|
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
|
-
|
|
204
|
+
EditorAndToolbar.propTypes = {
|
|
133
205
|
children: _propTypes["default"].oneOfType([_propTypes["default"].arrayOf(_propTypes["default"].node), _propTypes["default"].node]).isRequired,
|
|
134
|
-
value:
|
|
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:
|
|
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":";;;;;;;;;;;AAAA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,IAAMA,GAAG,GAAG,IAAAC,iBAAA,EAAM,2DAAN,CAAZ;AAEA,IAAMC,KAAK,GAAG;EACZC,IAAI,EAAE;IACJC,QAAQ,EAAE,UADN;IAEJC,OAAO,EAAE,KAFL;IAGJC,MAAM,EAAE,gBAHJ;IAIJC,YAAY,EAAE,KAJV;IAKJC,MAAM,EAAE,MALJ;IAMJ,gCAAgC;MAC9BC,SAAS,EAAE,YADmB;MAE9BC,QAAQ,EAAE,SAFoB;MAG9BC,SAAS,EAAE,OAHmB;MAI9B;MACAN,OAAO,EAAE;IALqB,CAN5B;IAaJ,8BAA8B;MAC5B;MACAA,OAAO,EAAE;IAFmB;EAb1B,CADM;EAmBZO,QAAQ,EAAE;IACRP,OAAO,EAAE;EADD,CAnBE;EAsBZQ,YAAY,EAAE;IACZT,QAAQ,EAAE,UADE;IAEZC,OAAO,EAAE,KAFG;IAGZS,SAAS,EAAE,QAHC;IAIZC,KAAK,EAAEA,eAAA,CAAMC,IAAN,EAJK;IAKZC,eAAe,EAAEF,eAAA,CAAMG,UAAN,EALL;IAMZ,aAAa;MACXC,IAAI,EAAE,GADK;MAEXC,KAAK,EAAE,GAFI;MAGXC,MAAM,EAAE,GAHG;MAIXC,MAAM,EAAE,KAJG;MAKXC,OAAO,EAAE,IALE;MAMXnB,QAAQ,EAAE,UANC;MAOXoB,UAAU,EAAE,yDAPD;MAQXC,aAAa,EAAE;IARJ,CAND;IAgBZ,YAAY;MACVN,IAAI,EAAE,GADI;MAEVC,KAAK,EAAE,GAFG;MAGVC,MAAM,EAAE,GAHE;MAIVC,MAAM,EAAE,KAJE;MAKVC,OAAO,EAAE,IALC;MAMVnB,QAAQ,EAAE,UANA;MAOVsB,SAAS,EAAE,WAPD;MAQVF,UAAU,EACR,mFATQ;MAUVP,eAAe,EAAE;IAVP,CAhBA;IA4BZ,WAAW;MACT,YAAY;QACVS,SAAS,EAAE,WADD;QAEVT,eAAe,EAAEU,cAFP;QAGVL,MAAM,EAAE;MAHE;IADH,CA5BC;IAmCZ,WAAW;MACT,YAAY;QACVI,SAAS,EAAE,WADD;QAEVT,eAAe,EAAE,OAFP;QAGVK,MAAM,EAAE;MAHE;IADH;EAnCC,CAtBF;EAiEZM,iBAAiB,EAAE;IACjB,aAAa;MACXC,OAAO,EAAE;IADE,CADI;IAIjB,YAAY;MACVA,OAAO,EAAE;IADC;EAJK,CAjEP;EAyEZC,iBAAiB,EAAE;IACjB,wBAAwB;MACtBD,OAAO,EAAE;IADa,CADP;IAIjBE,cAAc,EAAE,MAJC;IAKjB,sBAAsB;EALL,CAzEP;EAgFZC,QAAQ,EAAE;IACR,aAAa;MACXd,UAAU,EAAE,aADD;MAEXe,cAAc,EAAE,SAFL;MAGXC,eAAe,EAAE,oEAHN;MAIXC,gBAAgB,EAAE,UAJP;MAKXC,kBAAkB,EAAE;IALT,CADL;IAQR,YAAY;MACVjB,IAAI,EAAE,GADI;MAEVC,KAAK,EAAE,GAFG;MAGVC,MAAM,EAAE,GAHE;MAIVC,MAAM,EAAE,KAJE;MAKVC,OAAO,EAAE,IALC;MAMVnB,QAAQ,EAAE,UANA;MAOVsB,SAAS,EAAE,WAPD;MAQVF,UAAU,EAAE,iFARF;MASVP,eAAe,EAAE;IATP,CARJ;IAmBR,WAAW;MACT,YAAY;QACVS,SAAS,EAAE,WADD;QAEVT,eAAe,EAAE,OAFP;QAGVK,MAAM,EAAE;MAHE;IADH;EAnBH,CAhFE;EA2GZe,aAAa,EAAE;IACb,YAAY;MACVX,SAAS,EAAE,WADD;MAEVT,eAAe,EAAEU,cAFP;MAGVL,MAAM,EAAE;IAHE,CADC;IAMb,WAAW;MACT,YAAY;QACVL,eAAe,EAAEU;MADP;IADH;EANE,CA3GH;EAuHZW,KAAK,EAAE;IACLhC,MAAM,EAAE;EADH,CAvHK;EA0HZiC,QAAQ,EAAE;IACRjC,MAAM,EAAE;EADA,CA1HE;EA6HZkC,SAAS,EAAE;IACTnC,OAAO,EAAE;EADA;AA7HC,CAAd;;AAkIO,IAAMoC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAAAC,KAAK,EAAI;EAAA;;EACvC,IACEC,MADF,GAkBID,KAlBJ,CACEC,MADF;EAAA,IAEEC,OAFF,GAkBIF,KAlBJ,CAEEE,OAFF;EAAA,IAGEhC,QAHF,GAkBI8B,KAlBJ,CAGE9B,QAHF;EAAA,IAIEiC,KAJF,GAkBIH,KAlBJ,CAIEG,KAJF;EAAA,IAKEC,OALF,GAkBIJ,KAlBJ,CAKEI,OALF;EAAA,IAMEC,QANF,GAkBIL,KAlBJ,CAMEK,QANF;EAAA,IAOEC,eAPF,GAkBIN,KAlBJ,CAOEM,eAPF;EAAA,IAQEC,MARF,GAkBIP,KAlBJ,CAQEO,MARF;EAAA,IASEC,WATF,GAkBIR,KAlBJ,CASEQ,WATF;EAAA,IAUEC,SAVF,GAkBIT,KAlBJ,CAUES,SAVF;EAAA,IAWEnB,QAXF,GAkBIU,KAlBJ,CAWEV,QAXF;EAAA,IAYEoB,gBAZF,GAkBIV,KAlBJ,CAYEU,gBAZF;EAAA,IAaEC,gBAbF,GAkBIX,KAlBJ,CAaEW,gBAbF;EAAA,IAcEC,WAdF,GAkBIZ,KAlBJ,CAcEY,WAdF;EAAA,IAeEC,WAfF,GAkBIb,KAlBJ,CAeEa,WAfF;EAAA,IAgBEC,UAhBF,GAkBId,KAlBJ,CAgBEc,UAhBF;EAAA,IAiBEC,SAjBF,GAkBIf,KAlBJ,CAiBEe,SAjBF;EAoBA,IAAMC,WAAW,GAAG,IAAAC,sBAAA,EAAWf,OAAO,CAAC/B,YAAnB,mEACjB+B,OAAO,CAACP,aADS,EACOoB,SADP,iDAEjBb,OAAO,CAACZ,QAFS,EAEEA,QAFF,iDAGjBY,OAAO,CAAChB,iBAHS,EAGWyB,gBAHX,iDAIjBT,OAAO,CAACd,iBAJS,EAIWsB,gBAJX,gBAApB;EAMA,IAAIQ,cAAc,GAAGhD,QAArB;EAEAZ,GAAG,CACD,oBADC,EAEDyD,SAFC,EAGD,kBAHC,EAIDZ,KAAK,CAACY,SAJL,EAKD,gBALC,EAMDP,WANC,CAAH;EASA,oBACE;IACE,SAAS,EAAE,IAAAS,sBAAA,qEAENf,OAAO,CAACL,QAFF,EAEagB,WAAW,IAAIA,WAAW,CAAChB,QAFxC,kDAGNK,OAAO,CAACN,KAHF,EAGUiB,WAAW,IAAIA,WAAW,CAACjB,KAHrC,kBAKTM,OAAO,CAACzC,IALC;EADb,gBASE;IAAK,SAAS,EAAEuD;EAAhB,gBACE;IACE,SAAS,EAAE,IAAAC,sBAAA,uCAENf,OAAO,CAACJ,SAFF,EAEce,WAAW,IAAIA,WAAW,CAAChB,QAFzC,GAITK,OAAO,CAAChC,QAJC;EADb,GAQGgD,cARH,CADF,CATF,eAqBE,gCAAC,mBAAD;IACE,MAAM,EAAEjB,MADV;IAEE,SAAS,EAAEQ,SAFb;IAGE,OAAO,EAAEL,OAHX;IAIE,WAAW,EAAEI,WAJf;IAKE,KAAK,EAAEL,KALT;IAME,SAAS,EAAEY,SANb;IAOE,QAAQ,EAAEV,QAPZ;IAQE,eAAe,EAAEC,eARnB;IASE,MAAM,EAAEC,MATV;IAUE,UAAU,EAAEO,UAVd;IAWE,WAAW,EAAEF,WAXf;IAYE,WAAW,EAAEC;EAZf,EArBF,CADF;AAsCD,CA5EM;;;AA8EPd,gBAAgB,CAACoB,SAAjB,GAA6B;EAC3BjD,QAAQ,EAAEkD,qBAAA,CAAUC,SAAV,CAAoB,CAACD,qBAAA,CAAUE,OAAV,CAAkBF,qBAAA,CAAUG,IAA5B,CAAD,EAAoCH,qBAAA,CAAUG,IAA9C,CAApB,EAAyEC,UADxD;EAE3BrB,KAAK,EAAEiB,qBAAA,CAAUE,OAAV,CACLF,qBAAA,CAAUK,KAAV,CAAgB;IACdC,IAAI,EAAEN,qBAAA,CAAUO,MADF;IAEdzD,QAAQ,EAAEkD,qBAAA,CAAUQ,KAFN;IAGdC,IAAI,EAAET,qBAAA,CAAUU;EAHF,CAAhB,CADK,CAFoB;EAS3B7B,MAAM,EAAEmB,qBAAA,CAAUU,MAAV,CAAiBN,UATE;EAU3BT,SAAS,EAAEK,qBAAA,CAAUW,IAVM;EAW3B3B,OAAO,EAAEgB,qBAAA,CAAUQ,KAAV,CAAgBJ,UAXE;EAY3BnB,QAAQ,EAAEe,qBAAA,CAAUY,IAAV,CAAeR,UAZE;EAa3BlB,eAAe,EAAEc,qBAAA,CAAUY,IAAV,CAAeR,UAbL;EAc3BjB,MAAM,EAAEa,qBAAA,CAAUY,IAAV,CAAeR,UAdI;EAe3BV,UAAU,EAAEM,qBAAA,CAAUY,IAfK;EAgB3BxB,WAAW,EAAEY,qBAAA,CAAUK,KAAV,CAAgB;IAC3BC,IAAI,EAAEN,qBAAA,CAAUO,MADW;IAE3BzD,QAAQ,EAAEkD,qBAAA,CAAUQ,KAFO;IAG3BC,IAAI,EAAET,qBAAA,CAAUU;EAHW,CAAhB,CAhBc;EAqB3BxC,QAAQ,EAAE8B,qBAAA,CAAUW,IArBO;EAsB3BrB,gBAAgB,EAAEU,qBAAA,CAAUW,IAtBD;EAuB3BpB,gBAAgB,EAAES,qBAAA,CAAUW,IAvBD;EAwB3BtB,SAAS,EAAEW,qBAAA,CAAUW,IAxBM;EAyB3B7B,OAAO,EAAEkB,qBAAA,CAAUU,MAAV,CAAiBN,UAzBC;EA0B3BZ,WAAW,EAAEQ,qBAAA,CAAUU,MA1BI;EA2B3BjB,WAAW,EAAEO,qBAAA,CAAUK,KAAV,CAAgB;IAC3BQ,aAAa,EAAEb,qBAAA,CAAUW,IADE;IAE3BnC,KAAK,EAAEwB,qBAAA,CAAUO,MAFU;IAG3B9B,QAAQ,EAAEuB,qBAAA,CAAUW,IAHO;IAI3BrE,QAAQ,EAAE0D,qBAAA,CAAUc,KAAV,CAAgB,CAAC,QAAD,EAAW,KAAX,CAAhB;EAJiB,CAAhB;AA3Bc,CAA7B;;eAmCe,IAAAC,kBAAA,EAAW3E,KAAX,EAAkBuC,gBAAlB,C"}
|
|
@@ -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":"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","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=
|
|
33
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJUb29sYmFyUGx1Z2luIiwib3B0cyIsInJlbmRlckVkaXRvciIsInByb3BzIiwibWFpbkVkaXRvclJlZiIsImRpc2FibGVTY3JvbGxiYXIiLCJkaXNhYmxlVW5kZXJsaW5lIiwib25Eb25lIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BsdWdpbnMvdG9vbGJhci9pbmRleC5qc3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IEVkaXRvckFuZFRvb2xiYXIgZnJvbSAnLi9lZGl0b3ItYW5kLXRvb2xiYXInO1xuXG4vKipcbiAqIEFkZHMgYSB0b29sYmFyIHdoaWNoIGlzIHNob3duIHdoZW4gdGhlIGVkaXRvciBpcyBmb2N1c2VkLlxuICogQHBhcmFtIHsqfSBvcHRzXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIFRvb2xiYXJQbHVnaW4ob3B0cykge1xuICByZXR1cm4ge1xuICAgIC8qIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSAqL1xuICAgIHJlbmRlckVkaXRvcjogcHJvcHMgPT4gKFxuICAgICAgPEVkaXRvckFuZFRvb2xiYXJcbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgICBtYWluRWRpdG9yUmVmPXtvcHRzLm1haW5FZGl0b3JSZWZ9XG4gICAgICAgIGRpc2FibGVTY3JvbGxiYXI9e29wdHMuZGlzYWJsZVNjcm9sbGJhcn1cbiAgICAgICAgZGlzYWJsZVVuZGVybGluZT17b3B0cy5kaXNhYmxlVW5kZXJsaW5lfVxuICAgICAgICBvbkRvbmU9e29wdHMub25Eb25lfVxuICAgICAgLz5cbiAgICApXG4gIH07XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBRUE7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDZSxTQUFTQSxhQUFULENBQXVCQyxJQUF2QixFQUE2QjtFQUMxQyxPQUFPO0lBQ0w7SUFDQUMsWUFBWSxFQUFFLHNCQUFBQyxLQUFLO01BQUEsb0JBQ2pCLGdDQUFDLDRCQUFELGdDQUNNQSxLQUROO1FBRUUsYUFBYSxFQUFFRixJQUFJLENBQUNHLGFBRnRCO1FBR0UsZ0JBQWdCLEVBQUVILElBQUksQ0FBQ0ksZ0JBSHpCO1FBSUUsZ0JBQWdCLEVBQUVKLElBQUksQ0FBQ0ssZ0JBSnpCO1FBS0UsTUFBTSxFQUFFTCxJQUFJLENBQUNNO01BTGYsR0FEaUI7SUFBQTtFQUZkLENBQVA7QUFZRCJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
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=
|
|
161
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZXMiLCJidXR0b24iLCJjb2xvciIsImRpc3BsYXkiLCJwYWRkaW5nIiwiYWN0aXZlIiwiZGlzYWJsZWQiLCJvcGFjaXR5IiwiY3Vyc29yIiwibG9nIiwiZGVidWciLCJSYXdCdXR0b24iLCJwcm9wcyIsImUiLCJwcmV2ZW50RGVmYXVsdCIsIm9uQ2xpY2siLCJjbGFzc2VzIiwiY2hpbGRyZW4iLCJleHRyYVN0eWxlcyIsIm5hbWVzIiwiY2xhc3NOYW1lcyIsIlJlYWN0IiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwiZnVuYyIsImlzUmVxdWlyZWQiLCJvYmplY3QiLCJvbmVPZlR5cGUiLCJhcnJheU9mIiwibm9kZSIsImJvb2wiLCJCdXR0b24iLCJpbmplY3RTaGVldCIsIlJhd01hcmtCdXR0b24iLCJvblRvZ2dsZSIsIm1hcmsiLCJzdHJpbmciLCJNYXJrQnV0dG9uIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3BsdWdpbnMvdG9vbGJhci90b29sYmFyLWJ1dHRvbnMuanN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgZGVidWcgZnJvbSAnZGVidWcnO1xuaW1wb3J0IGluamVjdFNoZWV0IGZyb20gJ3JlYWN0LWpzcyc7XG5pbXBvcnQgY2xhc3NOYW1lcyBmcm9tICdjbGFzc25hbWVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbmNvbnN0IHN0eWxlcyA9ICgpID0+ICh7XG4gIGJ1dHRvbjoge1xuICAgIGNvbG9yOiAnZ3JleScsXG4gICAgZGlzcGxheTogJ2lubGluZS1mbGV4JyxcbiAgICBwYWRkaW5nOiAnMnB4JyxcbiAgICAnJiA6aG92ZXInOiB7XG4gICAgICBjb2xvcjogJ2JsYWNrJ1xuICAgIH1cbiAgfSxcbiAgYWN0aXZlOiB7XG4gICAgY29sb3I6ICdibGFjaydcbiAgfSxcbiAgZGlzYWJsZWQ6IHtcbiAgICBvcGFjaXR5OiAwLjcsXG4gICAgY3Vyc29yOiAnbm90LWFsbG93ZWQnLFxuICAgICcmIDpob3Zlcic6IHtcbiAgICAgIGNvbG9yOiAnZ3JleSdcbiAgICB9XG4gIH1cbn0pO1xuXG5jb25zdCBsb2cgPSBkZWJ1ZygncGllLWVsZW1lbnRzOmVkaXRhYmxlLWh0bWw6cmF3LWJ1dHRvbicpO1xuXG5leHBvcnQgY2xhc3MgUmF3QnV0dG9uIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBjaGlsZHJlbjogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLmFycmF5T2YoUHJvcFR5cGVzLm5vZGUpLCBQcm9wVHlwZXMubm9kZV0pLmlzUmVxdWlyZWQsXG4gICAgYWN0aXZlOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBkaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gICAgZXh0cmFTdHlsZXM6IFByb3BUeXBlcy5vYmplY3RcbiAgfTtcblxuICBjb25zdHJ1Y3Rvcihwcm9wcykge1xuICAgIHN1cGVyKHByb3BzKTtcbiAgfVxuXG4gIG9uQ2xpY2sgPSBlID0+IHtcbiAgICBsb2coJ1tvbkNsaWNrXScpO1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICBjb25zdCB7IG9uQ2xpY2sgfSA9IHRoaXMucHJvcHM7XG4gICAgb25DbGljayhlKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBhY3RpdmUsIGNsYXNzZXMsIGNoaWxkcmVuLCBkaXNhYmxlZCwgZXh0cmFTdHlsZXMgfSA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgbmFtZXMgPSBjbGFzc05hbWVzKGNsYXNzZXMuYnV0dG9uLCB7XG4gICAgICBbY2xhc3Nlcy5hY3RpdmVdOiBhY3RpdmUsXG4gICAgICBbY2xhc3Nlcy5kaXNhYmxlZF06IGRpc2FibGVkXG4gICAgfSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBzdHlsZT17ZXh0cmFTdHlsZXN9IGNsYXNzTmFtZT17bmFtZXN9IG9uTW91c2VEb3duPXt0aGlzLm9uQ2xpY2t9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBjb25zdCBCdXR0b24gPSBpbmplY3RTaGVldChzdHlsZXMoKSkoUmF3QnV0dG9uKTtcblxuZXhwb3J0IGNsYXNzIFJhd01hcmtCdXR0b24gZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG9uVG9nZ2xlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIG1hcms6IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgY2hpbGRyZW46IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5hcnJheU9mKFByb3BUeXBlcy5ub2RlKSwgUHJvcFR5cGVzLm5vZGVdKS5pc1JlcXVpcmVkLFxuICAgIGNsYXNzZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcbiAgICBhY3RpdmU6IFByb3BUeXBlcy5ib29sXG4gIH07XG5cbiAgY29uc3RydWN0b3IocHJvcHMpIHtcbiAgICBzdXBlcihwcm9wcyk7XG4gIH1cblxuICBvblRvZ2dsZSA9IGUgPT4ge1xuICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICB0aGlzLnByb3BzLm9uVG9nZ2xlKHRoaXMucHJvcHMubWFyayk7XG4gIH07XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgY2xhc3NlcywgY2hpbGRyZW4sIGFjdGl2ZSB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBuYW1lcyA9IGNsYXNzTmFtZXMoY2xhc3Nlcy5idXR0b24sIGFjdGl2ZSAmJiBjbGFzc2VzLmFjdGl2ZSk7XG4gICAgcmV0dXJuIChcbiAgICAgIDxzcGFuIGNsYXNzTmFtZT17bmFtZXN9IG9uTW91c2VEb3duPXt0aGlzLm9uVG9nZ2xlfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9zcGFuPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IE1hcmtCdXR0b24gPSBpbmplY3RTaGVldChzdHlsZXMoKSkoUmF3TWFya0J1dHRvbik7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7OztBQUVBLElBQU1BLE1BQU0sR0FBRyxTQUFUQSxNQUFTO0VBQUEsT0FBTztJQUNwQkMsTUFBTSxFQUFFO01BQ05DLEtBQUssRUFBRSxNQUREO01BRU5DLE9BQU8sRUFBRSxhQUZIO01BR05DLE9BQU8sRUFBRSxLQUhIO01BSU4sWUFBWTtRQUNWRixLQUFLLEVBQUU7TUFERztJQUpOLENBRFk7SUFTcEJHLE1BQU0sRUFBRTtNQUNOSCxLQUFLLEVBQUU7SUFERCxDQVRZO0lBWXBCSSxRQUFRLEVBQUU7TUFDUkMsT0FBTyxFQUFFLEdBREQ7TUFFUkMsTUFBTSxFQUFFLGFBRkE7TUFHUixZQUFZO1FBQ1ZOLEtBQUssRUFBRTtNQURHO0lBSEo7RUFaVSxDQUFQO0FBQUEsQ0FBZjs7QUFxQkEsSUFBTU8sR0FBRyxHQUFHLElBQUFDLGlCQUFBLEVBQU0sdUNBQU4sQ0FBWjs7SUFFYUMsUzs7Ozs7RUFVWCxtQkFBWUMsS0FBWixFQUFtQjtJQUFBOztJQUFBO0lBQ2pCLDBCQUFNQSxLQUFOO0lBRGlCLDRGQUlULFVBQUFDLENBQUMsRUFBSTtNQUNiSixHQUFHLENBQUMsV0FBRCxDQUFIO01BQ0FJLENBQUMsQ0FBQ0MsY0FBRjtNQUNBLElBQVFDLE9BQVIsR0FBb0IsTUFBS0gsS0FBekIsQ0FBUUcsT0FBUjtNQUNBQSxPQUFPLENBQUNGLENBQUQsQ0FBUDtJQUNELENBVGtCO0lBQUE7RUFFbEI7Ozs7V0FTRCxrQkFBUztNQUFBOztNQUNQLGtCQUE2RCxLQUFLRCxLQUFsRTtNQUFBLElBQVFQLE1BQVIsZUFBUUEsTUFBUjtNQUFBLElBQWdCVyxPQUFoQixlQUFnQkEsT0FBaEI7TUFB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
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
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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"}
|