@pie-lib/editable-html 11.18.6-esmbeta.0 → 11.19.0-mui-update.0

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 (136) hide show
  1. package/CHANGELOG.md +37 -0
  2. package/lib/block-tags.js +2 -3
  3. package/lib/block-tags.js.map +1 -1
  4. package/lib/constants.js +3 -6
  5. package/lib/constants.js.map +1 -1
  6. package/lib/editor.js +302 -450
  7. package/lib/editor.js.map +1 -1
  8. package/lib/index.js +19 -77
  9. package/lib/index.js.map +1 -1
  10. package/lib/parse-html.js +7 -7
  11. package/lib/parse-html.js.map +1 -1
  12. package/lib/plugins/characters/custom-popper.js +24 -44
  13. package/lib/plugins/characters/custom-popper.js.map +1 -1
  14. package/lib/plugins/characters/index.js +9 -60
  15. package/lib/plugins/characters/index.js.map +1 -1
  16. package/lib/plugins/characters/utils.js +3 -6
  17. package/lib/plugins/characters/utils.js.map +1 -1
  18. package/lib/plugins/css/icons/index.js +13 -25
  19. package/lib/plugins/css/icons/index.js.map +1 -1
  20. package/lib/plugins/css/index.js +22 -88
  21. package/lib/plugins/css/index.js.map +1 -1
  22. package/lib/plugins/customPlugin/index.js +10 -26
  23. package/lib/plugins/customPlugin/index.js.map +1 -1
  24. package/lib/plugins/html/icons/index.js +14 -26
  25. package/lib/plugins/html/icons/index.js.map +1 -1
  26. package/lib/plugins/html/index.js +4 -13
  27. package/lib/plugins/html/index.js.map +1 -1
  28. package/lib/plugins/image/alt-dialog.js +20 -49
  29. package/lib/plugins/image/alt-dialog.js.map +1 -1
  30. package/lib/plugins/image/component.js +119 -190
  31. package/lib/plugins/image/component.js.map +1 -1
  32. package/lib/plugins/image/image-toolbar.js +44 -86
  33. package/lib/plugins/image/image-toolbar.js.map +1 -1
  34. package/lib/plugins/image/index.js +6 -46
  35. package/lib/plugins/image/index.js.map +1 -1
  36. package/lib/plugins/image/insert-image-handler.js +10 -31
  37. package/lib/plugins/image/insert-image-handler.js.map +1 -1
  38. package/lib/plugins/index.js +44 -106
  39. package/lib/plugins/index.js.map +1 -1
  40. package/lib/plugins/list/index.js +27 -73
  41. package/lib/plugins/list/index.js.map +1 -1
  42. package/lib/plugins/math/index.js +64 -116
  43. package/lib/plugins/math/index.js.map +1 -1
  44. package/lib/plugins/media/index.js +23 -81
  45. package/lib/plugins/media/index.js.map +1 -1
  46. package/lib/plugins/media/media-dialog.js +192 -307
  47. package/lib/plugins/media/media-dialog.js.map +1 -1
  48. package/lib/plugins/media/media-toolbar.js +40 -65
  49. package/lib/plugins/media/media-toolbar.js.map +1 -1
  50. package/lib/plugins/media/media-wrapper.js +20 -49
  51. package/lib/plugins/media/media-wrapper.js.map +1 -1
  52. package/lib/plugins/rendering/index.js +5 -15
  53. package/lib/plugins/rendering/index.js.map +1 -1
  54. package/lib/plugins/respArea/drag-in-the-blank/choice.js +175 -249
  55. package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
  56. package/lib/plugins/respArea/drag-in-the-blank/index.js +39 -29
  57. package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
  58. package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -10
  59. package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
  60. package/lib/plugins/respArea/icons/index.js +22 -45
  61. package/lib/plugins/respArea/icons/index.js.map +1 -1
  62. package/lib/plugins/respArea/index.js +5 -59
  63. package/lib/plugins/respArea/index.js.map +1 -1
  64. package/lib/plugins/respArea/inline-dropdown/index.js +2 -10
  65. package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
  66. package/lib/plugins/respArea/math-templated/index.js +92 -109
  67. package/lib/plugins/respArea/math-templated/index.js.map +1 -1
  68. package/lib/plugins/respArea/utils.js +8 -40
  69. package/lib/plugins/respArea/utils.js.map +1 -1
  70. package/lib/plugins/table/CustomTablePlugin.js +24 -41
  71. package/lib/plugins/table/CustomTablePlugin.js.map +1 -1
  72. package/lib/plugins/table/icons/index.js +19 -35
  73. package/lib/plugins/table/icons/index.js.map +1 -1
  74. package/lib/plugins/table/index.js +41 -118
  75. package/lib/plugins/table/index.js.map +1 -1
  76. package/lib/plugins/table/table-toolbar.js +37 -87
  77. package/lib/plugins/table/table-toolbar.js.map +1 -1
  78. package/lib/plugins/textAlign/icons/index.js +18 -64
  79. package/lib/plugins/textAlign/icons/index.js.map +1 -1
  80. package/lib/plugins/textAlign/index.js +1 -6
  81. package/lib/plugins/textAlign/index.js.map +1 -1
  82. package/lib/plugins/toolbar/default-toolbar.js +30 -79
  83. package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
  84. package/lib/plugins/toolbar/done-button.js +16 -34
  85. package/lib/plugins/toolbar/done-button.js.map +1 -1
  86. package/lib/plugins/toolbar/editor-and-toolbar.js +174 -201
  87. package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
  88. package/lib/plugins/toolbar/index.js +0 -5
  89. package/lib/plugins/toolbar/index.js.map +1 -1
  90. package/lib/plugins/toolbar/toolbar-buttons.js +57 -107
  91. package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
  92. package/lib/plugins/toolbar/toolbar.js +95 -161
  93. package/lib/plugins/toolbar/toolbar.js.map +1 -1
  94. package/lib/plugins/utils.js +5 -25
  95. package/lib/plugins/utils.js.map +1 -1
  96. package/lib/serialization.js +44 -150
  97. package/lib/serialization.js.map +1 -1
  98. package/lib/shared/alert-dialog.js +23 -42
  99. package/lib/theme.js +1 -2
  100. package/lib/theme.js.map +1 -1
  101. package/package.json +15 -21
  102. package/src/__tests__/utils.js +1 -1
  103. package/src/editor.jsx +110 -108
  104. package/src/plugins/characters/custom-popper.js +20 -25
  105. package/src/plugins/css/icons/index.jsx +11 -13
  106. package/src/plugins/css/index.jsx +3 -5
  107. package/src/plugins/html/icons/index.jsx +12 -14
  108. package/src/plugins/image/alt-dialog.jsx +9 -8
  109. package/src/plugins/image/component.jsx +67 -87
  110. package/src/plugins/image/image-toolbar.jsx +26 -26
  111. package/src/plugins/image/index.jsx +1 -1
  112. package/src/plugins/index.jsx +10 -10
  113. package/src/plugins/math/index.jsx +1 -1
  114. package/src/plugins/media/index.jsx +2 -2
  115. package/src/plugins/media/media-dialog.js +65 -76
  116. package/src/plugins/media/media-toolbar.jsx +32 -33
  117. package/src/plugins/media/media-wrapper.jsx +10 -13
  118. package/src/plugins/respArea/drag-in-the-blank/choice.jsx +193 -180
  119. package/src/plugins/respArea/drag-in-the-blank/index.jsx +58 -22
  120. package/src/plugins/respArea/icons/index.jsx +16 -16
  121. package/src/plugins/respArea/math-templated/index.jsx +88 -89
  122. package/src/plugins/respArea/utils.jsx +1 -1
  123. package/src/plugins/table/icons/index.jsx +14 -16
  124. package/src/plugins/table/index.jsx +27 -19
  125. package/src/plugins/table/table-toolbar.jsx +17 -19
  126. package/src/plugins/textAlign/icons/index.jsx +3 -3
  127. package/src/plugins/toolbar/__tests__/default-toolbar.test.jsx +1 -1
  128. package/src/plugins/toolbar/__tests__/toolbar.test.jsx +1 -1
  129. package/src/plugins/toolbar/default-toolbar.jsx +18 -21
  130. package/src/plugins/toolbar/done-button.jsx +16 -22
  131. package/src/plugins/toolbar/editor-and-toolbar.jsx +134 -157
  132. package/src/plugins/toolbar/toolbar-buttons.jsx +29 -46
  133. package/src/plugins/toolbar/toolbar.jsx +60 -78
  134. package/esm/index.js +0 -111560
  135. package/esm/index.js.map +0 -1
  136. package/esm/package.json +0 -1
