@iobroker/adapter-react-v5 2.1.11 → 3.0.2

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 (84) hide show
  1. package/Components/CustomModal.js +168 -0
  2. package/Components/CustomModal.js.map +1 -0
  3. package/Components/JsonConfigComponent/ChipInput.js +926 -0
  4. package/Components/JsonConfigComponent/ChipInput.js.map +1 -0
  5. package/Components/JsonConfigComponent/ConfigAlive.js +135 -0
  6. package/Components/JsonConfigComponent/ConfigAlive.js.map +1 -0
  7. package/Components/JsonConfigComponent/ConfigAutocomplete.js +204 -0
  8. package/Components/JsonConfigComponent/ConfigAutocomplete.js.map +1 -0
  9. package/Components/JsonConfigComponent/ConfigAutocompleteSendTo.js +311 -0
  10. package/Components/JsonConfigComponent/ConfigAutocompleteSendTo.js.map +1 -0
  11. package/Components/JsonConfigComponent/ConfigCRON.js +195 -0
  12. package/Components/JsonConfigComponent/ConfigCRON.js.map +1 -0
  13. package/Components/JsonConfigComponent/ConfigCertificateSelect.js +178 -0
  14. package/Components/JsonConfigComponent/ConfigCertificateSelect.js.map +1 -0
  15. package/Components/JsonConfigComponent/ConfigCheckbox.js +112 -0
  16. package/Components/JsonConfigComponent/ConfigCheckbox.js.map +1 -0
  17. package/Components/JsonConfigComponent/ConfigChip.js +149 -0
  18. package/Components/JsonConfigComponent/ConfigChip.js.map +1 -0
  19. package/Components/JsonConfigComponent/ConfigColor.js +156 -0
  20. package/Components/JsonConfigComponent/ConfigColor.js.map +1 -0
  21. package/Components/JsonConfigComponent/ConfigCoordinates.js +165 -0
  22. package/Components/JsonConfigComponent/ConfigCoordinates.js.map +1 -0
  23. package/Components/JsonConfigComponent/ConfigCustomEasyAccess.js +180 -0
  24. package/Components/JsonConfigComponent/ConfigCustomEasyAccess.js.map +1 -0
  25. package/Components/JsonConfigComponent/ConfigDatePicker.js +117 -0
  26. package/Components/JsonConfigComponent/ConfigDatePicker.js.map +1 -0
  27. package/Components/JsonConfigComponent/ConfigGeneric.js +660 -0
  28. package/Components/JsonConfigComponent/ConfigGeneric.js.map +1 -0
  29. package/Components/JsonConfigComponent/ConfigIP.js +151 -0
  30. package/Components/JsonConfigComponent/ConfigIP.js.map +1 -0
  31. package/Components/JsonConfigComponent/ConfigImageUpload.js +215 -0
  32. package/Components/JsonConfigComponent/ConfigImageUpload.js.map +1 -0
  33. package/Components/JsonConfigComponent/ConfigInstanceSelect.js +197 -0
  34. package/Components/JsonConfigComponent/ConfigInstanceSelect.js.map +1 -0
  35. package/Components/JsonConfigComponent/ConfigJsonEditor.js +211 -0
  36. package/Components/JsonConfigComponent/ConfigJsonEditor.js.map +1 -0
  37. package/Components/JsonConfigComponent/ConfigLanguage.js +175 -0
  38. package/Components/JsonConfigComponent/ConfigLanguage.js.map +1 -0
  39. package/Components/JsonConfigComponent/ConfigNumber.js +194 -0
  40. package/Components/JsonConfigComponent/ConfigNumber.js.map +1 -0
  41. package/Components/JsonConfigComponent/ConfigObjectId.js +201 -0
  42. package/Components/JsonConfigComponent/ConfigObjectId.js.map +1 -0
  43. package/Components/JsonConfigComponent/ConfigPanel.js +421 -0
  44. package/Components/JsonConfigComponent/ConfigPanel.js.map +1 -0
  45. package/Components/JsonConfigComponent/ConfigPassword.js +236 -0
  46. package/Components/JsonConfigComponent/ConfigPassword.js.map +1 -0
  47. package/Components/JsonConfigComponent/ConfigPattern.js +94 -0
  48. package/Components/JsonConfigComponent/ConfigPattern.js.map +1 -0
  49. package/Components/JsonConfigComponent/ConfigSelect.js +163 -0
  50. package/Components/JsonConfigComponent/ConfigSelect.js.map +1 -0
  51. package/Components/JsonConfigComponent/ConfigSelectSendTo.js +258 -0
  52. package/Components/JsonConfigComponent/ConfigSelectSendTo.js.map +1 -0
  53. package/Components/JsonConfigComponent/ConfigSendto.js +282 -0
  54. package/Components/JsonConfigComponent/ConfigSendto.js.map +1 -0
  55. package/Components/JsonConfigComponent/ConfigSetState.js +266 -0
  56. package/Components/JsonConfigComponent/ConfigSetState.js.map +1 -0
  57. package/Components/JsonConfigComponent/ConfigStaticDivider.js +88 -0
  58. package/Components/JsonConfigComponent/ConfigStaticDivider.js.map +1 -0
  59. package/Components/JsonConfigComponent/ConfigStaticHeader.js +81 -0
  60. package/Components/JsonConfigComponent/ConfigStaticHeader.js.map +1 -0
  61. package/Components/JsonConfigComponent/ConfigStaticImage.js +88 -0
  62. package/Components/JsonConfigComponent/ConfigStaticImage.js.map +1 -0
  63. package/Components/JsonConfigComponent/ConfigStaticText.js +104 -0
  64. package/Components/JsonConfigComponent/ConfigStaticText.js.map +1 -0
  65. package/Components/JsonConfigComponent/ConfigTable.js +651 -0
  66. package/Components/JsonConfigComponent/ConfigTable.js.map +1 -0
  67. package/Components/JsonConfigComponent/ConfigTabs.js +166 -0
  68. package/Components/JsonConfigComponent/ConfigTabs.js.map +1 -0
  69. package/Components/JsonConfigComponent/ConfigText.js +170 -0
  70. package/Components/JsonConfigComponent/ConfigText.js.map +1 -0
  71. package/Components/JsonConfigComponent/ConfigTextSendTo.js +168 -0
  72. package/Components/JsonConfigComponent/ConfigTextSendTo.js.map +1 -0
  73. package/Components/JsonConfigComponent/ConfigTimePicker.js +111 -0
  74. package/Components/JsonConfigComponent/ConfigTimePicker.js.map +1 -0
  75. package/Components/JsonConfigComponent/ConfigTopic.js +140 -0
  76. package/Components/JsonConfigComponent/ConfigTopic.js.map +1 -0
  77. package/Components/JsonConfigComponent/ConfigUser.js +176 -0
  78. package/Components/JsonConfigComponent/ConfigUser.js.map +1 -0
  79. package/Components/JsonConfigComponent/index.js +511 -0
  80. package/Components/JsonConfigComponent/index.js.map +1 -0
  81. package/Components/UploadImage.js +357 -0
  82. package/Components/UploadImage.js.map +1 -0
  83. package/README.md +3 -0
  84. package/package.json +3 -1
