@bigbinary/neeto-image-uploader-frontend 2.3.33 → 2.3.35

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 (64) hide show
  1. package/app/javascript/src/translations/ar.json +7 -3
  2. package/app/javascript/src/translations/bg.json +7 -3
  3. package/app/javascript/src/translations/ca.json +7 -3
  4. package/app/javascript/src/translations/cs.json +7 -3
  5. package/app/javascript/src/translations/da.json +7 -3
  6. package/app/javascript/src/translations/de.json +7 -3
  7. package/app/javascript/src/translations/es-MX.json +7 -3
  8. package/app/javascript/src/translations/es.json +7 -3
  9. package/app/javascript/src/translations/et.json +7 -3
  10. package/app/javascript/src/translations/fi.json +7 -3
  11. package/app/javascript/src/translations/fil.json +7 -3
  12. package/app/javascript/src/translations/fr.json +7 -3
  13. package/app/javascript/src/translations/he.json +7 -3
  14. package/app/javascript/src/translations/hi.json +7 -3
  15. package/app/javascript/src/translations/hr.json +7 -3
  16. package/app/javascript/src/translations/id.json +7 -3
  17. package/app/javascript/src/translations/it.json +7 -3
  18. package/app/javascript/src/translations/ja.json +7 -3
  19. package/app/javascript/src/translations/ko.json +7 -3
  20. package/app/javascript/src/translations/nl.json +7 -3
  21. package/app/javascript/src/translations/pl.json +7 -3
  22. package/app/javascript/src/translations/pt-BR.json +7 -3
  23. package/app/javascript/src/translations/pt.json +7 -3
  24. package/app/javascript/src/translations/ro.json +7 -3
  25. package/app/javascript/src/translations/ru.json +7 -3
  26. package/app/javascript/src/translations/sk.json +7 -3
  27. package/app/javascript/src/translations/sl.json +7 -3
  28. package/app/javascript/src/translations/sv.json +7 -3
  29. package/app/javascript/src/translations/th.json +7 -3
  30. package/app/javascript/src/translations/tr.json +7 -3
  31. package/app/javascript/src/translations/uk.json +7 -3
  32. package/app/javascript/src/translations/vi.json +7 -3
  33. package/app/javascript/src/translations/zh-CN.json +7 -3
  34. package/app/javascript/src/translations/zh-TW.json +7 -3
  35. package/dist/AssetLibrary.js +2 -2
  36. package/dist/BasicImageUploader.js +4 -4
  37. package/dist/BasicImageUploader.js.map +1 -1
  38. package/dist/ImageForm.js +13 -13
  39. package/dist/ImageForm.js.map +1 -1
  40. package/dist/ImageUploader.js +7 -7
  41. package/dist/ImageUploader.js.map +1 -1
  42. package/dist/cjs/AssetLibrary.js +2 -2
  43. package/dist/cjs/BasicImageUploader.js +4 -4
  44. package/dist/cjs/BasicImageUploader.js.map +1 -1
  45. package/dist/cjs/ImageForm.js +13 -13
  46. package/dist/cjs/ImageForm.js.map +1 -1
  47. package/dist/cjs/ImageUploader.js +7 -7
  48. package/dist/cjs/ImageUploader.js.map +1 -1
  49. package/dist/cjs/index.js +2 -2
  50. package/dist/{index-ph4UeLLc.js → index-Bd796sPX.js} +28 -18
  51. package/dist/index-Bd796sPX.js.map +1 -0
  52. package/dist/{index-BH0wqq_n.js → index-oS3UYUfo.js} +28 -18
  53. package/dist/index-oS3UYUfo.js.map +1 -0
  54. package/dist/index.js +2 -2
  55. package/dist/{utils-DMz4D2SB.js → utils-BjNaSuOu.js} +13 -9
  56. package/dist/utils-BjNaSuOu.js.map +1 -0
  57. package/dist/{utils-CVOvfMWy.js → utils-Um4BP0zx.js} +13 -9
  58. package/dist/utils-Um4BP0zx.js.map +1 -0
  59. package/package.json +15 -15
  60. package/types.d.ts +1 -1
  61. package/dist/index-BH0wqq_n.js.map +0 -1
  62. package/dist/index-ph4UeLLc.js.map +0 -1
  63. package/dist/utils-CVOvfMWy.js.map +0 -1
  64. package/dist/utils-DMz4D2SB.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ImageUploader.js","sources":["../../app/javascript/src/components/ImageUploader/index.jsx"],"sourcesContent":["import { useState } from \"react\";\n\nimport classnames from \"classnames\";\nimport { isPresent, noop } from \"neetocist\";\nimport { globalProps } from \"neetocommons/initializers\";\nimport { MenuHorizontal } from \"neetoicons\";\nimport { Dropdown } 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 { isNilOrEmpty, isNotNilOrEmpty } from \"components/ImageEditor/utils\";\nimport AssetLibrary from \"components/Modal\";\nimport { constructCloudflareImageURL } from \"components/utils\";\nimport { useCreateBlob } from \"hooks/useDirectUploads\";\nimport useImageUploader from \"hooks/useImageUploader\";\nimport { generateASCIIFileName } from \"hooks/utils\";\nimport { CLOUD_FLARE, 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 defaultImageSize = {},\n isDisabled = false,\n onDrop,\n isOptionsDisabled = false,\n}) => {\n const [isAssetLibraryOpen, setIsAssetLibraryOpen] = useState(false);\n const [image, setImage] = useState({ url: src });\n\n const { t } = useTranslation();\n\n const { mutateAsync: createBlob } = useCreateBlob();\n\n const uploadConfigWithDefaults = mergeRight(\n DEFAULT_UPLOAD_CONFIG,\n uploadConfig\n );\n\n const isCloudFlareImageUploader =\n globalProps.assetsUploaderService === CLOUD_FLARE;\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 id: attachedImage.id,\n filename: generateASCIIFileName(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 = async result => {\n if (IS_DEVELOPMENT_OR_HEROKU_ENV) {\n handleSuccess(mergeRight(result, { metadata: { url: result.url } }));\n\n return;\n }\n\n const imageKitPayload = () => ({\n filename: generateASCIIFileName(result.name),\n byte_size: result.size,\n content_type: result.fileType,\n checksum: result.fileId,\n metadata: result,\n service_name: \"imagekitio\",\n });\n\n const cloudFlarePayload = () => ({\n filename: generateASCIIFileName(result.filename),\n content_type: result.contentType,\n byte_size: result.byteSize,\n checksum: result.id,\n metadata: {\n ...result.metadata,\n url: constructCloudflareImageURL(result.variants[0]),\n isCropped: false,\n },\n service_name: \"cloudflare_image\",\n });\n\n const payload = isCloudFlareImageUploader\n ? cloudFlarePayload()\n : imageKitPayload();\n\n const response = await createBlob(payload, {});\n handleSuccess(response);\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\n className={classnames(className, {\n \"cursor-pointer\": true,\n \"cursor-not-allowed\": isDisabled,\n \"opacity-70\": isDisabled && isNilOrEmpty(image.url),\n })}\n >\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 {!isOptionsDisabled && (\n <Dropdown\n buttonSize=\"small\"\n buttonStyle=\"tertiary\"\n disabled={isDisabled}\n icon={MenuHorizontal}\n buttonProps={{\n // eslint-disable-next-line @bigbinary/neeto/use-neetoui-classes\n className: \"absolute right-3 top-3 rounded-full\",\n }}\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 )}\n </div>\n ) : (\n <ImageDirectUpload\n {...{ defaultImageSize, setImage, setIsAssetLibraryOpen }}\n isDisabled={isPresent(fixedAspectRatio)}\n isUploadDisabled={isDisabled}\n uploadConfig={uploadConfigWithDefaults}\n onDrop={onDrop || uploadFile}\n />\n )}\n <AssetLibrary\n {...{ defaultImageSize, 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","_ref$defaultImageSize","defaultImageSize","_ref$isDisabled","isDisabled","onDrop","_ref$isOptionsDisable","isOptionsDisabled","_useState","useState","_useState2","_slicedToArray","isAssetLibraryOpen","setIsAssetLibraryOpen","_useState3","url","_useState4","image","setImage","_useTranslation","useTranslation","t","_useCreateBlob","useCreateBlob","createBlob","mutateAsync","uploadConfigWithDefaults","mergeRight","DEFAULT_UPLOAD_CONFIG","isCloudFlareImageUploader","globalProps","assetsUploaderService","CLOUD_FLARE","handleDelete","onChange","signedId","key","filename","size","type","file","handleSuccess","attachedImage","metadata","id","generateASCIIFileName","blobUrl","byteSize","contentType","handleImageSelectionFromLibrary","handleUploadComplete","_ref2","_asyncToGenerator","_regeneratorRuntime","mark","_callee","result","imageKitPayload","cloudFlarePayload","payload","response","wrap","_callee$","_context","prev","next","IS_DEVELOPMENT_OR_HEROKU_ENV","abrupt","name","byte_size","content_type","fileType","checksum","fileId","service_name","_objectSpread","constructCloudflareImageURL","variants","isCropped","sent","stop","_x","apply","arguments","_useImageUploader","useImageUploader","uploadFile","options","OPTION_KEYS","asset","label","onClick","remove","_jsxs","classnames","isNilOrEmpty","children","isNotNilOrEmpty","IMAGE_WRAPPER_CLASSNAME","_jsx","ImageWithFallback","buttonSize","buttonStyle","disabled","icon","MenuHorizontal","buttonProps","map","_ref3","otherProps","_objectWithoutProperties","_excluded","_createElement","Button","ImageDirectUpload","isPresent","isUploadDisabled","AssetLibrary","isOpen","onClose"],"mappings":"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"}