@@ -1,92 +1,119 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports["default"] = exports.Component = void 0;
9
-
10
8
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
-
12
9
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
-
14
10
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
-
16
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
17
-
18
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
19
-
20
11
  var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
21
-
22
12
  var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
23
-
13
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
24
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
25
-
26
- var _LinearProgress = _interopRequireDefault(require("@material-ui/core/LinearProgress"));
27
-
15
+ var _LinearProgress = _interopRequireDefault(require("@mui/material/LinearProgress"));
28
16
  var _propTypes = _interopRequireDefault(require("prop-types"));
29
-
30
17
  var _react = _interopRequireDefault(require("react"));
31
-
32
18
  var _classnames = _interopRequireDefault(require("classnames"));
33
-
34
19
  var _debug = _interopRequireDefault(require("debug"));
35
-
36
- var _styles = require("@material-ui/core/styles");
37
-
20
+ var _styles = require("@mui/material/styles");
38
21
  var _slatePropTypes = _interopRequireDefault(require("slate-prop-types"));
39
-
40
- 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); }; }
41
-
42
- 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; } }
43
-
22
+ function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
23
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
44
24
  var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:image:component');
45
-
46
25
  var size = function size(s) {
47
26
  return s ? "".concat(s, "px") : 'auto';
48
27
  };
