@bigbinary/neeto-image-uploader-frontend 2.0.2 → 2.2.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 (44) hide show
  1. package/app/javascript/src/translations/en.json +5 -0
  2. package/dist/AssetLibrary.js +10231 -0
  3. package/dist/AssetLibrary.js.map +1 -0
  4. package/dist/BasicImageUploader.js +66 -0
  5. package/dist/BasicImageUploader.js.map +1 -0
  6. package/dist/ImageUploader.js +228 -0
  7. package/dist/ImageUploader.js.map +1 -0
  8. package/dist/ImageWithFallback-7492935f.js +167 -0
  9. package/dist/ImageWithFallback-7492935f.js.map +1 -0
  10. package/dist/ImageWithFallback-e6b44c73.js +158 -0
  11. package/dist/ImageWithFallback-e6b44c73.js.map +1 -0
  12. package/dist/cjs/AssetLibrary.js +10303 -0
  13. package/dist/cjs/AssetLibrary.js.map +1 -0
  14. package/dist/cjs/BasicImageUploader.js +74 -0
  15. package/dist/cjs/BasicImageUploader.js.map +1 -0
  16. package/dist/cjs/ImageUploader.js +237 -0
  17. package/dist/cjs/ImageUploader.js.map +1 -0
  18. package/dist/cjs/hooks.js +24 -0
  19. package/dist/cjs/hooks.js.map +1 -0
  20. package/dist/cjs/index.js +95 -0
  21. package/dist/cjs/index.js.map +1 -0
  22. package/dist/hooks.js +14 -0
  23. package/dist/hooks.js.map +1 -0
  24. package/dist/index-7f064861.js +663 -0
  25. package/dist/index-7f064861.js.map +1 -0
  26. package/dist/index-b9963255.js +658 -0
  27. package/dist/index-b9963255.js.map +1 -0
  28. package/dist/index.js +81 -3910
  29. package/dist/index.js.map +1 -1
  30. package/dist/useImageUploader-36a03350.js +598 -0
  31. package/dist/useImageUploader-36a03350.js.map +1 -0
  32. package/dist/useImageUploader-550a5fdc.js +616 -0
  33. package/dist/useImageUploader-550a5fdc.js.map +1 -0
  34. package/dist/useProfileImageUpload-837e76b8.js +256 -0
  35. package/dist/useProfileImageUpload-837e76b8.js.map +1 -0
  36. package/dist/useProfileImageUpload-f0088c2a.js +263 -0
  37. package/dist/useProfileImageUpload-f0088c2a.js.map +1 -0
  38. package/dist/utils-88cce499.js +277 -0
  39. package/dist/utils-88cce499.js.map +1 -0
  40. package/dist/utils-96eacd77.js +248 -0
  41. package/dist/utils-96eacd77.js.map +1 -0
  42. package/package.json +30 -18
  43. package/dist/index.cjs.js +0 -3939
  44. package/dist/index.cjs.js.map +0 -1