1
+ {"version":3,"file":"ImageUploader.js","sources":["../../app/javascript/src/components/ImageUploader/index.jsx"],"sourcesContent":["import { useState } from \"react\";\n\nimport classnames from \"classnames\";\nimport { isPresent, noop } from \"neetocist\";\nimport { globalProps } from \"neetocommons/initializers\";\nimport { MenuHorizontal } from \"neetoicons\";\nimport { Dropdown } 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 { isNilOrEmpty, isNotNilOrEmpty } from \"components/ImageEditor/utils\";\nimport AssetLibrary from \"components/Modal\";\nimport { constructCloudflareImageURL } from \"components/utils\";\nimport { useCreateBlob } from \"hooks/useDirectUploads\";\nimport useImageUploader from \"hooks/useImageUploader\";\nimport { generateASCIIFileName } from \"hooks/utils\";\nimport { CLOUD_FLARE, 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 defaultImageSize = {},\n isDisabled = false,\n onDrop,\n isOptionsDisabled = false,\n}) => {\n const [isAssetLibraryOpen, setIsAssetLibraryOpen] = useState(false);\n const [image, setImage] = useState({ url: src });\n\n const { t } = useTranslation();\n\n const { mutateAsync: createBlob } = useCreateBlob();\n\n const uploadConfigWithDefaults = mergeRight(\n DEFAULT_UPLOAD_CONFIG,\n uploadConfig\n );\n\n const isCloudFlareImageUploader =\n globalProps.assetsUploaderService === CLOUD_FLARE;\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 id: attachedImage.id,\n filename: generateASCIIFileName(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 = async result => {\n if (IS_DEVELOPMENT_OR_HEROKU_ENV) {\n handleSuccess(mergeRight(result, { metadata: { url: result.url } }));\n\n return;\n }\n\n const imageKitPayload = () => ({\n filename: generateASCIIFileName(result.name),\n byte_size: result.size,\n content_type: result.fileType,\n checksum: result.fileId,\n metadata: result,\n service_name: \"imagekitio\",\n });\n\n const cloudFlarePayload = () => ({\n filename: generateASCIIFileName(result.filename),\n content_type: result.contentType,\n byte_size: result.byteSize,\n checksum: result.id,\n metadata: {\n ...result.metadata,\n url: constructCloudflareImageURL(result.variants[0]),\n isCropped: false,\n },\n service_name: \"cloudflare_image\",\n });\n\n const payload = isCloudFlareImageUploader\n ? cloudFlarePayload()\n : imageKitPayload();\n\n const response = await createBlob(payload, {});\n handleSuccess(response);\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-testid\": \"image-uploader-open-image-library-button\",\n },\n {\n key: OPTION_KEYS.remove,\n label: t(\"neetoImageUploader.imageUpload.remove\"),\n onClick: handleDelete,\n \"data-testid\": \"image-uploader-remove-button\",\n },\n ];\n\n return (\n <div\n className={classnames(className, {\n \"cursor-pointer\": true,\n \"cursor-not-allowed\": isDisabled,\n \"opacity-70\": isDisabled && isNilOrEmpty(image.url),\n })}\n >\n {isNotNilOrEmpty(image.url) ? (\n <div\n className={IMAGE_WRAPPER_CLASSNAME}\n data-testid=\"image-uploader-wrapper\"\n >\n <ImageWithFallback\n className=\"h-full w-full\"\n data-testid=\"uploaded-image\"\n src={image.url}\n />\n {!isOptionsDisabled && (\n <Dropdown\n buttonSize=\"small\"\n buttonStyle=\"tertiary\"\n disabled={isDisabled}\n icon={MenuHorizontal}\n buttonProps={{\n // eslint-disable-next-line @bigbinary/neeto/use-neetoui-classes\n className: \"absolute end-3 top-3 rounded-full\",\n }}\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 )}\n </div>\n ) : (\n <ImageDirectUpload\n {...{ defaultImageSize, setImage, setIsAssetLibraryOpen }}\n isDisabled={isPresent(fixedAspectRatio)}\n isUploadDisabled={isDisabled}\n uploadConfig={uploadConfigWithDefaults}\n onDrop={onDrop || uploadFile}\n />\n )}\n <AssetLibrary\n {...{ defaultImageSize, 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","_ref$defaultImageSize","defaultImageSize","_ref$isDisabled","isDisabled","onDrop","_ref$isOptionsDisable","isOptionsDisabled","_useState","useState","_useState2","_slicedToArray","isAssetLibraryOpen","setIsAssetLibraryOpen","_useState3","url","_useState4","image","setImage","_useTranslation","useTranslation","t","_useCreateBlob","useCreateBlob","createBlob","mutateAsync","uploadConfigWithDefaults","mergeRight","DEFAULT_UPLOAD_CONFIG","isCloudFlareImageUploader","globalProps","assetsUploaderService","CLOUD_FLARE","handleDelete","onChange","signedId","key","filename","size","type","file","handleSuccess","attachedImage","metadata","id","generateASCIIFileName","blobUrl","byteSize","contentType","handleImageSelectionFromLibrary","handleUploadComplete","_ref2","_asyncToGenerator","_regeneratorRuntime","mark","_callee","result","imageKitPayload","cloudFlarePayload","payload","response","wrap","_callee$","_context","prev","next","IS_DEVELOPMENT_OR_HEROKU_ENV","abrupt","name","byte_size","content_type","fileType","checksum","fileId","service_name","_objectSpread","constructCloudflareImageURL","variants","isCropped","sent","stop","_x","apply","arguments","_useImageUploader","useImageUploader","uploadFile","options","OPTION_KEYS","asset","label","onClick","remove","_jsxs","classnames","isNilOrEmpty","children","isNotNilOrEmpty","IMAGE_WRAPPER_CLASSNAME","_jsx","ImageWithFallback","buttonSize","buttonStyle","disabled","icon","MenuHorizontal","buttonProps","map","_ref3","otherProps","_objectWithoutProperties","_excluded","_createElement","Button","ImageDirectUpload","isPresent","isUploadDisabled","AssetLibrary","isOpen","onClose"],"mappings":"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"}
package/dist/cjs/index.js CHANGED
@@ -3,7 +3,7 @@
3
3
  var BasicImageUploader = require('./BasicImageUploader.js');