49
-
50
- var Component = /*#__PURE__*/function (_React$Component) {
51
- (0, _inherits2["default"])(Component, _React$Component);
52
-
53
- var _super = _createSuper(Component);
54
-
28
+ var StyledImageRoot = (0, _styles.styled)('div')(function (_ref) {
29
+ var theme = _ref.theme;
30
+ return {
31
+ position: 'relative',
32
+ border: "solid 1px ".concat(theme.palette.common.white),
33
+ display: 'flex',
34
+ transition: 'opacity 200ms linear',
35
+ '&.loading': {
36
+ opacity: 0.3
37
+ },
38
+ '&.pendingDelete': {
39
+ opacity: 0.3
40
+ }
41
+ };
42
+ });
43
+ var StyledProgress = (0, _styles.styled)(_LinearProgress["default"])(function () {
44
+ return {
45
+ position: 'absolute',
46
+ left: '0',
47
+ width: 'fit-content',
48
+ top: '0%',
49
+ transition: 'opacity 200ms linear',
50
+ '&.hideProgress': {
51
+ opacity: 0
52
+ }
53
+ };
54
+ });
55
+ var StyledImageContainer = (0, _styles.styled)('div')(function () {
56
+ return {
57
+ position: 'relative',
58
+ width: 'fit-content',
59
+ display: 'flex',
60
+ alignItems: 'center',
61
+ '&&:hover > .resize': {
62
+ display: 'block'
63
+ }
64
+ };
65
+ });
66
+ var StyledImage = (0, _styles.styled)('img')(function (_ref2) {
67
+ var theme = _ref2.theme;
68
+ return {
69
+ '&.active': {
70
+ border: "solid 1px ".concat(theme.palette.primary.main)
71
+ }
72
+ };
73
+ });
74
+ var StyledResize = (0, _styles.styled)('div')(function (_ref3) {
75
+ var theme = _ref3.theme;
76
+ return {
77
+ backgroundColor: theme.palette.primary.main,
78
+ cursor: 'col-resize',
79
+ height: '35px',
80
+ width: '5px',
81
+ borderRadius: 8,
82
+ marginLeft: '5px',
83
+ marginRight: '10px',
84
+ display: 'none'
85
+ };
86
+ });
87
+ var Component = exports.Component = /*#__PURE__*/function (_React$Component) {
55
88
  function Component() {
56
89
  var _this;
57
-
58
90
  (0, _classCallCheck2["default"])(this, Component);
59
-
60
91
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
61
92
  args[_key] = arguments[_key];
62
93
  }
63
-
64
- _this = _super.call.apply(_super, [this].concat(args));
65
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getWidth", function (percent) {
94
+ _this = _callSuper(this, Component, [].concat(args));
95
+ (0, _defineProperty2["default"])(_this, "getWidth", function (percent) {
66
96
  var multiplier = percent / 100;
67
97
  return _this.img.naturalWidth * multiplier;
68
98
  });
69
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getHeight", function (percent) {
99
+ (0, _defineProperty2["default"])(_this, "getHeight", function (percent) {
70
100
  var multiplier = percent / 100;
71
101
  return _this.img.naturalHeight * multiplier;
72
102
  });
73
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "getPercentFromWidth", function (width) {
103
+ (0, _defineProperty2["default"])(_this, "getPercentFromWidth", function (width) {
74
104
  var floored = width / _this.img.naturalWidth * 4;
75
105
  return parseInt(floored.toFixed(0) * 25, 10);
76
106
  });
77
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "applySizeData", function () {
107
+ (0, _defineProperty2["default"])(_this, "applySizeData", function () {
78
108
  var _this$props = _this.props,
79
- node = _this$props.node,
80
- editor = _this$props.editor;
109
+ node = _this$props.node,
110
+ editor = _this$props.editor;
81
111
  var update = node.data;
82
112
  var w = update.get('width');
83
-
84
113
  if (w) {
85
114
  update = update.set('resizePercent', _this.getPercentFromWidth(w));
86
115
  }
87
-
88
116
  log('[applySizeData] update: ', update);
89
-
90
117
  if (!update.equals(node.data)) {
91
118
  editor.change(function (c) {
92
119
  return c.setNodeByKey(node.key, {
@@ -95,49 +122,44 @@ var Component = /*#__PURE__*/function (_React$Component) {
95
122
  });
96
123
  }
97
124
  });
98
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "initialiseResize", function () {
125
+ (0, _defineProperty2["default"])(_this, "initialiseResize", function () {
99
126
  window.addEventListener('mousemove', _this.startResizing, false);
100
127
  window.addEventListener('mouseup', _this.stopResizing, false);
101
128
  });
102
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "loadImage", function () {
103
- var _ref = _this.props || {},
104
- maxImageWidth = _ref.maxImageWidth,
105
- maxImageHeight = _ref.maxImageHeight;
106
-
129
+ (0, _defineProperty2["default"])(_this, "loadImage", function () {
130
+ var _ref4 = _this.props || {},
131
+ maxImageWidth = _ref4.maxImageWidth,
132
+ maxImageHeight = _ref4.maxImageHeight;
107
133
  maxImageWidth = maxImageWidth || 700;
108
134
  maxImageHeight = maxImageHeight || 900;
109
- var box = _this.img; //on first load
135
+ var box = _this.img;
110
136
 
137
+ //on first load
111
138
  if (!box.style.width || box.style.width === 'auto') {
112
139
  var dimensions = {
113
140
  width: box && box.naturalWidth || 100,
114
141
  height: box && box.naturalHeight || 100
115
142
  };
116
-
117
143
  var _this$updateImageDime = _this.updateImageDimensions(dimensions, {
118
- width: dimensions.width < maxImageWidth ? dimensions.width : maxImageWidth,
119
- height: dimensions.height < maxImageHeight ? dimensions.height : maxImageHeight
120
- }, true),
121
- width = _this$updateImageDime.width,
122
- height = _this$updateImageDime.height;
123
-
144
+ width: dimensions.width < maxImageWidth ? dimensions.width : maxImageWidth,
145
+ height: dimensions.height < maxImageHeight ? dimensions.height : maxImageHeight
146
+ }, true),
147
+ width = _this$updateImageDime.width,
148
+ height = _this$updateImageDime.height;
124
149
  box.style.width = "".concat(width, "px");
125
150
  box.style.height = "".concat(height, "px");
126
-
127
151
  _this.setState({
128
152
  dimensions: {
129
153
  height: height,
130
154
  width: width
131
155
  }
132
156
  });
133
-
134
157
  var _this$props2 = _this.props,
135
- node = _this$props2.node,
136
- editor = _this$props2.editor;
158
+ node = _this$props2.node,
159
+ editor = _this$props2.editor;
137
160
  var update = node.data;
138
161
  update = update.set('width', width);
139
162
  update = update.set('height', height);
140
-
141
163
  if (!update.equals(node.data)) {
142
164
  editor.change(function (c) {
143
165
  return c.setNodeByKey(node.key, {
@@ -147,42 +169,36 @@ var Component = /*#__PURE__*/function (_React$Component) {
147
169
  }
148
170
  }
149
171
  });
150
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "startResizing", function (e) {
172
+ (0, _defineProperty2["default"])(_this, "startResizing", function (e) {
151
173
  var bounds = e.target.getBoundingClientRect();
152
174
  var box = _this.img;
153
175
  var dimensions = {
154
176
  width: box && box.naturalWidth || 100,
155
177
  height: box && box.naturalHeight || 100
156
178
  };
157
-
158
179
  var _this$updateImageDime2 = _this.updateImageDimensions(dimensions, {
159
- width: e.clientX - bounds.left,
160
- height: e.clientY - bounds.top
161
- }, true),
162
- width = _this$updateImageDime2.width,
163
- height = _this$updateImageDime2.height;
164
-
180
+ width: e.clientX - bounds.left,
181
+ height: e.clientY - bounds.top
182
+ }, true),
183
+ width = _this$updateImageDime2.width,
184
+ height = _this$updateImageDime2.height;
165
185
  var hasMinimumWidth = width > 50 && height > 50;
166
186
  var hasDimensionsConstraints = width <= 700 && height <= 900;
167
-
168
187
  if (hasMinimumWidth && hasDimensionsConstraints && box) {
169
188
  box.style.width = "".concat(width, "px");
170
189
  box.style.height = "".concat(height, "px");
171
-
172
190
  _this.setState({
173
191
  dimensions: {
174
192
  height: height,
175
193
  width: width
176
194
  }
177
195
  });
178
-
179
196
  var _this$props3 = _this.props,
180
- node = _this$props3.node,
181
- editor = _this$props3.editor;
197
+ node = _this$props3.node,
198
+ editor = _this$props3.editor;
182
199
  var update = node.data;
183
200
  update = update.set('width', width);
184
201
  update = update.set('height', height);
185
-
186
202
  if (!update.equals(node.data)) {
187
203
  editor.change(function (c) {
188
204
  return c.setNodeByKey(node.key, {
@@ -192,31 +208,30 @@ var Component = /*#__PURE__*/function (_React$Component) {
192
208
  }
193
209
  }
194
210
  });
195
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "stopResizing", function () {
211
+ (0, _defineProperty2["default"])(_this, "stopResizing", function () {
196
212
  window.removeEventListener('mousemove', _this.startResizing, false);
197
213
  window.removeEventListener('mouseup', _this.stopResizing, false);
198
214
  });
199
- (0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "updateImageDimensions", function (initialDim, nextDim, keepAspectRatio, resizeType) {
215
+ (0, _defineProperty2["default"])(_this, "updateImageDimensions", function (initialDim, nextDim, keepAspectRatio, resizeType) {
200
216
  // if we want to keep image aspect ratio
201
217
  if (keepAspectRatio) {
202
218
  var imageAspectRatio = initialDim.width / initialDim.height;
203
-
204
219
  if (resizeType === 'height') {
205
220
  // if we want to change image height => we update the width accordingly
206
221
  return {
207
222
  width: nextDim.height * imageAspectRatio,
208
223
  height: nextDim.height
209
224
  };
210
- } // if we want to change image width => we update the height accordingly
211
-
225
+ }
212
226
 
227
+ // if we want to change image width => we update the height accordingly
213
228
  return {
214
229
  width: nextDim.width,
215
230
  height: nextDim.width / imageAspectRatio
216
231
  };
217
- } // if we don't want to keep aspect ratio, we just update both values
218
-
232
+ }
219
233
 
234
+ // if we don't want to keep aspect ratio, we just update both values
220
235
  return {
221
236
  width: nextDim.width,
222
237
  height: nextDim.height
@@ -224,13 +239,12 @@ var Component = /*#__PURE__*/function (_React$Component) {
224
239
  });
225
240
  return _this;
226
241
  }
227
-
228
- (0, _createClass2["default"])(Component, [{
242
+ (0, _inherits2["default"])(Component, _React$Component);
243
+ return (0, _createClass2["default"])(Component, [{
229
244
  key: "componentDidMount",
230
245
  value: function componentDidMount() {
231
246
  this.applySizeData();
232
247
  var resizeHandle = this.resize;
233
-
234
248
  if (resizeHandle) {
235
249
  resizeHandle.addEventListener('mousedown', this.initialiseResize, false);
236
250
  }
@@ -253,13 +267,11 @@ var Component = /*#__PURE__*/function (_React$Component) {
253
267
  key: "render",
254
268
  value: function render() {
255
269
  var _this2 = this;
256
-
257
270
  var _this$props4 = this.props,
258
- node = _this$props4.node,
259
- editor = _this$props4.editor,
260
- classes = _this$props4.classes,
261
- attributes = _this$props4.attributes,
262
- onFocus = _this$props4.onFocus;
271
+ node = _this$props4.node,
272
+ editor = _this$props4.editor,
273
+ attributes = _this$props4.attributes,
274
+ onFocus = _this$props4.onFocus;
263
275
  var active = editor.value.isFocused && editor.value.selection.hasEdgeIn(node);
264
276
  var src = node.data.get('src');
265
277
  var loaded = node.data.get('loaded') !== false;
@@ -268,152 +280,69 @@ var Component = /*#__PURE__*/function (_React$Component) {
268
280
  var percent = node.data.get('percent');
269
281
  var alt = node.data.get('alt');
270
282
  var justifyContent;
271
-
272
283
  switch (alignment) {
273
284
  case 'left':
274
285
  justifyContent = 'flex-start';
275
286
  break;
276
-
277
287
  case 'center':
278
288
  justifyContent = 'center';
279
289
  break;
280
-
281
290
  case 'right':
282
291
  justifyContent = 'flex-end';
283
292
  break;
284
-
285
293
  default:
286
294
  justifyContent = 'flex-start';
287
295
  break;
288
296
  }
289
-
290
297
  log('[render] node.data:', node.data);
291
298
  var size = this.getSize(node.data);
292
299
  log('[render] style:', size);
293
- var className = (0, _classnames["default"])(classes.root, !loaded && classes.loading, deleteStatus === 'pending' && classes.pendingDelete);
294
- var progressClasses = (0, _classnames["default"])(classes.progress, loaded && classes.hideProgress);
300
+ var className = (0, _classnames["default"])(!loaded && 'loading', deleteStatus === 'pending' && 'pendingDelete');
301
+ var progressClasses = (0, _classnames["default"])(loaded && 'hideProgress');
295
302
  return [/*#__PURE__*/_react["default"].createElement("span", {
296
303
  key: 'sp1'
297
- }, "\xA0"), /*#__PURE__*/_react["default"].createElement("div", {
304
+ }, "\xA0"), /*#__PURE__*/_react["default"].createElement(StyledImageRoot, {
298
305
  key: 'comp',
299
306
  onFocus: onFocus,
300
307
  className: className,
301
308
  style: {
302
309
  justifyContent: justifyContent
303
310
  }
304
- }, /*#__PURE__*/_react["default"].createElement(_LinearProgress["default"], {
311
+ }, /*#__PURE__*/_react["default"].createElement(StyledProgress, {
305
312
  mode: "determinate",
306
313
  value: percent > 0 ? percent : 0,
307
314
  className: progressClasses
308
- }), /*#__PURE__*/_react["default"].createElement("div", {
309
- className: classes.imageContainer
310
- }, /*#__PURE__*/_react["default"].createElement("img", (0, _extends2["default"])({}, attributes, {
311
- className: (0, _classnames["default"])(classes.image, active && classes.active),
312
- ref: function ref(_ref2) {
313
- _this2.img = _ref2;
315
+ }), /*#__PURE__*/_react["default"].createElement(StyledImageContainer, null, /*#__PURE__*/_react["default"].createElement(StyledImage, (0, _extends2["default"])({}, attributes, {
316
+ className: (0, _classnames["default"])(active && 'active'),
317
+ ref: function ref(_ref5) {
318
+ _this2.img = _ref5;
314
319
  },
315
320
  src: src,
316
321
  style: size,
317
322
  onLoad: this.loadImage,
318
323
  alt: alt
319
- })), /*#__PURE__*/_react["default"].createElement("div", {
320
- ref: function ref(_ref3) {
321
- _this2.resize = _ref3;
324
+ })), /*#__PURE__*/_react["default"].createElement(StyledResize, {
325
+ ref: function ref(_ref6) {
326
+ _this2.resize = _ref6;
322
327
  },
323
- className: (0, _classnames["default"])(classes.resize, 'resize')
328
+ className: "resize"
324
329
  }))), /*#__PURE__*/_react["default"].createElement("span", {
325
330
  key: 'sp2'
326
331
  }, "\xA0")];
327
332
  }
328
333
  }]);
329
- return Component;
330
334
  }(_react["default"].Component);
331
-
332
- exports.Component = Component;
333
335
  (0, _defineProperty2["default"])(Component, "propTypes", {
334
336
  node: _slatePropTypes["default"].node.isRequired,
335
337
  editor: _propTypes["default"].shape({
336
338
  change: _propTypes["default"].func.isRequired,
337
339
  value: _propTypes["default"].object
338
340
  }).isRequired,
339
- classes: _propTypes["default"].object.isRequired,
340
341
  attributes: _propTypes["default"].object,
341
342
  onFocus: _propTypes["default"].func,
342
343
  onBlur: _propTypes["default"].func,
343
344
  maxImageWidth: _propTypes["default"].number,
344
345
  maxImageHeight: _propTypes["default"].number
345
346
  });
346
-
347
- var styles = function styles(theme) {
348
- return {
349
- portal: {
350
- position: 'absolute',
351
- opacity: 0,
352
- transition: 'opacity 200ms linear'
353
- },
354
- floatingButtonRow: {
355
- backgroundColor: theme.palette.background.paper,
356
- borderRadius: '1px',
357
- display: 'flex',
358
- padding: '10px',
359
- border: "solid 1px ".concat(theme.palette.grey[200]),
360
- boxShadow: '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)'
361
- },
362
- progress: {
363
- position: 'absolute',
364
- left: '0',
365
- width: 'fit-content',
366
- top: '0%',
367
- transition: 'opacity 200ms linear'
368
- },
369
- hideProgress: {
370
- opacity: 0
371
- },
372
- loading: {
373
- opacity: 0.3
374
- },
375
- pendingDelete: {
376
- opacity: 0.3
377
- },
378
- root: {
379
- position: 'relative',
380
- border: "solid 1px ".concat(theme.palette.common.white),
381
- display: 'flex',
382
- transition: 'opacity 200ms linear'
383
- },
384
- "delete": {
385
- position: 'absolute',
386
- right: 0
387
- },
388
- imageContainer: {
389
- position: 'relative',
390
- width: 'fit-content',
391
- display: 'flex',
392
- alignItems: 'center',
393
- '&&:hover > .resize': {
394
- display: 'block'
395
- }
396
- },
397
- active: {
398
- border: "solid 1px ".concat(theme.palette.primary.main)
399
- },
400
- resize: {
401
- backgroundColor: theme.palette.primary.main,
402
- cursor: 'col-resize',
403
- height: '35px',
404
- width: '5px',
405
- borderRadius: 8,
406
- marginLeft: '5px',
407
- marginRight: '10px',
408
- display: 'none'
409
- },
410
- drawableHeight: {
411
- minHeight: 350
412
- }
413
- };
414
- };
415
-
416
- var _default = (0, _styles.withStyles)(styles)(Component);
417
-
418
- exports["default"] = _default;
347
+ var _default = exports["default"] = Component;
419
348
  //# sourceMappingURL=component.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/plugins/image/component.jsx"],"names":["log","size","s","Component","percent","multiplier","img","naturalWidth","naturalHeight","width","floored","parseInt","toFixed","props","node","editor","update","data","w","get","set","getPercentFromWidth","equals","change","c","setNodeByKey","key","window","addEventListener","startResizing","stopResizing","maxImageWidth","maxImageHeight","box","style","dimensions","height","updateImageDimensions","setState","e","bounds","target","getBoundingClientRect","clientX","left","clientY","top","hasMinimumWidth","hasDimensionsConstraints","removeEventListener","initialDim","nextDim","keepAspectRatio","resizeType","imageAspectRatio","applySizeData","resizeHandle","resize","initialiseResize","objectFit","classes","attributes","onFocus","active","value","isFocused","selection","hasEdgeIn","src","loaded","deleteStatus","alignment","alt","justifyContent","getSize","className","root","loading","pendingDelete","progressClasses","progress","hideProgress","imageContainer","image","ref","loadImage","React","SlatePropTypes","isRequired","PropTypes","shape","func","object","onBlur","number","styles","theme","portal","position","opacity","transition","floatingButtonRow","backgroundColor","palette","background","paper","borderRadius","display","padding","border","grey","boxShadow","common","white","right","alignItems","primary","main","cursor","marginLeft","marginRight","drawableHeight","minHeight"],"mappings":"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","sourcesContent":["import LinearProgress from '@material-ui/core/LinearProgress';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { withStyles } from '@material-ui/core/styles';\nimport SlatePropTypes from 'slate-prop-types';\n\nconst log = debug('@pie-lib:editable-html:plugins:image:component');\n\nconst size = (s) => (s ? `${s}px` : 'auto');\n\nexport class Component extends React.Component {\n static propTypes = {\n node: SlatePropTypes.node.isRequired,\n editor: PropTypes.shape({\n change: PropTypes.func.isRequired,\n value: PropTypes.object,\n }).isRequired,\n classes: PropTypes.object.isRequired,\n attributes: PropTypes.object,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n maxImageWidth: PropTypes.number,\n maxImageHeight: PropTypes.number,\n };\n\n getWidth = (percent) => {\n const multiplier = percent / 100;\n return this.img.naturalWidth * multiplier;\n };\n\n getHeight = (percent) => {\n const multiplier = percent / 100;\n return this.img.naturalHeight * multiplier;\n };\n\n getPercentFromWidth = (width) => {\n var floored = (width / this.img.naturalWidth) * 4;\n return parseInt(floored.toFixed(0) * 25, 10);\n };\n\n applySizeData = () => {\n const { node, editor } = this.props;\n\n let update = node.data;\n\n const w = update.get('width');\n if (w) {\n update = update.set('resizePercent', this.getPercentFromWidth(w));\n }\n\n log('[applySizeData] update: ', update);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n };\n\n initialiseResize = () => {\n window.addEventListener('mousemove', this.startResizing, false);\n window.addEventListener('mouseup', this.stopResizing, false);\n };\n\n componentDidMount() {\n this.applySizeData();\n\n const resizeHandle = this.resize;\n\n if (resizeHandle) {\n resizeHandle.addEventListener('mousedown', this.initialiseResize, false);\n }\n }\n\n componentDidUpdate() {\n this.applySizeData();\n }\n\n getSize(data) {\n return {\n width: size(data.get('width')),\n height: size(data.get('height')),\n objectFit: 'contain',\n };\n }\n\n loadImage = () => {\n let { maxImageWidth, maxImageHeight } = this.props || {};\n maxImageWidth = maxImageWidth || 700;\n maxImageHeight = maxImageHeight || 900;\n\n const box = this.img;\n\n //on first load\n if (!box.style.width || box.style.width === 'auto') {\n const dimensions = {\n width: (box && box.naturalWidth) || 100,\n height: (box && box.naturalHeight) || 100,\n };\n\n const { width, height } = this.updateImageDimensions(\n dimensions,\n {\n width: dimensions.width < maxImageWidth ? dimensions.width : maxImageWidth,\n height: dimensions.height < maxImageHeight ? dimensions.height : maxImageHeight,\n },\n true,\n );\n\n box.style.width = `${width}px`;\n box.style.height = `${height}px`;\n\n this.setState({\n dimensions: { height: height, width: width },\n });\n\n const { node, editor } = this.props;\n\n let update = node.data;\n\n update = update.set('width', width);\n update = update.set('height', height);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n }\n };\n\n startResizing = (e) => {\n const bounds = e.target.getBoundingClientRect();\n const box = this.img;\n const dimensions = {\n width: (box && box.naturalWidth) || 100,\n height: (box && box.naturalHeight) || 100,\n };\n\n const { width, height } = this.updateImageDimensions(\n dimensions,\n {\n width: e.clientX - bounds.left,\n height: e.clientY - bounds.top,\n },\n true,\n );\n\n const hasMinimumWidth = width > 50 && height > 50;\n const hasDimensionsConstraints = width <= 700 && height <= 900;\n\n if (hasMinimumWidth && hasDimensionsConstraints && box) {\n box.style.width = `${width}px`;\n box.style.height = `${height}px`;\n\n this.setState({\n dimensions: { height: height, width: width },\n });\n\n const { node, editor } = this.props;\n\n let update = node.data;\n\n update = update.set('width', width);\n update = update.set('height', height);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n }\n };\n\n stopResizing = () => {\n window.removeEventListener('mousemove', this.startResizing, false);\n window.removeEventListener('mouseup', this.stopResizing, false);\n };\n\n updateImageDimensions = (initialDim, nextDim, keepAspectRatio, resizeType) => {\n // if we want to keep image aspect ratio\n if (keepAspectRatio) {\n const imageAspectRatio = initialDim.width / initialDim.height;\n\n if (resizeType === 'height') {\n // if we want to change image height => we update the width accordingly\n return {\n width: nextDim.height * imageAspectRatio,\n height: nextDim.height,\n };\n }\n\n // if we want to change image width => we update the height accordingly\n return {\n width: nextDim.width,\n height: nextDim.width / imageAspectRatio,\n };\n }\n\n // if we don't want to keep aspect ratio, we just update both values\n return {\n width: nextDim.width,\n height: nextDim.height,\n };\n };\n\n render() {\n const { node, editor, classes, attributes, onFocus } = this.props;\n const active = editor.value.isFocused && editor.value.selection.hasEdgeIn(node);\n const src = node.data.get('src');\n const loaded = node.data.get('loaded') !== false;\n const deleteStatus = node.data.get('deleteStatus');\n const alignment = node.data.get('alignment');\n const percent = node.data.get('percent');\n const alt = node.data.get('alt');\n let justifyContent;\n\n switch (alignment) {\n case 'left':\n justifyContent = 'flex-start';\n break;\n\n case 'center':\n justifyContent = 'center';\n break;\n\n case 'right':\n justifyContent = 'flex-end';\n break;\n\n default:\n justifyContent = 'flex-start';\n break;\n }\n log('[render] node.data:', node.data);\n\n const size = this.getSize(node.data);\n\n log('[render] style:', size);\n\n const className = classNames(\n classes.root,\n !loaded && classes.loading,\n deleteStatus === 'pending' && classes.pendingDelete,\n );\n\n const progressClasses = classNames(classes.progress, loaded && classes.hideProgress);\n\n return [\n <span key={'sp1'}>&nbsp;</span>,\n <div key={'comp'} onFocus={onFocus} className={className} style={{ justifyContent }}>\n <LinearProgress mode=\"determinate\" value={percent > 0 ? percent : 0} className={progressClasses} />\n <div className={classes.imageContainer}>\n <img\n {...attributes}\n className={classNames(classes.image, active && classes.active)}\n ref={(ref) => {\n this.img = ref;\n }}\n src={src}\n style={size}\n onLoad={this.loadImage}\n alt={alt}\n />\n <div\n ref={(ref) => {\n this.resize = ref;\n }}\n className={classNames(classes.resize, 'resize')}\n />\n </div>\n </div>,\n <span key={'sp2'}>&nbsp;</span>,\n ];\n }\n}\n\nconst styles = (theme) => ({\n portal: {\n position: 'absolute',\n opacity: 0,\n transition: 'opacity 200ms linear',\n },\n floatingButtonRow: {\n backgroundColor: theme.palette.background.paper,\n borderRadius: '1px',\n display: 'flex',\n padding: '10px',\n border: `solid 1px ${theme.palette.grey[200]}`,\n boxShadow:\n '0px 1px 5px 0px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 3px 1px -2px rgba(0, 0, 0, 0.12)',\n },\n progress: {\n position: 'absolute',\n left: '0',\n width: 'fit-content',\n top: '0%',\n transition: 'opacity 200ms linear',\n },\n hideProgress: {\n opacity: 0,\n },\n loading: {\n opacity: 0.3,\n },\n pendingDelete: {\n opacity: 0.3,\n },\n root: {\n position: 'relative',\n border: `solid 1px ${theme.palette.common.white}`,\n display: 'flex',\n transition: 'opacity 200ms linear',\n },\n delete: {\n position: 'absolute',\n right: 0,\n },\n imageContainer: {\n position: 'relative',\n width: 'fit-content',\n display: 'flex',\n alignItems: 'center',\n\n '&&:hover > .resize': {\n display: 'block',\n },\n },\n active: {\n border: `solid 1px ${theme.palette.primary.main}`,\n },\n resize: {\n backgroundColor: theme.palette.primary.main,\n cursor: 'col-resize',\n height: '35px',\n width: '5px',\n borderRadius: 8,\n marginLeft: '5px',\n marginRight: '10px',\n display: 'none',\n },\n drawableHeight: {\n minHeight: 350,\n },\n});\n\nexport default withStyles(styles)(Component);\n"],"file":"component.js"}
1
+ {"version":3,"file":"component.js","names":["_LinearProgress","_interopRequireDefault","require","_propTypes","_react","_classnames","_debug","_styles","_slatePropTypes","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","log","debug","size","s","concat","StyledImageRoot","styled","_ref","theme","position","border","palette","common","white","display","transition","opacity","StyledProgress","LinearProgress","left","width","top","StyledImageContainer","alignItems","StyledImage","_ref2","primary","main","StyledResize","_ref3","backgroundColor","cursor","height","borderRadius","marginLeft","marginRight","Component","exports","_React$Component","_this","_classCallCheck2","_len","arguments","length","args","Array","_key","_defineProperty2","percent","multiplier","img","naturalWidth","naturalHeight","floored","parseInt","toFixed","_this$props","props","node","editor","update","data","w","get","set","getPercentFromWidth","equals","change","c","setNodeByKey","key","window","addEventListener","startResizing","stopResizing","_ref4","maxImageWidth","maxImageHeight","box","style","dimensions","_this$updateImageDime","updateImageDimensions","setState","_this$props2","bounds","target","getBoundingClientRect","_this$updateImageDime2","clientX","clientY","hasMinimumWidth","hasDimensionsConstraints","_this$props3","removeEventListener","initialDim","nextDim","keepAspectRatio","resizeType","imageAspectRatio","_inherits2","_createClass2","value","componentDidMount","applySizeData","resizeHandle","resize","initialiseResize","componentDidUpdate","getSize","objectFit","render","_this2","_this$props4","attributes","onFocus","active","isFocused","selection","hasEdgeIn","src","loaded","deleteStatus","alignment","alt","justifyContent","className","classNames","progressClasses","createElement","mode","_extends2","ref","onLoad","loadImage","React","SlatePropTypes","isRequired","PropTypes","shape","func","object","onBlur","number","_default"],"sources":["../../../src/plugins/image/component.jsx"],"sourcesContent":["import LinearProgress from '@mui/material/LinearProgress';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport classNames from 'classnames';\nimport debug from 'debug';\nimport { styled } from '@mui/material/styles';\nimport SlatePropTypes from 'slate-prop-types';\n\nconst log = debug('@pie-lib:editable-html:plugins:image:component');\n\nconst size = (s) => (s ? `${s}px` : 'auto');\n\nconst StyledImageRoot = styled('div')(({ theme }) => ({\n position: 'relative',\n border: `solid 1px ${theme.palette.common.white}`,\n display: 'flex',\n transition: 'opacity 200ms linear',\n '&.loading': {\n opacity: 0.3,\n },\n '&.pendingDelete': {\n opacity: 0.3,\n },\n}));\n\nconst StyledProgress = styled(LinearProgress)(() => ({\n position: 'absolute',\n left: '0',\n width: 'fit-content',\n top: '0%',\n transition: 'opacity 200ms linear',\n '&.hideProgress': {\n opacity: 0,\n },\n}));\n\nconst StyledImageContainer = styled('div')(() => ({\n position: 'relative',\n width: 'fit-content',\n display: 'flex',\n alignItems: 'center',\n '&&:hover > .resize': {\n display: 'block',\n },\n}));\n\nconst StyledImage = styled('img')(({ theme }) => ({\n '&.active': {\n border: `solid 1px ${theme.palette.primary.main}`,\n },\n}));\n\nconst StyledResize = styled('div')(({ theme }) => ({\n backgroundColor: theme.palette.primary.main,\n cursor: 'col-resize',\n height: '35px',\n width: '5px',\n borderRadius: 8,\n marginLeft: '5px',\n marginRight: '10px',\n display: 'none',\n}));\n\nexport class Component extends React.Component {\n static propTypes = {\n node: SlatePropTypes.node.isRequired,\n editor: PropTypes.shape({\n change: PropTypes.func.isRequired,\n value: PropTypes.object,\n }).isRequired,\n attributes: PropTypes.object,\n onFocus: PropTypes.func,\n onBlur: PropTypes.func,\n maxImageWidth: PropTypes.number,\n maxImageHeight: PropTypes.number,\n };\n\n getWidth = (percent) => {\n const multiplier = percent / 100;\n return this.img.naturalWidth * multiplier;\n };\n\n getHeight = (percent) => {\n const multiplier = percent / 100;\n return this.img.naturalHeight * multiplier;\n };\n\n getPercentFromWidth = (width) => {\n var floored = (width / this.img.naturalWidth) * 4;\n return parseInt(floored.toFixed(0) * 25, 10);\n };\n\n applySizeData = () => {\n const { node, editor } = this.props;\n\n let update = node.data;\n\n const w = update.get('width');\n if (w) {\n update = update.set('resizePercent', this.getPercentFromWidth(w));\n }\n\n log('[applySizeData] update: ', update);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n };\n\n initialiseResize = () => {\n window.addEventListener('mousemove', this.startResizing, false);\n window.addEventListener('mouseup', this.stopResizing, false);\n };\n\n componentDidMount() {\n this.applySizeData();\n\n const resizeHandle = this.resize;\n\n if (resizeHandle) {\n resizeHandle.addEventListener('mousedown', this.initialiseResize, false);\n }\n }\n\n componentDidUpdate() {\n this.applySizeData();\n }\n\n getSize(data) {\n return {\n width: size(data.get('width')),\n height: size(data.get('height')),\n objectFit: 'contain',\n };\n }\n\n loadImage = () => {\n let { maxImageWidth, maxImageHeight } = this.props || {};\n maxImageWidth = maxImageWidth || 700;\n maxImageHeight = maxImageHeight || 900;\n\n const box = this.img;\n\n //on first load\n if (!box.style.width || box.style.width === 'auto') {\n const dimensions = {\n width: (box && box.naturalWidth) || 100,\n height: (box && box.naturalHeight) || 100,\n };\n\n const { width, height } = this.updateImageDimensions(\n dimensions,\n {\n width: dimensions.width < maxImageWidth ? dimensions.width : maxImageWidth,\n height: dimensions.height < maxImageHeight ? dimensions.height : maxImageHeight,\n },\n true,\n );\n\n box.style.width = `${width}px`;\n box.style.height = `${height}px`;\n\n this.setState({\n dimensions: { height: height, width: width },\n });\n\n const { node, editor } = this.props;\n\n let update = node.data;\n\n update = update.set('width', width);\n update = update.set('height', height);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n }\n };\n\n startResizing = (e) => {\n const bounds = e.target.getBoundingClientRect();\n const box = this.img;\n const dimensions = {\n width: (box && box.naturalWidth) || 100,\n height: (box && box.naturalHeight) || 100,\n };\n\n const { width, height } = this.updateImageDimensions(\n dimensions,\n {\n width: e.clientX - bounds.left,\n height: e.clientY - bounds.top,\n },\n true,\n );\n\n const hasMinimumWidth = width > 50 && height > 50;\n const hasDimensionsConstraints = width <= 700 && height <= 900;\n\n if (hasMinimumWidth && hasDimensionsConstraints && box) {\n box.style.width = `${width}px`;\n box.style.height = `${height}px`;\n\n this.setState({\n dimensions: { height: height, width: width },\n });\n\n const { node, editor } = this.props;\n\n let update = node.data;\n\n update = update.set('width', width);\n update = update.set('height', height);\n\n if (!update.equals(node.data)) {\n editor.change((c) => c.setNodeByKey(node.key, { data: update }));\n }\n }\n };\n\n stopResizing = () => {\n window.removeEventListener('mousemove', this.startResizing, false);\n window.removeEventListener('mouseup', this.stopResizing, false);\n };\n\n updateImageDimensions = (initialDim, nextDim, keepAspectRatio, resizeType) => {\n // if we want to keep image aspect ratio\n if (keepAspectRatio) {\n const imageAspectRatio = initialDim.width / initialDim.height;\n\n if (resizeType === 'height') {\n // if we want to change image height => we update the width accordingly\n return {\n width: nextDim.height * imageAspectRatio,\n height: nextDim.height,\n };\n }\n\n // if we want to change image width => we update the height accordingly\n return {\n width: nextDim.width,\n height: nextDim.width / imageAspectRatio,\n };\n }\n\n // if we don't want to keep aspect ratio, we just update both values\n return {\n width: nextDim.width,\n height: nextDim.height,\n };\n };\n\n render() {\n const { node, editor, attributes, onFocus } = this.props;\n const active = editor.value.isFocused && editor.value.selection.hasEdgeIn(node);\n const src = node.data.get('src');\n const loaded = node.data.get('loaded') !== false;\n const deleteStatus = node.data.get('deleteStatus');\n const alignment = node.data.get('alignment');\n const percent = node.data.get('percent');\n const alt = node.data.get('alt');\n let justifyContent;\n\n switch (alignment) {\n case 'left':\n justifyContent = 'flex-start';\n break;\n\n case 'center':\n justifyContent = 'center';\n break;\n\n case 'right':\n justifyContent = 'flex-end';\n break;\n\n default:\n justifyContent = 'flex-start';\n break;\n }\n log('[render] node.data:', node.data);\n\n const size = this.getSize(node.data);\n\n log('[render] style:', size);\n\n const className = classNames(\n !loaded && 'loading',\n deleteStatus === 'pending' && 'pendingDelete',\n );\n\n const progressClasses = classNames(loaded && 'hideProgress');\n\n return [\n <span key={'sp1'}>&nbsp;</span>,\n <StyledImageRoot key={'comp'} onFocus={onFocus} className={className} style={{ justifyContent }}>\n <StyledProgress mode=\"determinate\" value={percent > 0 ? percent : 0} className={progressClasses} />\n <StyledImageContainer>\n <StyledImage\n {...attributes}\n className={classNames(active && 'active')}\n ref={(ref) => {\n this.img = ref;\n }}\n src={src}\n style={size}\n onLoad={this.loadImage}\n alt={alt}\n />\n <StyledResize\n ref={(ref) => {\n this.resize = ref;\n }}\n className=\"resize\"\n />\n </StyledImageContainer>\n </StyledImageRoot>,\n <span key={'sp2'}>&nbsp;</span>,\n ];\n }\n}\n\nexport default Component;\n"],"mappings":"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","ignoreList":[]}