@@ -0,0 +1,357 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+
12
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
13
+
14
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
+
16
+ var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
+
18
+ var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
19
+
20
+ var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
21
+
22
+ var _react = require("react");
23
+
24
+ var _clsx = _interopRequireDefault(require("clsx"));
25
+
26
+ var _propTypes = _interopRequireDefault(require("prop-types"));
27
+
28
+ var _reactDropzone = _interopRequireDefault(require("react-dropzone"));
29
+
30
+ var _reactCropper = require("react-cropper");
31
+
32
+ require("cropperjs/dist/cropper.css");
33
+
34
+ var _styles = require("@mui/styles");
35
+
36
+ var _material = require("@mui/material");
37
+
38
+ var _IconButton = _interopRequireDefault(require("@mui/material/IconButton"));
39
+
40
+ var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
41
+
42
+ var _Crop = _interopRequireDefault(require("@mui/icons-material/Crop"));
43
+
44
+ var _fa = require("react-icons/fa");
45
+
46
+ 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); }; }
47
+
48
+ 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; } }
49
+
50
+ var styles = function styles(theme) {
51
+ return {
52
+ dropZone: {
53
+ width: '100%',
54
+ height: 100,
55
+ position: 'relative'
56
+ },
57
+ dropZoneEmpty: {},
58
+ image: {
59
+ objectFit: 'contain',
60
+ margin: 'auto',
61
+ display: 'flex',
62
+ width: '100%',
63
+ height: '100%'
64
+ },
65
+ uploadDiv: {
66
+ position: 'relative',
67
+ width: '100%',
68
+ height: 300,
69
+ opacity: 0.9,
70
+ marginTop: 30,
71
+ cursor: 'pointer',
72
+ outline: 'none'
73
+ },
74
+ uploadDivDragging: {
75
+ opacity: 1,
76
+ background: 'rgba(128,255,128,0.1)'
77
+ },
78
+ uploadCenterDiv: {
79
+ margin: 5,
80
+ border: '3px dashed grey',
81
+ borderRadius: 5,
82
+ width: 'calc(100% - 10px)',
83
+ height: 'calc(100% - 10px)',
84
+ position: 'relative',
85
+ display: 'flex'
86
+ },
87
+ uploadCenterIcon: {
88
+ paddingTop: 10,
89
+ width: 48,
90
+ height: 48
91
+ },
92
+ uploadCenterText: {
93
+ fontSize: 16
94
+ },
95
+ uploadCenterTextAndIcon: {
96
+ textAlign: 'center',
97
+ position: 'absolute',
98
+ top: 0,
99
+ bottom: 0,
100
+ left: 0,
101
+ right: 0,
102
+ display: 'flex',
103
+ flexDirection: 'column',
104
+ alignItems: 'center',
105
+ justifyContent: 'center'
106
+ },
107
+ disabledOpacity: {
108
+ opacity: 0.3,
109
+ cursor: 'default'
110
+ },
111
+ buttonRemoveWrapper: {
112
+ position: 'absolute',
113
+ zIndex: 222,
114
+ right: 0
115
+ },
116
+ buttonCropWrapper: {
117
+ position: 'absolute',
118
+ zIndex: 222,
119
+ right: 0,
120
+ top: 50
121
+ },
122
+ error: {
123
+ border: '2px solid red'
124
+ }
125
+ };
126
+ };
127
+
128
+ var UploadImage = /*#__PURE__*/function (_Component) {
129
+ (0, _inherits2["default"])(UploadImage, _Component);
130
+
131
+ var _super = _createSuper(UploadImage);
132
+
133
+ function UploadImage(props) {
134
+ var _this;
135
+
136
+ (0, _classCallCheck2["default"])(this, UploadImage);
137
+ _this = _super.call(this, props);
138
+ _this.state = {
139
+ uploadFile: false,
140
+ anchorEl: null,
141
+ cropHandler: false
142
+ };
143
+ _this.cropperRef = /*#__PURE__*/(0, _react.createRef)();
144
+ return _this;
145
+ }
146
+
147
+ (0, _createClass2["default"])(UploadImage, [{
148
+ key: "onDrop",
149
+ value: function onDrop(acceptedFiles) {
150
+ var _this$props = this.props,
151
+ maxSize = _this$props.maxSize,
152
+ t = _this$props.t,
153
+ onChange = _this$props.onChange;
154
+ var file = acceptedFiles[0];
155
+ var reader = new FileReader();
156
+
157
+ reader.onabort = function () {
158
+ return console.log('file reading was aborted');
159
+ };
160
+
161
+ reader.onerror = function () {
162
+ return console.log('file reading has failed');
163
+ };
164
+
165
+ reader.onload = function () {
166
+ var ext = 'image/' + file.name.split('.').pop().toLowerCase();
167
+
168
+ if (ext === 'image/jpg') {
169
+ ext = 'image/jpeg';
170
+ } else if (ext.includes('svg')) {
171
+ ext = 'image/svg+xml';
172
+ }
173
+
174
+ if (file.size > maxSize) {
175
+ return window.alert(t('File is too big. Max %sk allowed. Try use SVG.', Math.round(maxSize / 1024)));
176
+ }
177
+
178
+ var base64 = "data:".concat(ext, ";base64,").concat(btoa(new Uint8Array(reader.result).reduce(function (data, _byte) {
179
+ return data + String.fromCharCode(_byte);
180
+ }, '')));
181
+ onChange(base64);
182
+ };
183
+
184
+ reader.readAsArrayBuffer(file);
185
+ }
186
+ }, {
187
+ key: "render",
188
+ value: function render() {
189
+ var _this2 = this;
190
+
191
+ var _this$props2 = this.props,
192
+ disabled = _this$props2.disabled,
193
+ maxSize = _this$props2.maxSize,
194
+ classes = _this$props2.classes,
195
+ icon = _this$props2.icon,
196
+ t = _this$props2.t,
197
+ removeIconFunc = _this$props2.removeIconFunc,
198
+ accept = _this$props2.accept,
199
+ error = _this$props2.error,
200
+ crop = _this$props2.crop,
201
+ onChange = _this$props2.onChange;
202
+ var _this$state = this.state,
203
+ uploadFile = _this$state.uploadFile,
204
+ anchorEl = _this$state.anchorEl,
205
+ cropHandler = _this$state.cropHandler;
206
+ return /*#__PURE__*/React.createElement(_reactDropzone["default"], {
207
+ disabled: disabled || cropHandler,
208
+ key: "dropzone",
209
+ multiple: false,
210
+ accept: accept,
211
+ maxSize: maxSize,
212
+ onDragEnter: function onDragEnter() {
213
+ return _this2.setState({
214
+ uploadFile: 'dragging'
215
+ });
216
+ },
217
+ onDragLeave: function onDragLeave() {
218
+ return _this2.setState({
219
+ uploadFile: true
220
+ });
221
+ },
222
+ onDrop: function onDrop(acceptedFiles, errors) {
223
+ _this2.setState({
224
+ uploadFile: false
225
+ });
226
+
227
+ if (!acceptedFiles.length) {
228
+ window.alert(errors && errors[0] && errors[0].errors && errors[0].errors[0] && errors[0].errors[0].message || t('Cannot upload'));
229
+ } else {
230
+ return _this2.onDrop(acceptedFiles);
231
+ }
232
+ }
233
+ }, function (_ref) {
234
+ var getRootProps = _ref.getRootProps,
235
+ getInputProps = _ref.getInputProps;
236
+ return /*#__PURE__*/React.createElement("div", (0, _extends2["default"])({
237
+ className: (0, _clsx["default"])(classes.uploadDiv, uploadFile === 'dragging' && classes.uploadDivDragging, classes.dropZone, disabled && classes.disabledOpacity, !icon && classes.dropZoneEmpty)
238
+ }, getRootProps()), /*#__PURE__*/React.createElement("input", getInputProps()), /*#__PURE__*/React.createElement("div", {
239
+ className: (0, _clsx["default"])(classes.uploadCenterDiv, error && classes.error)
240
+ }, !icon ? /*#__PURE__*/React.createElement("div", {
241
+ className: classes.uploadCenterTextAndIcon
242
+ }, /*#__PURE__*/React.createElement(_fa.FaFileUpload, {
243
+ className: classes.uploadCenterIcon
244
+ }), /*#__PURE__*/React.createElement("div", {
245
+ className: classes.uploadCenterText
246
+ }, uploadFile === 'dragging' ? t('Drop file here') : t('Place your files here or click here to open the browse dialog'))) : removeIconFunc && !cropHandler && /*#__PURE__*/React.createElement("div", {
247
+ className: classes.buttonRemoveWrapper
248
+ }, /*#__PURE__*/React.createElement(_material.Tooltip, {
249
+ title: t('Clear')
250
+ }, /*#__PURE__*/React.createElement(_IconButton["default"], {
251
+ size: "large",
252
+ onClick: function onClick(e) {
253
+ removeIconFunc && removeIconFunc();
254
+ e.stopPropagation();
255
+ }
256
+ }, /*#__PURE__*/React.createElement(_Close["default"], null)))), icon && crop && /*#__PURE__*/React.createElement("div", {
257
+ className: classes.buttonCropWrapper
258
+ }, /*#__PURE__*/React.createElement(_material.Tooltip, {
259
+ title: t('Crop')
260
+ }, /*#__PURE__*/React.createElement(_IconButton["default"], {
261
+ size: "large",
262
+ onClick: function onClick(e) {
263
+ if (!cropHandler) {
264
+ _this2.setState({
265
+ cropHandler: true
266
+ });
267
+ } else {
268
+ _this2.setState({
269
+ anchorEl: e.currentTarget
270
+ });
271
+ }
272
+
273
+ e.stopPropagation();
274
+ }
275
+ }, /*#__PURE__*/React.createElement(_Crop["default"], {
276
+ color: cropHandler ? 'primary' : 'inherit'
277
+ }))), /*#__PURE__*/React.createElement(_material.Menu, {
278
+ id: "simple-menu",
279
+ anchorEl: anchorEl,
280
+ keepMounted: true,
281
+ open: Boolean(anchorEl),
282
+ onClose: function onClose() {
283
+ return _this2.setState({
284
+ anchorEl: null
285
+ });
286
+ }
287
+ }, /*#__PURE__*/React.createElement(_material.MenuItem, {
288
+ onClick: function onClick() {
289
+ return _this2.setState({
290
+ anchorEl: null,
291
+ cropHandler: false
292
+ }, function () {
293
+ var _this2$cropperRef, _this2$cropperRef$cur;
294
+
295
+ var imageElement = (_this2$cropperRef = _this2.cropperRef) === null || _this2$cropperRef === void 0 ? void 0 : (_this2$cropperRef$cur = _this2$cropperRef.current) === null || _this2$cropperRef$cur === void 0 ? void 0 : _this2$cropperRef$cur.cropper;
296
+ onChange(imageElement.getCroppedCanvas().toDataURL());
297
+ });
298
+ }
299
+ }, t('Save')), /*#__PURE__*/React.createElement(_material.MenuItem, {
300
+ onClick: function onClick() {
301
+ return _this2.setState({
302
+ anchorEl: null,
303
+ cropHandler: false
304
+ });
305
+ }
306
+ }, t('Close')))), icon && !cropHandler ? /*#__PURE__*/React.createElement("img", {
307
+ src: icon,
308
+ className: classes.image,
309
+ alt: "icon"
310
+ }) : null, icon && crop && cropHandler ? /*#__PURE__*/React.createElement(_reactCropper.Cropper, {
311
+ ref: _this2.cropperRef,
312
+ className: classes.image,
313
+ src: icon,
314
+ initialAspectRatio: 1,
315
+ viewMode: 1,
316
+ guides: false,
317
+ minCropBoxHeight: 10,
318
+ minCropBoxWidth: 10,
319
+ background: false,
320
+ checkOrientation: false
321
+ }) : null));
322
+ });
323
+ }
324
+ }]);
325
+ return UploadImage;
326
+ }(_react.Component);
327
+
328
+ UploadImage.defaultProps = {
329
+ disabled: false,
330
+ maxSize: 10 * 1024,
331
+ icon: null,
332
+ removeIconFunc: null,
333
+ accept: 'image/*',
334
+ error: false,
335
+ onChange: function onChange(base64) {
336
+ return console.log(base64);
337
+ },
338
+ t: function t(el) {
339
+ return el;
340
+ },
341
+ crop: false
342
+ };
343
+ UploadImage.propTypes = {
344
+ classes: _propTypes["default"].object,
345
+ maxSize: _propTypes["default"].number,
346
+ disabled: _propTypes["default"].bool,
347
+ crop: _propTypes["default"].bool,
348
+ error: _propTypes["default"].bool,
349
+ onChange: _propTypes["default"].func,
350
+ accept: _propTypes["default"].string,
351
+ t: _propTypes["default"].func
352
+ };
353
+
354
+ var _default = (0, _styles.withStyles)(styles)(UploadImage);
355
+
356
+ exports["default"] = _default;
357
+ //# sourceMappingURL=UploadImage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UploadImage.js","names":["styles","theme","dropZone","width","height","position","dropZoneEmpty","image","objectFit","margin","display","uploadDiv","opacity","marginTop","cursor","outline","uploadDivDragging","background","uploadCenterDiv","border","borderRadius","uploadCenterIcon","paddingTop","uploadCenterText","fontSize","uploadCenterTextAndIcon","textAlign","top","bottom","left","right","flexDirection","alignItems","justifyContent","disabledOpacity","buttonRemoveWrapper","zIndex","buttonCropWrapper","error","UploadImage","props","state","uploadFile","anchorEl","cropHandler","cropperRef","createRef","acceptedFiles","maxSize","t","onChange","file","reader","FileReader","onabort","console","log","onerror","onload","ext","name","split","pop","toLowerCase","includes","size","window","alert","Math","round","base64","btoa","Uint8Array","result","reduce","data","byte","String","fromCharCode","readAsArrayBuffer","disabled","classes","icon","removeIconFunc","accept","crop","setState","errors","length","message","onDrop","getRootProps","getInputProps","clsx","e","stopPropagation","currentTarget","Boolean","imageElement","current","cropper","getCroppedCanvas","toDataURL","Component","defaultProps","el","propTypes","PropTypes","object","number","bool","func","string","withStyles"],"sources":["UploadImage.jsx"],"sourcesContent":["import { Component, createRef } from 'react';\nimport clsx from 'clsx';\nimport PropTypes from 'prop-types';\nimport Dropzone from 'react-dropzone';\nimport { Cropper } from 'react-cropper';\nimport 'cropperjs/dist/cropper.css';\n\nimport { withStyles } from '@mui/styles';\nimport { Menu, MenuItem, Tooltip } from '@mui/material';\nimport IconButton from '@mui/material/IconButton';\n\nimport IconClose from '@mui/icons-material/Close';\nimport CropIcon from '@mui/icons-material/Crop';\nimport { FaFileUpload as UploadIcon } from 'react-icons/fa';\n\nconst styles = theme => ({\n dropZone: {\n width: '100%',\n height: 100,\n position: 'relative',\n },\n dropZoneEmpty: {\n\n },\n image: {\n objectFit: 'contain',\n margin: 'auto',\n display: 'flex',\n width: '100%',\n height: '100%',\n },\n\n uploadDiv: {\n position: 'relative',\n width: '100%',\n height: 300,\n opacity: 0.9,\n marginTop: 30,\n cursor: 'pointer',\n outline: 'none'\n },\n uploadDivDragging: {\n opacity: 1,\n background: 'rgba(128,255,128,0.1)'\n },\n\n uploadCenterDiv: {\n margin: 5,\n border: '3px dashed grey',\n borderRadius: 5,\n width: 'calc(100% - 10px)',\n height: 'calc(100% - 10px)',\n position: 'relative',\n display: 'flex'\n },\n uploadCenterIcon: {\n paddingTop: 10,\n width: 48,\n height: 48,\n },\n uploadCenterText: {\n fontSize: 16,\n },\n uploadCenterTextAndIcon: {\n textAlign: 'center',\n position: 'absolute',\n top: 0,\n bottom: 0,\n left: 0,\n right: 0,\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center'\n\n },\n disabledOpacity: {\n opacity: 0.3,\n cursor: 'default'\n },\n buttonRemoveWrapper: {\n position: 'absolute',\n zIndex: 222,\n right: 0\n },\n buttonCropWrapper: {\n position: 'absolute',\n zIndex: 222,\n right: 0,\n top: 50\n },\n error: {\n border: '2px solid red'\n }\n});\n\nclass UploadImage extends Component {\n constructor(props) {\n super(props);\n this.state = {\n uploadFile: false,\n anchorEl: null,\n cropHandler: false,\n };\n this.cropperRef = createRef();\n }\n\n onDrop(acceptedFiles) {\n const { maxSize, t, onChange } = this.props;\n\n const file = acceptedFiles[0];\n const reader = new FileReader();\n\n reader.onabort = () => console.log('file reading was aborted');\n reader.onerror = () => console.log('file reading has failed');\n reader.onload = () => {\n let ext = 'image/' + file.name.split('.').pop().toLowerCase();\n if (ext === 'image/jpg') {\n ext = 'image/jpeg';\n } else if (ext.includes('svg')) {\n ext = 'image/svg+xml';\n }\n if (file.size > maxSize) {\n return window.alert(t('File is too big. Max %sk allowed. Try use SVG.', Math.round(maxSize / 1024)));\n }\n const base64 = `data:${ext};base64,${btoa(\n new Uint8Array(reader.result)\n .reduce((data, byte) => data + String.fromCharCode(byte), ''))}`;\n\n onChange(base64);\n };\n reader.readAsArrayBuffer(file);\n }\n\n render() {\n const { disabled, maxSize, classes, icon, t, removeIconFunc, accept, error, crop, onChange } = this.props;\n const { uploadFile, anchorEl, cropHandler } = this.state;\n return <Dropzone\n disabled={disabled || cropHandler}\n key=\"dropzone\"\n multiple={false}\n accept={accept}\n maxSize={maxSize}\n onDragEnter={() => this.setState({ uploadFile: 'dragging' })}\n onDragLeave={() => this.setState({ uploadFile: true })}\n onDrop={(acceptedFiles, errors) => {\n this.setState({ uploadFile: false });\n if (!acceptedFiles.length) {\n window.alert((errors && errors[0] && errors[0].errors && errors[0].errors[0] && errors[0].errors[0].message) || t('Cannot upload'));\n } else {\n return this.onDrop(acceptedFiles);\n }\n }}\n >\n {({ getRootProps, getInputProps }) => <div\n className={clsx(\n classes.uploadDiv,\n uploadFile === 'dragging' && classes.uploadDivDragging,\n classes.dropZone,\n disabled && classes.disabledOpacity,\n !icon && classes.dropZoneEmpty\n )}\n {...getRootProps()}>\n <input {...getInputProps()} />\n <div className={clsx(classes.uploadCenterDiv, error && classes.error)}>\n {!icon ? <div className={classes.uploadCenterTextAndIcon}>\n <UploadIcon className={classes.uploadCenterIcon} />\n <div className={classes.uploadCenterText}>{\n uploadFile === 'dragging' ? t('Drop file here') :\n t('Place your files here or click here to open the browse dialog')}</div>\n </div>\n :\n removeIconFunc && !cropHandler && <div className={classes.buttonRemoveWrapper}>\n <Tooltip title={t('Clear')}>\n <IconButton size=\"large\" onClick={e => {\n removeIconFunc && removeIconFunc();\n e.stopPropagation();\n }}><IconClose />\n </IconButton>\n </Tooltip>\n </div>\n }\n {icon && crop && <div className={classes.buttonCropWrapper}>\n <Tooltip title={t('Crop')}>\n <IconButton size=\"large\" onClick={e => {\n if (!cropHandler) {\n this.setState({ cropHandler: true });\n } else {\n this.setState({ anchorEl: e.currentTarget });\n }\n e.stopPropagation();\n }}><CropIcon color={cropHandler ? 'primary' : 'inherit'} />\n </IconButton>\n </Tooltip>\n <Menu\n id=\"simple-menu\"\n anchorEl={anchorEl}\n keepMounted\n open={Boolean(anchorEl)}\n onClose={() => this.setState({ anchorEl: null })}\n >\n <MenuItem onClick={() => this.setState({ anchorEl: null, cropHandler: false }, () => {\n const imageElement = this.cropperRef?.current?.cropper;\n onChange(imageElement.getCroppedCanvas().toDataURL());\n })}>{t('Save')}</MenuItem>\n <MenuItem onClick={() => this.setState({ anchorEl: null, cropHandler: false })}>{t('Close')}</MenuItem>\n </Menu>\n </div>}\n {icon && !cropHandler ? <img src={icon} className={classes.image} alt=\"icon\" /> : null}\n\n {icon && crop && cropHandler ? <Cropper\n ref={this.cropperRef}\n className={classes.image}\n src={icon}\n initialAspectRatio={1}\n viewMode={1}\n guides={false}\n minCropBoxHeight={10}\n minCropBoxWidth={10}\n background={false}\n checkOrientation={false}\n /> : null}\n </div>\n </div>}\n </Dropzone>;\n }\n}\n\nUploadImage.defaultProps = {\n disabled: false,\n maxSize: 10 * 1024,\n icon: null,\n removeIconFunc: null,\n accept: 'image/*',\n error: false,\n onChange: base64 => console.log(base64),\n t: el => el,\n crop: false,\n};\n\nUploadImage.propTypes = {\n classes: PropTypes.object,\n maxSize: PropTypes.number,\n disabled: PropTypes.bool,\n crop: PropTypes.bool,\n error: PropTypes.bool,\n onChange: PropTypes.func,\n accept: PropTypes.string,\n t: PropTypes.func,\n};\n\nexport default withStyles(styles)(UploadImage);\n"],"mappings":"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"}
package/README.md CHANGED
@@ -641,6 +641,9 @@ If you still have questions, try to find an answer [here](https://mui.com/guides
641
641
  -->
642
642
 
643
643
  ## Changelog
644
+ ### 3.0.2 (2022-05-24)
645
+ * (bluefox) Added JsonConfigComponent
646
+
644
647
  ### 2.1.11 (2022-05-24)
645
648
  * (bluefox) Update file browser. It supports now the file changed events.
646
649
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@iobroker/adapter-react-v5",
3
- "version": "2.1.11",
3
+ "version": "3.0.2",
4
4
  "description": "React classes to develop admin interfaces for ioBroker with react.",
5
5
  "author": {
6
6
  "name": "bluefox",
@@ -31,6 +31,8 @@
31
31
  "@mui/icons-material": "^5.8.0",
32
32
  "@mui/material": "^5.8.1",
33
33
  "@mui/styles": "^5.8.0",
34
+ "@mui/x-date-pickers": "^5.0.0-alpha.4",
35
+ "react-cropper": "^2.1.8",
34
36
  "@sentry/browser": "^6.19.7",
35
37
  "@sentry/integrations": "^6.19.7",
36
38
  "@types/iobroker": "^4.0.3",