4
4
  var ImageForm = require('./ImageForm.js');
5
5
  var ImageUploader = require('./ImageUploader.js');
6
- var AssetLibrary = require('../index-ph4UeLLc.js');
6
+ var AssetLibrary = require('../index-Bd796sPX.js');
7
7
  var useProfileImageUpload = require('../useProfileImageUpload-Q6eh_T9J.js');
8
8
  var useImageUploader = require('../useImageUploader-6Su_fSo7.js');
9
9
  var utils = require('./utils.js');
@@ -13,7 +13,7 @@ require('classnames');
13
13
  require('@bigbinary/neeto-cist');
14
14
  require('@bigbinary/neeto-icons/Delete');
15
15
  require('@bigbinary/neetoui/Button');
16
- require('../utils-CVOvfMWy.js');
16
+ require('../utils-Um4BP0zx.js');
17
17
  require('@bigbinary/neetoui/Typography');
18
18
  require('@bigbinary/neetoui/ProgressBar');
19
19
  require('ramda');
@@ -12,7 +12,7 @@ var Toastr = require('@bigbinary/neetoui/Toastr');
12
12
  var Typography = require('@bigbinary/neetoui/Typography');
13
13
  var ramda = require('ramda');
14
14
  var reactI18next = require('react-i18next');