@@ -0,0 +1,66 @@
1
+ import { _ as _defineProperty } from './index-b9963255.js';
2
+ import { _ as _objectWithoutProperties, i as isNilOrEmpty, l as isNotNilOrEmpty, m as IMAGE_WRAPPER_CLASSNAME } from './utils-96eacd77.js';
3
+ import 'react';
4
+ import classnames from 'classnames';
5
+ import { noop } from '@bigbinary/neeto-cist';
6
+ import Delete$1 from '@bigbinary/neeto-icons/Delete';
7
+ import Button from '@bigbinary/neetoui/Button';
8
+ import { I as ImageWithFallback, a as ImageDirectUpload } from './ImageWithFallback-e6b44c73.js';
9
+ import { jsx, jsxs } from 'react/jsx-runtime';
10
+ import '@bigbinary/neeto-commons-frontend/initializers';
11
+ import 'react-dropzone';
12
+ import 'i18next';
13
+ import '@bigbinary/neetoui/Toastr';
14
+ import 'ramda';
15
+ import '@bigbinary/neetoui/Typography';
16
+ import 'react-i18next';
17
+
18
+ var _excluded = ["src", "className", "imageFallbackProps", "onDrop", "isDisabled", "onRemove"];
19
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
20
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
21
+ var BasicImageUploader = function BasicImageUploader(_ref) {
22
+ var _ref$src = _ref.src,
23
+ src = _ref$src === void 0 ? "" : _ref$src,
24
+ _ref$className = _ref.className,
25
+ className = _ref$className === void 0 ? "" : _ref$className,
26
+ _ref$imageFallbackPro = _ref.imageFallbackProps,
27
+ imageFallbackProps = _ref$imageFallbackPro === void 0 ? {
28
+ alt: "Uplaoded Image",
29
+ className: "h-full w-full"
30
+ } : _ref$imageFallbackPro,
31
+ _ref$onDrop = _ref.onDrop,
32
+ onDrop = _ref$onDrop === void 0 ? noop : _ref$onDrop,
33
+ _ref$isDisabled = _ref.isDisabled,
34
+ isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
35
+ _ref$onRemove = _ref.onRemove,
36
+ onRemove = _ref$onRemove === void 0 ? noop : _ref$onRemove,
37
+ props = _objectWithoutProperties(_ref, _excluded);
38
+ return /*#__PURE__*/jsx("div", {
39
+ className: classnames(className, {
40
+ "cursor-pointer": true,
41
+ "cursor-not-allowed": isDisabled,
42
+ "opacity-70": isDisabled && isNilOrEmpty(src)
43
+ }),
44
+ children: isNotNilOrEmpty(src) ? /*#__PURE__*/jsxs("div", {
45
+ className: IMAGE_WRAPPER_CLASSNAME,
46
+ children: [/*#__PURE__*/jsx(ImageWithFallback, _objectSpread(_objectSpread({}, _objectSpread(_objectSpread({}, imageFallbackProps), {}, {
47
+ src: src
48
+ })), {}, {
49
+ "data-cy": "uploaded-image"
50
+ })), /*#__PURE__*/jsx(Button, {
51
+ className: "absolute right-3 top-3",
52
+ "data-cy": "basic-image-uploader-remove-button",
53
+ disabled: isDisabled,
54
+ icon: Delete$1,
55
+ size: "small",
56
+ onClick: onRemove
57
+ })]
58
+ }) : /*#__PURE__*/jsx(ImageDirectUpload, _objectSpread({}, _objectSpread(_objectSpread({}, props), {}, {
59
+ isDisabled: isDisabled,
60
+ onDrop: onDrop
61
+ })))
62
+ });
63
+ };
64
+
65
+ export { BasicImageUploader as default };
66
+ //# sourceMappingURL=BasicImageUploader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BasicImageUploader.js","sources":["../app/javascript/src/components/BasicImageUploader.jsx"],"sourcesContent":["import React from \"react\";\n\nimport classnames from \"classnames\";\nimport { noop } from \"neetocist\";\nimport { Delete } from \"neetoicons\";\nimport { Button } from \"neetoui\";\n\nimport ImageDirectUpload from \"./common/ImageDirectUpload\";\nimport ImageWithFallback from \"./common/ImageWithFallback\";\nimport { IMAGE_WRAPPER_CLASSNAME } from \"./constants\";\nimport { isNilOrEmpty, isNotNilOrEmpty } from \"./ImageEditor/utils\";\n\nconst BasicImageUploader = ({\n src = \"\",\n className = \"\",\n imageFallbackProps = { alt: \"Uplaoded Image\", className: \"h-full w-full\" },\n onDrop = noop,\n isDisabled = false,\n onRemove = noop,\n ...props\n}) => (\n <div\n className={classnames(className, {\n \"cursor-pointer\": true,\n \"cursor-not-allowed\": isDisabled,\n \"opacity-70\": isDisabled && isNilOrEmpty(src),\n })}\n >\n {isNotNilOrEmpty(src) ? (\n <div className={IMAGE_WRAPPER_CLASSNAME}>\n <ImageWithFallback\n {...{ ...imageFallbackProps, src }}\n data-cy=\"uploaded-image\"\n />\n <Button\n className=\"absolute right-3 top-3\"\n data-cy=\"basic-image-uploader-remove-button\"\n disabled={isDisabled}\n icon={Delete}\n size=\"small\"\n onClick={onRemove}\n />\n </div>\n ) : (\n <ImageDirectUpload {...{ ...props, isDisabled, onDrop }} />\n )}\n </div>\n);\n\nexport default BasicImageUploader;\n"],"names":["BasicImageUploader","_ref","_ref$src","src","_ref$className","className","_ref$imageFallbackPro","imageFallbackProps","alt","_ref$onDrop","onDrop","noop","_ref$isDisabled","isDisabled","_ref$onRemove","onRemove","props","_objectWithoutProperties","_excluded","_jsx","classnames","isNilOrEmpty","children","isNotNilOrEmpty","_jsxs","IMAGE_WRAPPER_CLASSNAME","ImageWithFallback","_objectSpread","Button","disabled","icon","Delete","size","onClick","ImageDirectUpload"],"mappings":";;;;;;;;;;;;;;;;;;;;AAYA,IAAMA,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAAC,IAAA,EAAA;AAAA,EAAA,IAAAC,QAAA,GAAAD,IAAA,CACtBE,GAAG;AAAHA,IAAAA,GAAG,GAAAD,QAAA,KAAG,KAAA,CAAA,GAAA,EAAE,GAAAA,QAAA;IAAAE,cAAA,GAAAH,IAAA,CACRI,SAAS;AAATA,IAAAA,SAAS,GAAAD,cAAA,KAAG,KAAA,CAAA,GAAA,EAAE,GAAAA,cAAA;IAAAE,qBAAA,GAAAL,IAAA,CACdM,kBAAkB;IAAlBA,kBAAkB,GAAAD,qBAAA,KAAG,KAAA,CAAA,GAAA;AAAEE,MAAAA,GAAG,EAAE,gBAAgB;AAAEH,MAAAA,SAAS,EAAE,eAAA;AAAgB,KAAC,GAAAC,qBAAA;IAAAG,WAAA,GAAAR,IAAA,CAC1ES,MAAM;AAANA,IAAAA,MAAM,GAAAD,WAAA,KAAGE,KAAAA,CAAAA,GAAAA,IAAI,GAAAF,WAAA;IAAAG,eAAA,GAAAX,IAAA,CACbY,UAAU;AAAVA,IAAAA,UAAU,GAAAD,eAAA,KAAG,KAAA,CAAA,GAAA,KAAK,GAAAA,eAAA;IAAAE,aAAA,GAAAb,IAAA,CAClBc,QAAQ;AAARA,IAAAA,QAAQ,GAAAD,aAAA,KAAGH,KAAAA,CAAAA,GAAAA,IAAI,GAAAG,aAAA;AACZE,IAAAA,KAAK,GAAAC,wBAAA,CAAAhB,IAAA,EAAAiB,SAAA,CAAA,CAAA;AAAA,EAAA,oBAERC,GAAA,CAAA,KAAA,EAAA;AACEd,IAAAA,SAAS,EAAEe,UAAU,CAACf,SAAS,EAAE;AAC/B,MAAA,gBAAgB,EAAE,IAAI;AACtB,MAAA,oBAAoB,EAAEQ,UAAU;AAChC,MAAA,YAAY,EAAEA,UAAU,IAAIQ,YAAY,CAAClB,GAAG,CAAA;AAC9C,KAAC,CAAE;AAAAmB,IAAAA,QAAA,EAEFC,eAAe,CAACpB,GAAG,CAAC,gBACnBqB,IAAA,CAAA,KAAA,EAAA;AAAKnB,MAAAA,SAAS,EAAEoB,uBAAwB;AAAAH,MAAAA,QAAA,EACtCH,cAAAA,GAAA,CAACO,iBAAiB,EAAAC,aAAA,CAAAA,aAAA,CAAAA,EAAAA,EAAAA,aAAA,CAAAA,aAAA,KACPpB,kBAAkB,CAAA,EAAA,EAAA,EAAA;AAAEJ,QAAAA,GAAG,EAAHA,GAAAA;AAAG,OAAA,CAAA,CAAA,EAAA,EAAA,EAAA;QAChC,SAAQ,EAAA,gBAAA;AAAgB,OAAA,CACzB,CAAC,eACFgB,GAAA,CAACS,MAAM,EAAA;AACLvB,QAAAA,SAAS,EAAC,wBAAwB;AAClC,QAAA,SAAA,EAAQ,oCAAoC;AAC5CwB,QAAAA,QAAQ,EAAEhB,UAAW;AACrBiB,QAAAA,IAAI,EAAEC,QAAO;AACbC,QAAAA,IAAI,EAAC,OAAO;AACZC,QAAAA,OAAO,EAAElB,QAAAA;AAAS,OACnB,CAAC,CAAA;AAAA,KACC,CAAC,gBAENI,GAAA,CAACe,iBAAiB,EAAAP,aAAA,CAAA,EAAA,EAAAA,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAUX,KAAK,CAAA,EAAA,EAAA,EAAA;AAAEH,MAAAA,UAAU,EAAVA,UAAU;AAAEH,MAAAA,MAAM,EAANA,MAAAA;KAAW,CAAA,CAAA,CAAA;AAC3D,GACE,CAAC,CAAA;AAAA;;;;"}
@@ -0,0 +1,228 @@
1
+ import { a as _slicedToArray, _ as _defineProperty, I as IS_DEVELOPMENT_OR_HEROKU_ENV } from './index-b9963255.js';
2
+ import { h as DEFAULT_UPLOAD_CONFIG, k as OPTION_KEYS, l as isNotNilOrEmpty, m as IMAGE_WRAPPER_CLASSNAME, _ as _objectWithoutProperties } from './utils-96eacd77.js';
3
+ import { useState, createElement } from 'react';
4
+ import classnames from 'classnames';
5
+ import { isPresent, noop } from '@bigbinary/neeto-cist';
6
+ import MenuHorizontal from '@bigbinary/neeto-icons/MenuHorizontal';
7
+ import Dropdown from '@bigbinary/neetoui/Dropdown';
8
+ import Toastr from '@bigbinary/neetoui/Toastr';
9
+ import { mergeRight } from 'ramda';
10
+ import { useTranslation } from 'react-i18next';
11
+ import { I as ImageWithFallback, a as ImageDirectUpload } from './ImageWithFallback-e6b44c73.js';
12
+ import Modal from './AssetLibrary.js';
13
+ import { u as useCreateBlob, e as useImageUploader } from './useImageUploader-36a03350.js';
14
+ import { jsxs, jsx } from 'react/jsx-runtime';
15
+ import '@bigbinary/neeto-commons-frontend/initializers';
16
+ import 'react-dropzone';
17
+ import 'i18next';
18
+ import '@bigbinary/neetoui/Button';
19
+ import '@bigbinary/neetoui/Typography';
20
+ import '@bigbinary/neetoui/Modal';
21
+ import '@bigbinary/neetoui/Tab';
22
+ import '@bigbinary/neetoui/Spinner';
23
+ import '@bigbinary/neeto-icons/LeftArrow';
24
+ import '@tanstack/react-query';
25
+ import 'axios';
26
+ import '@bigbinary/neeto-commons-frontend/react-utils';
27
+ import '@bigbinary/neeto-commons-frontend/utils';
28
+ import '@bigbinary/neetoui/Input';
29
+ import '@bigbinary/neetoui/Switch';
30
+ import '@bigbinary/neeto-icons/index';
31
+ import '@bigbinary/neeto-molecules/Container';
32
+ import '@bigbinary/neeto-molecules/Header';
33
+ import '@bigbinary/neeto-commons-frontend/constants';
34
+ import '@bigbinary/neetoui/Pane';
35
+ import '@bigbinary/neetoui/formik/ActionBlock';
36
+ import '@bigbinary/neetoui/formik/Form';
37
+ import '@bigbinary/neetoui/formik/Input';
38
+ import '@bigbinary/neetoui/formik/Select';
39
+ import '@bigbinary/neetoui/formik/Textarea';
40
+ import 'yup';
41
+ import 'formik';
42
+ import '@bigbinary/neeto-molecules/MoreDropdown';
43
+ import '@bigbinary/neetoui/Avatar';
44
+ import '@bigbinary/neetoui/Alert';
45
+ import '@bigbinary/neeto-molecules/PageLoader';
46
+ import '@bigbinary/neeto-molecules/SubHeader';
47
+ import '@bigbinary/neeto-molecules/TableWrapper';
48
+ import '@bigbinary/neetoui/Table';
49
+ import '@bigbinary/neetoui/NoData';
50
+ import '@bigbinary/neetoui/Tooltip';
51
+ import '@bigbinary/neeto-image-uploader-frontend';
52
+ import '@bigbinary/neeto-icons/ExternalLink';
53
+ import '@bigbinary/neetoui/Callout';
54
+ import '@bigbinary/neetoui/Label';
55
+ import '@bigbinary/neetoui/Radio';
56
+ import '@bigbinary/neeto-icons/Delete';
57
+ import '@bigbinary/neeto-commons-frontend/react-utils/withImmutableActions';
58
+ import 'zustand';
59
+ import 'zustand/shallow';
60
+ import '@bigbinary/neetoui/Checkbox';
61
+ import '@bigbinary/neeto-icons/Search';
62
+ import '@bigbinary/neeto-icons/Down';
63
+ import '@bigbinary/neeto-icons/Up';
64
+ import '@bigbinary/neeto-filters-frontend';
65
+ import '@bigbinary/neeto-molecules/Columns';
66
+ import 'react-router-dom';
67
+ import 'util';
68
+ import '@bigbinary/neetoui/Tag';
69
+ import '@bigbinary/neeto-icons/Right';
70
+ import '@bigbinary/neeto-icons/Info';
71
+ import '@bigbinary/neeto-commons-frontend/react-utils/useFetchNeetoApps';
72
+ import '@bigbinary/neetoui/formik/Switch';
73
+ import '@bigbinary/neetoui/formik/MultiEmailInput';
74
+ import '@bigbinary/neetoui/formik/Radio';
75
+ import '@bigbinary/neeto-icons/Warning';
76
+ import '@bigbinary/neetoui/formik/Checkbox';
77
+ import '@bigbinary/neeto-icons/UserCircle';
78
+ import '@rails/activestorage';
79
+
80
+ var _excluded = ["key", "label"];
81
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
82
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
83
+ var Menu = Dropdown.Menu,
84
+ MenuItem = Dropdown.MenuItem;
85
+ var ImageUploader = function ImageUploader(_ref) {
86
+ var _ref$onUploadComplete = _ref.onUploadComplete,
87
+ onUploadComplete = _ref$onUploadComplete === void 0 ? noop : _ref$onUploadComplete,
88
+ _ref$className = _ref.className,
89
+ className = _ref$className === void 0 ? "" : _ref$className,
90
+ _ref$src = _ref.src,
91
+ src = _ref$src === void 0 ? "" : _ref$src,
92
+ _ref$uploadConfig = _ref.uploadConfig,
93
+ uploadConfig = _ref$uploadConfig === void 0 ? {} : _ref$uploadConfig,
94
+ _ref$fixedAspectRatio = _ref.fixedAspectRatio,
95
+ fixedAspectRatio = _ref$fixedAspectRatio === void 0 ? {} : _ref$fixedAspectRatio;
96
+ var _useState = useState(false),
97
+ _useState2 = _slicedToArray(_useState, 2),
98
+ isAssetLibraryOpen = _useState2[0],
99
+ setIsAssetLibraryOpen = _useState2[1];
100
+ var _useState3 = useState({
101
+ url: src
102
+ }),
103
+ _useState4 = _slicedToArray(_useState3, 2),
104
+ image = _useState4[0],
105
+ setImage = _useState4[1];
106
+ var _useTranslation = useTranslation(),
107
+ t = _useTranslation.t;
108
+ var _useCreateBlob = useCreateBlob(),
109
+ createBlob = _useCreateBlob.mutate;
110
+ var uploadConfigWithDefaults = mergeRight(DEFAULT_UPLOAD_CONFIG, uploadConfig);
111
+ var handleDelete = function handleDelete() {
112
+ setImage({});
113
+ onChange({
114
+ url: "",
115
+ signedId: "",
116
+ key: "",
117
+ filename: "",
118
+ size: "",
119
+ type: ""
120
+ });
121
+ };
122
+ var onChange = function onChange(file) {
123
+ return onUploadComplete(file);
124
+ };
125
+ var handleSuccess = function handleSuccess(attachedImage) {
126
+ setImage(mergeRight(image, {
127
+ url: attachedImage.metadata.url
128
+ }));
129
+ onChange({
130
+ filename: attachedImage.filename,
131
+ key: attachedImage.key,
132
+ url: attachedImage.blobUrl,
133
+ signedId: attachedImage.signedId,
134
+ size: attachedImage.byteSize,
135
+ type: attachedImage.contentType
136
+ });
137
+ };
138
+ var handleImageSelectionFromLibrary = function handleImageSelectionFromLibrary(image) {
139
+ setImage(image);
140
+ onChange(image);
141
+ };
142
+ var handleUploadComplete = function handleUploadComplete(image) {
143
+ if (IS_DEVELOPMENT_OR_HEROKU_ENV) {
144
+ handleSuccess(mergeRight(image, {
145
+ metadata: {
146
+ url: image.url
147
+ }
148
+ }));
149
+ return;
150
+ }
151
+ var payload = {
152
+ filename: image.name,
153
+ byte_size: image.size,
154
+ content_type: image.fileType,
155
+ checksum: image.fileId,
156
+ metadata: image,
157
+ service_name: "imagekitio"
158
+ };
159
+ createBlob(payload, {
160
+ onSuccess: handleSuccess,
161
+ onError: Toastr.error
162
+ });
163
+ };
164
+ var _useImageUploader = useImageUploader({
165
+ onUploadComplete: handleUploadComplete
166
+ }),
167
+ uploadFile = _useImageUploader.uploadFile;
168
+ var options = [{
169
+ key: OPTION_KEYS.asset,
170
+ label: t("neetoImageUploader.imageUpload.imageLibrary"),
171
+ onClick: function onClick() {
172
+ return setIsAssetLibraryOpen(true);
173
+ },
174
+ "data-cy": "image-uploader-open-image-library-button"
175
+ }, {
176
+ key: OPTION_KEYS.remove,
177
+ label: t("neetoImageUploader.imageUpload.remove"),
178
+ onClick: handleDelete,
179
+ "data-cy": "image-uploader-remove-button"
180
+ }];
181
+ return /*#__PURE__*/jsxs("div", {
182
+ className: classnames(className, {
183
+ "cursor-pointer": true
184
+ }),
185
+ children: [isNotNilOrEmpty(image.url) ? /*#__PURE__*/jsxs("div", {
186
+ className: IMAGE_WRAPPER_CLASSNAME,
187
+ "data-cy": "image-uploader-wrapper",
188
+ children: [/*#__PURE__*/jsx(ImageWithFallback, {
189
+ className: "h-full w-full",
190
+ "data-cy": "uploaded-image",
191
+ src: image.url
192
+ }), /*#__PURE__*/jsx(Dropdown, {
193
+ buttonProps: {
194
+ className: "absolute right-3 top-3"
195
+ },
196
+ buttonSize: "small",
197
+ buttonStyle: "primary",
198
+ icon: MenuHorizontal,
199
+ children: /*#__PURE__*/jsx(Menu, {
200
+ children: options.map(function (_ref2) {
201
+ var key = _ref2.key,
202
+ label = _ref2.label,
203
+ otherProps = _objectWithoutProperties(_ref2, _excluded);
204
+ return /*#__PURE__*/createElement(MenuItem.Button, _objectSpread(_objectSpread({}, otherProps), {}, {
205
+ key: key
206
+ }), label);
207
+ })
208
+ })
209
+ })]
210
+ }) : /*#__PURE__*/jsx(ImageDirectUpload, {
211
+ setIsAssetLibraryOpen: setIsAssetLibraryOpen,
212
+ isDisabled: isPresent(fixedAspectRatio),
213
+ uploadConfig: uploadConfigWithDefaults,
214
+ onDrop: uploadFile
215
+ }), /*#__PURE__*/jsx(Modal, {
216
+ fixedAspectRatio: fixedAspectRatio,
217
+ isOpen: isAssetLibraryOpen,
218
+ uploadConfig: uploadConfigWithDefaults,
219
+ onClose: function onClose() {
220
+ return setIsAssetLibraryOpen(false);
221
+ },
222
+ onUploadComplete: handleImageSelectionFromLibrary
223
+ })]
224
+ });
225
+ };
226
+
227
+ export { ImageUploader as default };
228
+ //# sourceMappingURL=ImageUploader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageUploader.js","sources":["../app/javascript/src/components/ImageUploader/index.jsx"],"sourcesContent":["import React, { useState } from \"react\";\n\nimport classnames from \"classnames\";\nimport { isPresent, noop } from \"neetocist\";\nimport { MenuHorizontal } from \"neetoicons\";\nimport { Dropdown, Toastr } from \"neetoui\";\nimport { mergeRight } from \"ramda\";\nimport { useTranslation } from \"react-i18next\";\n\nimport ImageDirectUpload from \"components/common/ImageDirectUpload\";\nimport ImageWithFallback from \"components/common/ImageWithFallback\";\nimport { IMAGE_WRAPPER_CLASSNAME } from \"components/constants\";\nimport { isNotNilOrEmpty } from \"components/ImageEditor/utils\";\nimport AssetLibrary from \"components/Modal\";\nimport { useCreateBlob } from \"hooks/useDirectUploads\";\nimport useImageUploader from \"hooks/useImageUploader\";\nimport { IS_DEVELOPMENT_OR_HEROKU_ENV } from \"src/constants\";\n\nimport { DEFAULT_UPLOAD_CONFIG, OPTION_KEYS } from \"./constants\";\n\nconst { Menu, MenuItem } = Dropdown;\n\nconst ImageUploader = ({\n onUploadComplete = noop,\n className = \"\",\n src = \"\",\n uploadConfig = {},\n fixedAspectRatio = {},\n}) => {\n const [isAssetLibraryOpen, setIsAssetLibraryOpen] = useState(false);\n const [image, setImage] = useState({ url: src });\n\n const { t } = useTranslation();\n\n const { mutate: createBlob } = useCreateBlob();\n\n const uploadConfigWithDefaults = mergeRight(\n DEFAULT_UPLOAD_CONFIG,\n uploadConfig\n );\n\n const handleDelete = () => {\n setImage({});\n onChange({\n url: \"\",\n signedId: \"\",\n key: \"\",\n filename: \"\",\n size: \"\",\n type: \"\",\n });\n };\n\n const onChange = file => onUploadComplete(file);\n\n const handleSuccess = attachedImage => {\n setImage(mergeRight(image, { url: attachedImage.metadata.url }));\n onChange({\n filename: attachedImage.filename,\n key: attachedImage.key,\n url: attachedImage.blobUrl,\n signedId: attachedImage.signedId,\n size: attachedImage.byteSize,\n type: attachedImage.contentType,\n });\n };\n\n const handleImageSelectionFromLibrary = image => {\n setImage(image);\n onChange(image);\n };\n\n const handleUploadComplete = image => {\n if (IS_DEVELOPMENT_OR_HEROKU_ENV) {\n handleSuccess(mergeRight(image, { metadata: { url: image.url } }));\n\n return;\n }\n\n const payload = {\n filename: image.name,\n byte_size: image.size,\n content_type: image.fileType,\n checksum: image.fileId,\n metadata: image,\n service_name: \"imagekitio\",\n };\n\n createBlob(payload, {\n onSuccess: handleSuccess,\n onError: Toastr.error,\n });\n };\n\n const { uploadFile } = useImageUploader({\n onUploadComplete: handleUploadComplete,\n });\n\n const options = [\n {\n key: OPTION_KEYS.asset,\n label: t(\"neetoImageUploader.imageUpload.imageLibrary\"),\n onClick: () => setIsAssetLibraryOpen(true),\n \"data-cy\": \"image-uploader-open-image-library-button\",\n },\n {\n key: OPTION_KEYS.remove,\n label: t(\"neetoImageUploader.imageUpload.remove\"),\n onClick: handleDelete,\n \"data-cy\": \"image-uploader-remove-button\",\n },\n ];\n\n return (\n <div className={classnames(className, { \"cursor-pointer\": true })}>\n {isNotNilOrEmpty(image.url) ? (\n <div\n className={IMAGE_WRAPPER_CLASSNAME}\n data-cy=\"image-uploader-wrapper\"\n >\n <ImageWithFallback\n className=\"h-full w-full\"\n data-cy=\"uploaded-image\"\n src={image.url}\n />\n <Dropdown\n buttonProps={{ className: \"absolute right-3 top-3\" }}\n buttonSize=\"small\"\n buttonStyle=\"primary\"\n icon={MenuHorizontal}\n >\n <Menu>\n {options.map(({ key, label, ...otherProps }) => (\n <MenuItem.Button {...otherProps} key={key}>\n {label}\n </MenuItem.Button>\n ))}\n </Menu>\n </Dropdown>\n </div>\n ) : (\n <ImageDirectUpload\n {...{ setIsAssetLibraryOpen }}\n isDisabled={isPresent(fixedAspectRatio)}\n uploadConfig={uploadConfigWithDefaults}\n onDrop={uploadFile}\n />\n )}\n <AssetLibrary\n {...{ fixedAspectRatio }}\n isOpen={isAssetLibraryOpen}\n uploadConfig={uploadConfigWithDefaults}\n onClose={() => setIsAssetLibraryOpen(false)}\n onUploadComplete={handleImageSelectionFromLibrary}\n />\n </div>\n );\n};\n\nexport default ImageUploader;\n"],"names":["Menu","Dropdown","MenuItem","ImageUploader","_ref","_ref$onUploadComplete","onUploadComplete","noop","_ref$className","className","_ref$src","src","_ref$uploadConfig","uploadConfig","_ref$fixedAspectRatio","fixedAspectRatio","_useState","useState","_useState2","_slicedToArray","isAssetLibraryOpen","setIsAssetLibraryOpen","_useState3","url","_useState4","image","setImage","_useTranslation","useTranslation","t","_useCreateBlob","useCreateBlob","createBlob","mutate","uploadConfigWithDefaults","mergeRight","DEFAULT_UPLOAD_CONFIG","handleDelete","onChange","signedId","key","filename","size","type","file","handleSuccess","attachedImage","metadata","blobUrl","byteSize","contentType","handleImageSelectionFromLibrary","handleUploadComplete","IS_DEVELOPMENT_OR_HEROKU_ENV","payload","name","byte_size","content_type","fileType","checksum","fileId","service_name","onSuccess","onError","Toastr","error","_useImageUploader","useImageUploader","uploadFile","options","OPTION_KEYS","asset","label","onClick","remove","_jsxs","classnames","children","isNotNilOrEmpty","IMAGE_WRAPPER_CLASSNAME","_jsx","ImageWithFallback","buttonProps","buttonSize","buttonStyle","icon","MenuHorizontal","map","_ref2","otherProps","_objectWithoutProperties","_excluded","_createElement","Button","_objectSpread","ImageDirectUpload","isDisabled","isPresent","onDrop","AssetLibrary","isOpen","onClose"],"mappings":"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"}
@@ -0,0 +1,167 @@
1
+ 'use strict';
2
+
3
+ var index = require('./index-7f064861.js');
4
+ var require$$0 = require('react');
5
+ var classnames = require('classnames');
6
+ var neetoCist = require('@bigbinary/neeto-cist');
7
+ var Button = require('@bigbinary/neetoui/Button');
8
+ var Typography = require('@bigbinary/neetoui/Typography');
9
+ var ramda = require('ramda');
10
+ var reactI18next = require('react-i18next');
11
+ var utils = require('./utils-88cce499.js');
12
+ var jsxRuntime = require('react/jsx-runtime');
13
+
14
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
15
+
16
+ var classnames__default = /*#__PURE__*/_interopDefaultLegacy(classnames);
17
+ var Button__default = /*#__PURE__*/_interopDefaultLegacy(Button);
18
+ var Typography__default = /*#__PURE__*/_interopDefaultLegacy(Typography);
19
+
20
+ var getAllowedTypes = function getAllowedTypes(uploadConfig) {
21
+ return ramda.pipe(ramda.values, ramda.flatten, ramda.map(function (extension) {
22
+ return extension.slice(1);
23
+ }), ramda.map(ramda.toUpper), ramda.join(", "))(uploadConfig.allowedImageTypes);
24
+ };
25
+
26
+ var ProgressBar = function ProgressBar(_ref) {
27
+ var _ref$progressPercenta = _ref.progressPercentage,
28
+ progressPercentage = _ref$progressPercenta === void 0 ? 0 : _ref$progressPercenta,
29
+ progressValue = _ref.progressValue;
30
+ return /*#__PURE__*/jsxRuntime.jsx("div", {
31
+ className: "neeto-ui-border-primary-600 hover:neeto-ui-bg-gray-100 neeto-ui-rounded-lg flex h-full cursor-pointer items-center justify-center gap-3 border border-dashed p-5 transition-all duration-300 ease-in-out",
32
+ children: /*#__PURE__*/jsxRuntime.jsx("div", {
33
+ className: "neeto-ui-bg-gray-200 neeto-ui-rounded-full w-full overflow-hidden dark:bg-gray-700",
34
+ children: /*#__PURE__*/jsxRuntime.jsx("div", {
35
+ className: "neeto-ui-bg-primary-600 text-2xs neeto-ui-text-primary-100 neeto-ui-rounded-full flex h-3 animate-pulse items-center justify-center font-medium leading-none transition-all duration-300 ease-in-out",
36
+ "data-cy": "neeto-image-uploader-progress-bar",
37
+ style: {
38
+ width: "".concat(progressPercentage, "%")
39
+ },
40
+ children: progressValue
41
+ })
42
+ })
43
+ });
44
+ };
45
+
46
+ function ownKeys$2(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
47
+ function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$2(Object(t), !0).forEach(function (r) { index._defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$2(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
48
+ var ImageDirectUpload = function ImageDirectUpload(_ref) {
49
+ var _ref$uploadConfig = _ref.uploadConfig,
50
+ uploadConfig = _ref$uploadConfig === void 0 ? utils.DEFAULT_UPLOAD_CONFIG : _ref$uploadConfig,
51
+ _ref$onDrop = _ref.onDrop,
52
+ onDrop = _ref$onDrop === void 0 ? neetoCist.noop : _ref$onDrop,
53
+ _ref$isDisabled = _ref.isDisabled,
54
+ isDisabled = _ref$isDisabled === void 0 ? false : _ref$isDisabled,
55
+ setIsAssetLibraryOpen = _ref.setIsAssetLibraryOpen;
56
+ var _useUploadDropzone = utils.useUploadDropzone({
57
+ uploadConfig: uploadConfig,
58
+ onDrop: onDrop
59
+ }),
60
+ getRootProps = _useUploadDropzone.getRootProps,
61
+ getInputProps = _useUploadDropzone.getInputProps,
62
+ isDragActive = _useUploadDropzone.isDragActive,
63
+ uploadProgress = _useUploadDropzone.uploadProgress;
64
+ var shouldShowProgress = !!(uploadProgress && !ramda.equals(uploadProgress, 1));
65
+ return shouldShowProgress ? /*#__PURE__*/jsxRuntime.jsx(ProgressBar, {
66
+ progressPercentage: uploadProgress,
67
+ progressValue: "".concat(uploadProgress, "%")
68
+ }) : /*#__PURE__*/jsxRuntime.jsx("div", _objectSpread$2(_objectSpread$2({}, getRootProps()), {}, {
69
+ className: classnames__default["default"](utils.DROPZONE_ROOT_DIV_CLASSNAME, {
70
+ "neeto-ui-border-gray-300": !isDragActive,
71
+ "neeto-ui-border-gray-700": isDragActive
72
+ }),
73
+ children: /*#__PURE__*/jsxRuntime.jsxs("div", {
74
+ className: "flex flex-col space-y-1",
75
+ children: [!isDisabled && /*#__PURE__*/jsxRuntime.jsx(Typography__default["default"], {
76
+ className: "neeto-ui-text-gray-800 text-center leading-4",
77
+ style: "body2",
78
+ children: /*#__PURE__*/jsxRuntime.jsx(reactI18next.Trans, {
79
+ i18nKey: "neetoImageUploader.imageUpload.dragAndDropOrBrowseFile",
80
+ components: {
81
+ span: /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
82
+ "data-cy": "neeto-image-uploader-browse-text",
83
+ style: "link"
84
+ })
85
+ }
86
+ })
87
+ }), setIsAssetLibraryOpen && /*#__PURE__*/jsxRuntime.jsx(Typography__default["default"], {
88
+ className: "text-center leading-4",
89
+ style: "body2",
90
+ onClick: function onClick(e) {
91
+ e.stopPropagation();
92
+ setIsAssetLibraryOpen(true);
93
+ },
94
+ children: /*#__PURE__*/jsxRuntime.jsx(reactI18next.Trans, {
95
+ i18nKey: "neetoImageUploader.imageUpload.selectImagefromImageLibrary",
96
+ components: {
97
+ span: /*#__PURE__*/jsxRuntime.jsx(Button__default["default"], {
98
+ "data-cy": "open-asset-library-button",
99
+ style: "link"
100
+ })
101
+ }
102
+ })
103
+ }), /*#__PURE__*/jsxRuntime.jsx("input", _objectSpread$2(_objectSpread$2({}, getInputProps()), {}, {
104
+ "data-cy": "neeto-image-uploader-file-input",
105
+ disabled: isDisabled
106
+ })), /*#__PURE__*/jsxRuntime.jsx(Typography__default["default"], {
107
+ className: "neeto-ui-text-gray-700 text-center leading-4",
108
+ "data-cy": "neeto-image-uploader-restriction-message",
109
+ lineHeight: "snug",
110
+ style: "nano",
111
+ children: /*#__PURE__*/jsxRuntime.jsx(reactI18next.Trans, {
112
+ i18nKey: "neetoImageUploader.imageUpload.restrictionMessage",
113
+ values: {
114
+ fileTypes: getAllowedTypes(uploadConfig),
115
+ size: uploadConfig === null || uploadConfig === void 0 ? void 0 : uploadConfig.maxImageSize
116
+ }
117
+ })
118
+ })]
119
+ })
120
+ }));
121
+ };
122
+
123
+ var _excluded$1 = ["className"];
124
+ function ownKeys$1(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
125
+ function _objectSpread$1(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys$1(Object(t), !0).forEach(function (r) { index._defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys$1(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
126
+ var ImagePlaceholder = function ImagePlaceholder(_ref) {
127
+ var _ref$className = _ref.className,
128
+ className = _ref$className === void 0 ? "" : _ref$className,
129
+ props = utils._objectWithoutProperties(_ref, _excluded$1);
130
+ return /*#__PURE__*/jsxRuntime.jsx("div", _objectSpread$1({
131
+ className: classnames__default["default"]("neeto-ui-bg-gray-200", index._defineProperty({}, className, className))
132
+ }, props));
133
+ };
134
+
135
+ var _excluded = ["src", "className", "fallback"];
136
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
137
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { index._defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
138
+ var ImageWithFallback = function ImageWithFallback(_ref) {
139
+ var src = _ref.src,
140
+ _ref$className = _ref.className,
141
+ className = _ref$className === void 0 ? "h-full w-full" : _ref$className,
142
+ _ref$fallback = _ref.fallback,
143
+ Fallback = _ref$fallback === void 0 ? ImagePlaceholder : _ref$fallback,
144
+ props = utils._objectWithoutProperties(_ref, _excluded);
145
+ var _useState = require$$0.useState(false),
146
+ _useState2 = index._slicedToArray(_useState, 2),
147
+ isLoaded = _useState2[0],
148
+ setIsLoaded = _useState2[1];
149
+ require$$0.useEffect(function () {
150
+ var img = new Image();
151
+ img.onload = function () {
152
+ setIsLoaded(true);
153
+ };
154
+ img.src = src;
155
+ }, [src]);
156
+ return isLoaded ? /*#__PURE__*/jsxRuntime.jsx("img", _objectSpread(_objectSpread({}, _objectSpread({
157
+ src: src
158
+ }, props)), {}, {
159
+ className: "h-full w-auto object-contain"
160
+ })) : /*#__PURE__*/jsxRuntime.jsx(Fallback, _objectSpread({}, _objectSpread({
161
+ className: className
162
+ }, props)));
163
+ };
164
+
165
+ exports.ImageDirectUpload = ImageDirectUpload;
166
+ exports.ImageWithFallback = ImageWithFallback;
167
+ //# sourceMappingURL=ImageWithFallback-7492935f.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageWithFallback-7492935f.js","sources":["../app/javascript/src/components/ImageUploader/utils.js","../app/javascript/src/components/common/ProgressBar.jsx","../app/javascript/src/components/common/ImageDirectUpload.jsx","../app/javascript/src/components/common/ImagePlaceholder.jsx","../app/javascript/src/components/common/ImageWithFallback.jsx"],"sourcesContent":["import { flatten, pipe, join, map, toUpper, values } from \"ramda\";\n\nexport const getAllowedTypes = uploadConfig =>\n pipe(\n values,\n flatten,\n map(extension => extension.slice(1)),\n map(toUpper),\n join(\", \")\n )(uploadConfig.allowedImageTypes);\n","import React from \"react\";\n\nconst ProgressBar = ({ progressPercentage = 0, progressValue }) => (\n <div className=\"neeto-ui-border-primary-600 hover:neeto-ui-bg-gray-100 neeto-ui-rounded-lg flex h-full cursor-pointer items-center justify-center gap-3 border border-dashed p-5 transition-all duration-300 ease-in-out\">\n <div className=\"neeto-ui-bg-gray-200 neeto-ui-rounded-full w-full overflow-hidden dark:bg-gray-700\">\n <div\n className=\"neeto-ui-bg-primary-600 text-2xs neeto-ui-text-primary-100 neeto-ui-rounded-full flex h-3 animate-pulse items-center justify-center font-medium leading-none transition-all duration-300 ease-in-out\"\n data-cy=\"neeto-image-uploader-progress-bar\"\n style={{ width: `${progressPercentage}%` }}\n >\n {progressValue}\n </div>\n </div>\n </div>\n);\n\nexport default ProgressBar;\n","import React from \"react\";\n\nimport classnames from \"classnames\";\nimport { noop } from \"neetocist\";\nimport { Button, Typography } from \"neetoui\";\nimport { equals } from \"ramda\";\nimport { Trans } from \"react-i18next\";\n\nimport { DEFAULT_UPLOAD_CONFIG } from \"components/ImageUploader/constants\";\nimport { getAllowedTypes } from \"components/ImageUploader/utils\";\nimport useUploadDropzone from \"hooks/useUploadDropzone\";\n\nimport { DROPZONE_ROOT_DIV_CLASSNAME } from \"./constants\";\nimport ProgressBar from \"./ProgressBar\";\n\nconst ImageDirectUpload = ({\n uploadConfig = DEFAULT_UPLOAD_CONFIG,\n onDrop = noop,\n isDisabled = false,\n setIsAssetLibraryOpen,\n}) => {\n const { getRootProps, getInputProps, isDragActive, uploadProgress } =\n useUploadDropzone({ uploadConfig, onDrop });\n\n const shouldShowProgress = !!(uploadProgress && !equals(uploadProgress, 1));\n\n return shouldShowProgress ? (\n <ProgressBar\n progressPercentage={uploadProgress}\n progressValue={`${uploadProgress}%`}\n />\n ) : (\n <div\n {...getRootProps()}\n className={classnames(DROPZONE_ROOT_DIV_CLASSNAME, {\n \"neeto-ui-border-gray-300\": !isDragActive,\n \"neeto-ui-border-gray-700\": isDragActive,\n })}\n >\n <div className=\"flex flex-col space-y-1\">\n {!isDisabled && (\n <Typography\n className=\"neeto-ui-text-gray-800 text-center leading-4\"\n style=\"body2\"\n >\n <Trans\n i18nKey=\"neetoImageUploader.imageUpload.dragAndDropOrBrowseFile\"\n components={{\n span: (\n <Button\n data-cy=\"neeto-image-uploader-browse-text\"\n style=\"link\"\n />\n ),\n }}\n />\n </Typography>\n )}\n {setIsAssetLibraryOpen && (\n <Typography\n className=\"text-center leading-4\"\n style=\"body2\"\n onClick={e => {\n e.stopPropagation();\n setIsAssetLibraryOpen(true);\n }}\n >\n <Trans\n i18nKey=\"neetoImageUploader.imageUpload.selectImagefromImageLibrary\"\n components={{\n span: (\n <Button data-cy=\"open-asset-library-button\" style=\"link\" />\n ),\n }}\n />\n </Typography>\n )}\n <input\n {...getInputProps()}\n data-cy=\"neeto-image-uploader-file-input\"\n disabled={isDisabled}\n />\n <Typography\n className=\"neeto-ui-text-gray-700 text-center leading-4\"\n data-cy=\"neeto-image-uploader-restriction-message\"\n lineHeight=\"snug\"\n style=\"nano\"\n >\n <Trans\n i18nKey=\"neetoImageUploader.imageUpload.restrictionMessage\"\n values={{\n fileTypes: getAllowedTypes(uploadConfig),\n size: uploadConfig?.maxImageSize,\n }}\n />\n </Typography>\n </div>\n </div>\n );\n};\n\nexport default ImageDirectUpload;\n","import React from \"react\";\n\nimport classnames from \"classnames\";\n\nconst ImagePlaceholder = ({ className = \"\", ...props }) => (\n <div\n className={classnames(\"neeto-ui-bg-gray-200\", {\n [className]: className,\n })}\n {...props}\n />\n);\n\nexport default ImagePlaceholder;\n","import React, { useEffect, useState } from \"react\";\n\nimport ImagePlaceholder from \"./ImagePlaceholder\";\n\nconst ImageWithFallback = ({\n src,\n className = \"h-full w-full\",\n fallback: Fallback = ImagePlaceholder,\n ...props\n}) => {\n const [isLoaded, setIsLoaded] = useState(false);\n\n useEffect(() => {\n const img = new Image();\n img.onload = () => {\n setIsLoaded(true);\n };\n img.src = src;\n }, [src]);\n\n return isLoaded ? (\n <img {...{ src, ...props }} className=\"h-full w-auto object-contain\" />\n ) : (\n <Fallback {...{ className, ...props }} />\n );\n};\n\nexport default ImageWithFallback;\n"],"names":["getAllowedTypes","uploadConfig","pipe","values","flatten","map","extension","slice","toUpper","join","allowedImageTypes","ProgressBar","_ref","_ref$progressPercenta","progressPercentage","progressValue","_jsx","className","children","style","width","concat","ImageDirectUpload","_ref$uploadConfig","DEFAULT_UPLOAD_CONFIG","_ref$onDrop","onDrop","noop","_ref$isDisabled","isDisabled","setIsAssetLibraryOpen","_useUploadDropzone","useUploadDropzone","getRootProps","getInputProps","isDragActive","uploadProgress","shouldShowProgress","equals","_objectSpread","classnames","DROPZONE_ROOT_DIV_CLASSNAME","_jsxs","Typography","Trans","i18nKey","components","span","Button","onClick","e","stopPropagation","disabled","lineHeight","fileTypes","size","maxImageSize","ImagePlaceholder","_ref$className","props","_objectWithoutProperties","_excluded","_defineProperty","ImageWithFallback","src","_ref$fallback","fallback","Fallback","_useState","useState","_useState2","_slicedToArray","isLoaded","setIsLoaded","useEffect","img","Image","onload"],"mappings":"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"}