15
- var utils$1 = require('./utils-CVOvfMWy.js');
15
+ var utils$1 = require('./utils-Um4BP0zx.js');
16
16
  var useImageUploader = require('./useImageUploader-6Su_fSo7.js');
17
17
  var index = require('./index-C7OXkHLU.js');
18
18
  var classnames = require('classnames');
@@ -525,7 +525,7 @@ var Controls = reactUtils.withT(function (_ref) {
525
525
  })]
526
526
  }), /*#__PURE__*/jsxRuntime.jsx(Button, {
527
527
  className: "mt-6 self-start",
528
- "data-cy": "neeto-image-uploader-crop-submit-button",
528
+ "data-testid": "neeto-image-uploader-crop-submit-button",
529
529
  label: t("neetoImageUploader.labels.done"),
530
530
  disabled: utils$1.isNilOrEmpty(imageRef.current) && (crop.width <= 0 || crop.height <= 0),
531
531
  onClick: handleSubmit
@@ -702,6 +702,14 @@ var useImageControls = function useImageControls(_ref) {
702
702
  var imageWidth = image.naturalWidth,
703
703
  imageHeight = image.naturalHeight;
704
704
  var maxCropWidth = (_defaultImageSize$wid = defaultImageSize.width) !== null && _defaultImageSize$wid !== void 0 ? _defaultImageSize$wid : imageWidth;
705
+ var aspectRatio = utils$1.getAspectRatio({
706
+ fixedAspectRatio: fixedAspectRatio,
707
+ imageSize: {
708
+ width: imageWidth,
709
+ height: imageHeight
710
+ }
711
+ });
712
+ var aspectRatioFactor = aspectRatio.width / aspectRatio.height;
705
713
  var _getInitialCropSize = utils$1.getInitialCropSize({
706
714
  image: image,
707
715
  aspectRatioFactor: aspectRatioFactor,
@@ -713,8 +721,10 @@ var useImageControls = function useImageControls(_ref) {
713
721
  cropWidth: cropWidth,
714
722
  cropHeight: cropHeight,
715
723
  width: imageWidth,
716
- height: imageHeight
724
+ height: imageHeight,
725
+ aspectRatio: aspectRatioFactor
717
726
  });
727
+ setAspectRatio(aspectRatio);
718
728
  setCrop(crop);
719
729
  setHeight(utils$1.getPixels(crop.height, imageHeight));
720
730
  setWidth(utils$1.getPixels(crop.width, imageWidth));
@@ -817,7 +827,7 @@ var ImageEditor = function ImageEditor(_ref) {
817
827
  className: "flex h-full flex-col gap-4 px-8 py-12",
818
828
  children: [/*#__PURE__*/jsxRuntime.jsx(Button, {
819
829
  className: "self-start",
820
- "data-cy": "image-editor-back-button",
830
+ "data-testid": "image-editor-back-button",
821
831
  icon: LeftArrow,
822
832
  iconPosition: "left",
823
833
  style: "text",
@@ -842,12 +852,12 @@ var ImageEditor = function ImageEditor(_ref) {
842
852
  onComplete: handleCropChange,
843
853
  children: [/*#__PURE__*/jsxRuntime.jsx("img", {
844
854
  alt: t("neetoImageUploader.common.image"),
845
- "data-cy": "image-editor-uploaded-image",
855
+ "data-testid": "image-editor-uploaded-image",
846
856
  ref: imageRef,
847
857
  src: image === null || image === void 0 ? void 0 : image.url,
848
858
  onLoad: handleImageLoad
849
859
  }), /*#__PURE__*/jsxRuntime.jsxs(Typography, {
850
- className: "neeto-ui-typography neeto-ui-text-nano neeto-ui-bg-gray-500 absolute bottom-0 right-0 z-10",
860
+ className: "neeto-ui-typography neeto-ui-text-nano neeto-ui-bg-gray-500 absolute bottom-0 end-0 z-10",
851
861
  style: "nano",
852
862
  children: [imageWidth, "x", imageHeight]
853
863
  })]
@@ -1868,7 +1878,7 @@ var InfiniteScroller = function InfiniteScroller(_ref) {
1868
1878
  children: /*#__PURE__*/jsxRuntime.jsx(Spinner, {})
1869
1879
  });
1870
1880
  return /*#__PURE__*/jsxRuntime.jsxs("div", {
1871
- className: "niu-unsplash-container mr-2 max-w-full overflow-x-hidden overflow-y-scroll",
1881
+ className: "niu-unsplash-container me-2 max-w-full overflow-x-hidden overflow-y-scroll",
1872
1882
  children: [/*#__PURE__*/jsxRuntime.jsx(_default, {
1873
1883
  hasMore: hasMore,
1874
1884
  loadMore: loadMore,
@@ -1882,7 +1892,7 @@ var InfiniteScroller = function InfiniteScroller(_ref) {
1882
1892
  children: images.map(function (image, index) {
1883
1893
  var _image$urls, _image$user, _image$user2;
1884
1894
  return /*#__PURE__*/jsxRuntime.jsx("div", {
1885
- className: "float-left w-1/2 pb-4 pr-4 md:w-1/4",
1895
+ className: "float-start w-1/2 pb-4 pe-4 md:w-1/4",
1886
1896
  children: /*#__PURE__*/jsxRuntime.jsx("div", {
1887
1897
  className: "relative w-full",
1888
1898
  style: {
@@ -1890,17 +1900,17 @@ var InfiniteScroller = function InfiniteScroller(_ref) {
1890
1900
  },
1891
1901
  children: /*#__PURE__*/jsxRuntime.jsxs("div", {
1892
1902
  className: "neeto-ui-rounded-sm neeto-ui-bg-gray-100 group absolute h-full w-full",
1893
- "data-cy": "library-image-card",
1903
+ "data-testid": "library-image-card",
1894
1904
  id: "unsplashImage".concat(image.id),
1895
1905
  children: [tab === utils$1.TABS[2].key && /*#__PURE__*/jsxRuntime.jsxs(jsxRuntime.Fragment, {
1896
1906
  children: [/*#__PURE__*/jsxRuntime.jsx("img", {
1897
- "data-cy": "niu-unsplash-image-".concat(index),
1907
+ "data-testid": "niu-unsplash-image-".concat(index),
1898
1908
  src: image === null || image === void 0 || (_image$urls = image.urls) === null || _image$urls === void 0 ? void 0 : _image$urls.regular,
1899
1909
  onClick: function onClick() {
1900
1910
  return handleUnsplashImageSelect(image);
1901
1911
  }
1902
1912
  }), /*#__PURE__*/jsxRuntime.jsxs("a", {
1903
- className: "neeto-ui-text-gray-100 absolute bottom-2 left-2 m-auto text-xs underline opacity-0 group-hover:opacity-100",
1913
+ className: "neeto-ui-text-gray-100 absolute bottom-2 start-2 m-auto text-xs underline opacity-0 group-hover:opacity-100",
1904
1914
  href: "https://unsplash.com/@".concat(image === null || image === void 0 || (_image$user = image.user) === null || _image$user === void 0 ? void 0 : _image$user.username),
1905
1915
  rel: "noreferrer",
1906
1916
  target: "_blank",
@@ -1910,16 +1920,16 @@ var InfiniteScroller = function InfiniteScroller(_ref) {
1910
1920
  children: [utils.hasPermission(constants.VIEW_ROLES_PERMISSION) && isMenuButtonEnabled && /*#__PURE__*/jsxRuntime.jsx(Dropdown, {
1911
1921
  buttonSize: "small",
1912
1922
  buttonStyle: "tertiary",
1913
- "data-cy": "image-library-image-options-".concat(index),
1923
+ "data-testid": "image-library-image-options-".concat(index),
1914
1924
  icon: MenuHorizontal,
1915
1925
  buttonProps: {
1916
1926
  className:
1917
1927
  // eslint-disable-next-line @bigbinary/neeto/use-neetoui-classes
1918
- "absolute right-2 top-2 z-1 rounded-full"
1928
+ "absolute end-2 top-2 z-1 rounded-full"
1919
1929
  },
1920
1930
  children: /*#__PURE__*/jsxRuntime.jsx(Menu, {
1921
1931
  children: /*#__PURE__*/jsxRuntime.jsx(MenuItem.Button, {
1922
- "data-cy": "image-library-image-delete",
1932
+ "data-testid": "image-library-image-delete",
1923
1933
  onClick: function onClick() {
1924
1934
  return setDeleteConfirmation({
1925
1935
  isOpen: true,
@@ -1930,7 +1940,7 @@ var InfiniteScroller = function InfiniteScroller(_ref) {
1930
1940
  })
1931
1941
  })
1932
1942
  }), /*#__PURE__*/jsxRuntime.jsx("img", {
1933
- "data-cy": "niu-library-image-".concat(index),
1943
+ "data-testid": "niu-library-image-".concat(index),
1934
1944
  src: image === null || image === void 0 ? void 0 : image.url,
1935
1945
  onClick: function onClick() {
1936
1946
  return setSelectedImage(image);
@@ -2155,7 +2165,7 @@ var ImageLibrary = function ImageLibrary(_ref) {
2155
2165
  children: [/*#__PURE__*/jsxRuntime.jsx(Input, {
2156
2166
  autoFocus: true,
2157
2167
  className: "mb-4",
2158
- "data-cy": "niu-unsplash-image-picker-search-input",
2168
+ "data-testid": "niu-unsplash-image-picker-search-input",
2159
2169
  name: "text",
2160
2170
  placeholder: inputPlaceHolder,
2161
2171
  value: query,
@@ -2341,7 +2351,7 @@ var Modal = function Modal(_ref) {
2341
2351
  children: utils$1.TABS.map(function (tab) {
2342
2352
  return /*#__PURE__*/jsxRuntime.jsx(Tab.Item, {
2343
2353
  active: activeTab === tab.key,
2344
- "data-cy": tab.dataCy,
2354
+ "data-testid": tab.dataTestid,
2345
2355
  onClick: function onClick() {
2346
2356
  return setActiveTab(tab.key);
2347
2357
  },
@@ -2371,4 +2381,4 @@ var Modal = function Modal(_ref) {
2371
2381
 
2372
2382
  exports.Modal = Modal;
2373
2383
  exports.constructCloudflareImageURL = constructCloudflareImageURL;
2374
- //# sourceMappingURL=index-ph4UeLLc.js.map
2384
+ //# sourceMappingURL=index-Bd796sPX.js.map