@zydon/common 2.7.62 → 2.7.63

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 (149) hide show
  1. package/dist/{chunk-75G5RNV4.js → chunk-5LQLLZ5L.js} +2 -2
  2. package/dist/chunk-5NIMUEW5.js +25 -0
  3. package/dist/chunk-5NIMUEW5.js.map +1 -0
  4. package/dist/chunk-6WGKIN5L.js +18 -0
  5. package/dist/chunk-6WGKIN5L.js.map +1 -0
  6. package/dist/chunk-7MVZYOHX.js +13 -0
  7. package/dist/chunk-7MVZYOHX.js.map +1 -0
  8. package/dist/{chunk-WDKKCLZ6.js → chunk-CWCEG2DZ.js} +2 -2
  9. package/dist/{chunk-HLMZQG27.js → chunk-HWYA3EGC.js} +2 -2
  10. package/dist/chunk-HWYA3EGC.js.map +1 -0
  11. package/dist/chunk-IEGF6HVV.js +43 -0
  12. package/dist/{chunk-L4FRE2NC.js.map → chunk-IEGF6HVV.js.map} +1 -1
  13. package/dist/chunk-JFZOAS75.js +23 -0
  14. package/dist/{chunk-5AWUE6JG.js → chunk-JZ55NEMI.js} +2 -2
  15. package/dist/{chunk-IMKYDHP2.js → chunk-KR3DUHA6.js} +3 -3
  16. package/dist/{chunk-EKIESGNJ.js → chunk-LEMPYV5U.js} +2 -2
  17. package/dist/{chunk-QGMJKW7H.js → chunk-LNXA53QR.js} +2 -2
  18. package/dist/{chunk-FBSNLBJM.js → chunk-LY3IB5VH.js} +2 -2
  19. package/dist/{chunk-DIWJKSWV.js → chunk-MP2LAJS5.js} +3 -3
  20. package/dist/{chunk-IC3H2DXY.js → chunk-N4DW7EIC.js} +2 -2
  21. package/dist/{chunk-CMZI4PHD.js → chunk-NQNNMRLC.js} +1 -1
  22. package/dist/{chunk-CMZI4PHD.js.map → chunk-NQNNMRLC.js.map} +1 -1
  23. package/dist/{chunk-DOVOMWT6.js → chunk-OTVEMGF2.js} +2 -2
  24. package/dist/chunk-POTVACYB.js +8 -0
  25. package/dist/chunk-POTVACYB.js.map +1 -0
  26. package/dist/chunk-QVU6HSYP.js +12 -0
  27. package/dist/chunk-QVU6HSYP.js.map +1 -0
  28. package/dist/{chunk-RANEJERP.js → chunk-R76WTFYC.js} +2 -2
  29. package/dist/chunk-RBTYTONM.js +13 -0
  30. package/dist/chunk-RBTYTONM.js.map +1 -0
  31. package/dist/{chunk-DPT3E7PD.js → chunk-RFRLNTFN.js} +2 -2
  32. package/dist/{chunk-LBYTNLD3.js → chunk-U7BH6DMJ.js} +2 -2
  33. package/dist/{chunk-CU7PKEY2.js → chunk-VPKUUY5Q.js} +2 -2
  34. package/dist/chunk-VYNBVZSA.js +37 -0
  35. package/dist/chunk-VYNBVZSA.js.map +1 -0
  36. package/dist/chunk-WQSRNCNF.js +5 -0
  37. package/dist/chunk-WQSRNCNF.js.map +1 -0
  38. package/dist/{chunk-5SIAWCDO.js → chunk-XZFBTUAG.js} +2 -2
  39. package/dist/{chunk-N7R22QVG.js → chunk-ZFRNMT3P.js} +2 -2
  40. package/dist/{chunk-YPQCLH3D.js → chunk-ZGSSTXUO.js} +2 -2
  41. package/dist/components/ActionButton/index.js +2 -2
  42. package/dist/components/Autocomplete/index.js +2 -2
  43. package/dist/components/Avatar/index.d.ts +1 -1
  44. package/dist/components/AvatarButton/index.js +3 -3
  45. package/dist/components/BuilderLayout/index.js +2 -2
  46. package/dist/components/BuilderSidebar/index.js +1 -1
  47. package/dist/components/BulkEditModal/index.d.ts +64 -0
  48. package/dist/components/BulkEditModal/index.js +28 -0
  49. package/dist/components/BulkEditModal/index.js.map +1 -0
  50. package/dist/components/CardBrand/index.js +1 -1
  51. package/dist/components/Common/index.js +3 -3
  52. package/dist/components/CopyButton/index.js +2 -2
  53. package/dist/components/DataGrid/index.js +2 -1
  54. package/dist/components/DataView/index.js +8 -6
  55. package/dist/components/DragButton/index.js +2 -2
  56. package/dist/components/Drawer/index.js +1 -1
  57. package/dist/components/DynamicDataView/index.d.ts +4 -2
  58. package/dist/components/DynamicDataView/index.js +20 -14
  59. package/dist/components/DynamicDataView/index.js.map +1 -1
  60. package/dist/components/EasyCropModal/index.js +3 -3
  61. package/dist/components/Error/index.js +1 -1
  62. package/dist/components/ExpandableGroup/index.js +7 -7
  63. package/dist/components/ExpandableGroup/index.js.map +1 -1
  64. package/dist/components/FieldMentions/index.js.map +1 -1
  65. package/dist/components/FileUpload/index.js +7 -6
  66. package/dist/components/FrameSkeleton/index.js +4 -4
  67. package/dist/components/HelpButton/index.js +2 -2
  68. package/dist/components/Icon/index.js +1 -1
  69. package/dist/components/IconButton/index.js +2 -2
  70. package/dist/components/ImageCropModal/index.js +3 -3
  71. package/dist/components/Incrementer/index.js +2 -2
  72. package/dist/components/InfoCircle/index.js +1 -1
  73. package/dist/components/ListBundles/index.js +2 -2
  74. package/dist/components/MenuItem/index.js +1 -1
  75. package/dist/components/Modal/index.js +2 -2
  76. package/dist/components/MoreMenu/index.js +1 -1
  77. package/dist/components/PasswordRules/index.js +1 -1
  78. package/dist/components/PopoverSelect/index.js +1 -1
  79. package/dist/components/SearchInput/index.js +2 -2
  80. package/dist/components/SelectableCards/index.js +3 -3
  81. package/dist/components/SeoPreview/index.js +1 -1
  82. package/dist/components/StateDisplay/index.js +2 -2
  83. package/dist/components/Steps/index.js +1 -1
  84. package/dist/components/StyledTab/index.js +1 -1
  85. package/dist/components/SwapList/index.js +2 -2
  86. package/dist/components/ToggleTheme/index.js +2 -2
  87. package/dist/components/WebhookCard/index.js +2 -2
  88. package/dist/components/carousel/index.js +2 -2
  89. package/dist/components/form/Address/index.js +3 -3
  90. package/dist/components/form/Autocomplete/index.js +3 -3
  91. package/dist/components/form/FileUpload/index.js +8 -7
  92. package/dist/components/form/FileUpload/index.js.map +1 -1
  93. package/dist/components/form/Incrementer/index.js +2 -2
  94. package/dist/components/form/Password/index.js +1 -1
  95. package/dist/components/form/SelectableCards/index.js +3 -3
  96. package/dist/components/form/UploadAvatarWithCrop/index.js +6 -5
  97. package/dist/components/form/UploadAvatarWithCrop/index.js.map +1 -1
  98. package/dist/components/form/UploadWithCrop/index.js +8 -7
  99. package/dist/components/form/UploadWithCrop/index.js.map +1 -1
  100. package/dist/components/form/Webhook/index.js +12 -12
  101. package/dist/components/form/Webhook/index.js.map +1 -1
  102. package/dist/components/lightbox/index.js +1 -1
  103. package/dist/components/table/index.js +2 -2
  104. package/dist/components/upload/index.js +11 -10
  105. package/dist/components/upload/index.js.map +1 -1
  106. package/dist/hooks/useCollapseSidebarOnMount.js +3 -3
  107. package/dist/hooks/useEventCallback.d.ts +2 -3
  108. package/dist/hooks/useEventCallback.js +1 -1
  109. package/dist/hooks/useLocalStorage.js +2 -2
  110. package/dist/hooks/useSnackbar.d.ts +1 -1
  111. package/dist/hooks/useThemeToggle.js +2 -2
  112. package/dist/index.d.ts +2 -2
  113. package/dist/index.js +2 -2
  114. package/dist/theme/core/index.d.ts +1 -1
  115. package/dist/theme/styles/index.d.ts +13 -13
  116. package/dist/theme/theme-provider.js +2 -2
  117. package/package.json +1 -1
  118. package/dist/chunk-G4J47YPR.js +0 -23
  119. package/dist/chunk-HLMZQG27.js.map +0 -1
  120. package/dist/chunk-JBPWWO5D.js +0 -15
  121. package/dist/chunk-JBPWWO5D.js.map +0 -1
  122. package/dist/chunk-L4FRE2NC.js +0 -42
  123. package/dist/chunk-MQAMSYYK.js +0 -8
  124. package/dist/chunk-MQAMSYYK.js.map +0 -1
  125. package/dist/chunk-SA2BESEB.js +0 -17
  126. package/dist/chunk-SA2BESEB.js.map +0 -1
  127. package/dist/chunk-TNSABPJ2.js +0 -27
  128. package/dist/chunk-TNSABPJ2.js.map +0 -1
  129. package/dist/chunk-UZ4EKQYP.js +0 -36
  130. package/dist/chunk-UZ4EKQYP.js.map +0 -1
  131. package/dist/{chunk-75G5RNV4.js.map → chunk-5LQLLZ5L.js.map} +0 -0
  132. package/dist/{chunk-WDKKCLZ6.js.map → chunk-CWCEG2DZ.js.map} +0 -0
  133. package/dist/{chunk-G4J47YPR.js.map → chunk-JFZOAS75.js.map} +0 -0
  134. package/dist/{chunk-5AWUE6JG.js.map → chunk-JZ55NEMI.js.map} +0 -0
  135. package/dist/{chunk-IMKYDHP2.js.map → chunk-KR3DUHA6.js.map} +0 -0
  136. package/dist/{chunk-EKIESGNJ.js.map → chunk-LEMPYV5U.js.map} +0 -0
  137. package/dist/{chunk-QGMJKW7H.js.map → chunk-LNXA53QR.js.map} +0 -0
  138. package/dist/{chunk-FBSNLBJM.js.map → chunk-LY3IB5VH.js.map} +0 -0
  139. package/dist/{chunk-DIWJKSWV.js.map → chunk-MP2LAJS5.js.map} +0 -0
  140. package/dist/{chunk-IC3H2DXY.js.map → chunk-N4DW7EIC.js.map} +0 -0
  141. package/dist/{chunk-DOVOMWT6.js.map → chunk-OTVEMGF2.js.map} +0 -0
  142. package/dist/{chunk-RANEJERP.js.map → chunk-R76WTFYC.js.map} +0 -0
  143. package/dist/{chunk-DPT3E7PD.js.map → chunk-RFRLNTFN.js.map} +0 -0
  144. package/dist/{chunk-LBYTNLD3.js.map → chunk-U7BH6DMJ.js.map} +0 -0
  145. package/dist/{chunk-CU7PKEY2.js.map → chunk-VPKUUY5Q.js.map} +0 -0
  146. package/dist/{chunk-5SIAWCDO.js.map → chunk-XZFBTUAG.js.map} +0 -0
  147. package/dist/{chunk-N7R22QVG.js.map → chunk-ZFRNMT3P.js.map} +0 -0
  148. package/dist/{chunk-YPQCLH3D.js.map → chunk-ZGSSTXUO.js.map} +0 -0
  149. package/dist/{index-c8f1e6e7.d.ts → index-5a5e5dc8.d.ts} +12 -12
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/FileUpload/components/HelperText.tsx","../src/components/FileUpload/components/MultiFilePreview.tsx","../src/components/FileUpload/components/SortableFile.tsx","../src/components/FileUpload/styles.ts","../src/components/FileUpload/components/ThumbnailBadge.tsx","../src/components/FileUpload/components/SingleFilePreview.tsx","../src/components/FileUpload/components/LoadingPreviewImage.tsx","../src/components/FileUpload/FileThumbnail/index.tsx","../src/components/FileUpload/hooks/useDropzoneUploader.ts","../src/components/FileUpload/utils.ts","../src/components/FileUpload/hooks/useFileUploadService.ts","../src/components/FileUpload/props.ts","../src/components/FileUpload/MultipleFileUpload.tsx","../src/components/FileUpload/components/DropZone.tsx","../src/components/FileUpload/components/DropZonePlaceholder.tsx","../src/components/FileUpload/MultipleImageUpload.tsx","../src/components/FileUpload/SingleFileUpload.tsx","../src/components/FileUpload/SingleImageUpload.tsx","../src/components/FileUpload/UploadAvatar.tsx","../src/components/FileUpload/UploadSimpleBox.tsx"],"names":["memo","FormHelperText","jsx","HelperText","helperText","disabled","isError","theme","HelperText_default","useCallback","useState","closestCenter","DndContext","KeyboardSensor","PointerSensor","useSensor","useSensors","restrictToHorizontalAxis","restrictToParentElement","restrictToWindowEdges","horizontalListSortingStrategy","SortableContext","sortableKeyboardCoordinates","AnimatePresence","useSortable","Stack","Typography","Box","IconButtonMui","Paper","alpha","styled","m","Container","Actions","StyledDropZone","prop","isDragActive","CloseIconButton","DragWrapper","FrameFileThumbnail","width","isDragging","FrameImageThumbnail","DeleteButton","IconButton_default","BoxUpload","hasError","SingleFilePreviewBox","SingleFilePreviewImg","aspectRatio","maxWidth","maxHeight","isLoading","isUploading","fill","SingleFilePreviewBlurImg","SingleFilePreviewHoverOverlay","AvatarContainer","RejectionFilesPaper","UploadPlaceholder","hasFile","PlaceholderLoading","PlaceholderUploadImageAltBox","UploadAvatarBox","ImagePreview","ActionsIconButton","Badge","jsxs","ThumbnailBadge","onRemove","sx","file","disableDrag","attributes","listeners","innerWidth","id","varFade","DragButton_default","FileThumbnail","ThumbnailBadge_default","SortableFile","thumbnail","disableTransitions","size","name","isNotFormatFile","setNodeRef","transform","transition","style","CSS","Tooltip_default","fData","SortableFile_default","MultiFilePreview","files","onReorder","setDisableTransitions","sensors","handleDragEnd","event","active","over","oldIndex","newIndex","sortableFile","MultiFilePreview_default","useRef","forwardRef","useLayoutEffect","useMemo","LoadingPreviewImage","onLoading","cropSize","props","imageRef","useMount_default","handleFinish","LoadingPreviewImage_default","SingleFilePreview","hoverAlt","fileId","fileName","previewUrl","SingleFilePreview_default","ButtonBase","IconButton","Tooltip","fileThumbnailClasses","tooltip","imageView","slotProps","onDownload","other","format","fileFormat","renderImg","renderIcon","Icon_default","fileThumb","renderContent","useEffect","useDropzone","isImageFile","mimeType","convertToWebP","quality","resolve","reject","canvas","ctx","img","blob","webpFile","compressImageWithoutCrop","height","compressedFile","getFileNameFromContentDisposition","contentDisposition","match","encodeFilenameForHeader","filename","useDropzoneUploader","onFilesSelect","onFileSelect","uploadFiles","filesPreview","dropzoneOptions","enableCrop","customAspectRatio","convertToWebp","maxFiles","compressionQuality","maxCompressedWidth","maxCompressedHeight","showErrorMessage","useApiMessage_default","internalFiles","setInternalFiles","cropModalOpen","setCropModalOpen","originalImage","setOriginalImage","croppedAreaPixels","setCroppedAreaPixels","imagePreview","setImagePreview","cropLoading","setCropLoading","pendingImages","setPendingImages","currentImageIndex","setCurrentImageIndex","totalPendingImages","setTotalPendingImages","processNextImage","images","nextImageData","prev","reader","onCropInitialized","_croppedArea","createCroppedImage","x","y","ratio","finalWidth","finalHeight","croppedFile","error","extendedFile","handleCropSave","currentImageData","croppedImage","remainingImages","handleCropCancel","onDrop","acceptedFiles","isImageUpload","key","totalFiles","imageFilesWithTempIds","index","processedFiles","handleDropRejected","fileRejections","errorCode","maxSizeInBytes","getRootProps","getInputProps","isDragReject","handleRemove","fileToRemove","newFiles","handleReorder","filesIdRef","idRef","useDropzoneUploader_default","ContentType","FileContentType","useFileUploadService","createFilesMutation","filesDetails","isUploadingFiles","setIsUploadingFiles","isLoadingPreview","setIsLoadingPreview","uploadFilesError","setUploadFilesError","setFilesPreview","filePreview","isUploadOrLoadingFiles","fetchFiles","details","validFiles","url","response","nameFromDisposition","previewFile","filesUrlRef","urlKey","filesWithContentType","contentTypeEnum","createResponse","extendedFiles","responseFile","originalFile","uploadErrorText","useFileUploadService_default","DropZone","tabIndex","uploading","dropZoneSxProps","dropZoneContent","children","FixedProgressBar_default","DropZone_default","Fragment","DropZonePlaceholder","header","description","UploadIllustration_default","DropZonePlaceholder_default","MultipleFileUpload","placeholderAlt","placeholderProps","dropzoneProps","hasFiles","MultipleFileUpload_default","MultipleImageUpload","customLabel","cropState","label","labelText","labelProcessing","EasyCropModal_default","MultipleImageUpload_default","SingleFileUpload","fileDetails","onRemoveFile","e","SingleFileUpload_default","SingleImageUpload","imagePreviewLoading","setImagePreviewLoading","hidePlaceholder","dropZoneSxWidth","SingleImageUpload_default","CircularProgress","UploadAvatar","maxSize","canRemove","imgSrc","loadedFileKey","objectUrl","handleImageLoad","handleClick","UploadAvatar_default","UploadBox","UploadSimpleBox_default"],"mappings":"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","sourcesContent":["import { memo } from 'react';\nimport FormHelperText from '@mui/material/FormHelperText';\n\nimport { HelperTextProps } from '../props';\n\nconst HelperText = ({ helperText, disabled, isError }: HelperTextProps) => {\n if (!helperText) return null;\n\n return (\n <FormHelperText\n error={isError}\n sx={theme => ({\n mx: '14px',\n color: disabled ? theme.palette.grey[500] : undefined,\n })}\n >\n {helperText}\n </FormHelperText>\n );\n};\n\nexport default memo(HelperText);\n","import { memo, useCallback, useState } from 'react';\nimport {\n closestCenter,\n DndContext,\n DragEndEvent,\n KeyboardSensor,\n PointerSensor,\n UniqueIdentifier,\n useSensor,\n useSensors,\n} from '@dnd-kit/core';\nimport {\n restrictToHorizontalAxis,\n restrictToParentElement,\n restrictToWindowEdges,\n} from '@dnd-kit/modifiers';\nimport {\n horizontalListSortingStrategy,\n SortableContext,\n sortableKeyboardCoordinates,\n} from '@dnd-kit/sortable';\nimport { AnimatePresence } from 'framer-motion';\n\nimport { ExtendFile, MultiFilePreviewProps } from '../props';\n\nimport SortableFile from './SortableFile';\n\nconst MultiFilePreview = ({\n thumbnail,\n files,\n onRemove,\n onReorder,\n sx,\n}: MultiFilePreviewProps) => {\n const [disableTransitions, setDisableTransitions] = useState(false);\n const sensors = useSensors(\n useSensor(PointerSensor, {\n activationConstraint: {\n distance: 8,\n },\n }),\n useSensor(KeyboardSensor, {\n coordinateGetter: sortableKeyboardCoordinates,\n }),\n );\n\n const handleDragEnd = useCallback(\n (event: DragEndEvent) => {\n const { active, over } = event;\n\n if (!active || !over || active.id === over.id) return;\n\n if (onReorder) {\n const oldIndex = files.findIndex(\n ({ id }: ExtendFile) => id === active.id,\n );\n const newIndex = files.findIndex(\n ({ id }: ExtendFile) => id === over.id,\n );\n\n if (oldIndex !== -1 && newIndex !== -1) {\n onReorder(oldIndex, newIndex, files);\n setDisableTransitions(true);\n setTimeout(() => {\n setDisableTransitions(false);\n }, 300);\n }\n }\n },\n [files, onReorder],\n );\n\n const sortableFile = (\n <AnimatePresence initial={false}>\n {files.map((file: ExtendFile) => (\n <SortableFile\n sx={sx}\n id={`preview-file-${file.id}`}\n file={file}\n onRemove={onRemove}\n thumbnail={thumbnail}\n disableDrag={!onReorder}\n disableTransitions={disableTransitions}\n key={`preview-file-${file.id}`}\n />\n ))}\n </AnimatePresence>\n );\n\n if (!onReorder) {\n return sortableFile;\n }\n\n return (\n <DndContext\n sensors={sensors}\n collisionDetection={closestCenter}\n onDragEnd={handleDragEnd}\n modifiers={[\n restrictToHorizontalAxis,\n restrictToParentElement,\n restrictToWindowEdges,\n ]}\n >\n <SortableContext\n items={files.map((file: ExtendFile) => file.id as UniqueIdentifier)}\n strategy={horizontalListSortingStrategy}\n >\n {sortableFile}\n </SortableContext>\n </DndContext>\n );\n};\n\nexport default memo(MultiFilePreview);\n","import { memo } from 'react';\nimport { useSortable } from '@dnd-kit/sortable';\nimport { CSS } from '@dnd-kit/utilities';\nimport Stack from '@mui/material/Stack';\nimport Typography from '@mui/material/Typography';\n\nimport { varFade } from 'components/animate';\nimport DragButton from 'components/DragButton';\nimport { FileThumbnail } from 'components/FileUpload';\nimport IconButton from 'components/IconButton';\nimport Tooltip from 'components/Tooltip';\nimport { fData } from 'utils/formatNumber';\n\nimport { SortableItemProps } from '../props';\nimport { Actions, DragWrapper, FrameFileThumbnail } from '../styles';\n\nimport ThumbnailBadge from './ThumbnailBadge';\n\nconst SortableFile = ({\n file,\n thumbnail,\n onRemove,\n sx,\n disableDrag = false,\n disableTransitions = false,\n}: SortableItemProps) => {\n /* istanbul ignore next */\n const size = file.size || 0;\n /* istanbul ignore next */\n const name = file.name || file.id;\n const id = file.id;\n const isNotFormatFile = typeof file === 'string';\n const innerWidth = disableDrag ? 70 : 80;\n\n const {\n attributes,\n listeners,\n setNodeRef,\n transform,\n transition,\n isDragging,\n } = useSortable({\n id,\n disabled: disableDrag,\n });\n\n const style = {\n transform: disableTransitions\n ? undefined\n : CSS.Transform.toString(transform),\n transition: disableTransitions ? 'none' : transition,\n opacity: disableTransitions ? 0.2 : 1,\n display: 'inline-block',\n alignItems: 'center',\n justifyContent: 'center',\n width: `${innerWidth + 8}px`,\n height: '68px',\n };\n\n if (thumbnail && file) {\n return (\n <DragWrapper ref={setNodeRef} style={style}>\n <ThumbnailBadge\n innerWidth={innerWidth}\n isDragging={isDragging}\n sx={sx}\n file={file}\n disableDrag={disableDrag}\n attributes={attributes}\n listeners={listeners}\n onRemove={onRemove}\n />\n </DragWrapper>\n );\n }\n\n return (\n <DragWrapper\n ref={setNodeRef}\n style={{\n ...style,\n height: '80px',\n width: `${innerWidth + 38}px`,\n }}\n >\n <FrameFileThumbnail\n width={innerWidth + 30}\n isDragging={isDragging}\n data-testid={`preview-multi-img-${id}`}\n {...varFade().inUp}\n sx={sx}\n >\n <DragButton disableDrag={disableDrag} {...attributes} {...listeners} />\n\n {file && <FileThumbnail file={file} />}\n\n <Stack flexGrow={1} sx={{ width: '100%' }}>\n <Tooltip title={name}>\n <Typography variant=\"subtitle2\" noWrap>\n {name}\n </Typography>\n </Tooltip>\n\n <Typography variant=\"caption\" sx={{ color: 'text.secondary' }}>\n {isNotFormatFile ? '' : fData(size)}\n </Typography>\n </Stack>\n\n <Actions>\n {onRemove && (\n <IconButton\n size=\"small\"\n label=\"Remover arquivo\"\n onClick={() => onRemove(file)}\n icon=\"DELETE_MARK_BUTTON_02\"\n />\n )}\n </Actions>\n </FrameFileThumbnail>\n </DragWrapper>\n );\n};\n\nexport default memo(SortableFile);\n","import Box from '@mui/material/Box';\nimport IconButtonMui from '@mui/material/IconButton';\nimport Paper from '@mui/material/Paper';\nimport Stack from '@mui/material/Stack';\nimport { alpha, styled } from '@mui/material/styles';\nimport { m } from 'framer-motion';\n\nimport IconButton from 'components/IconButton';\n\nimport { LoadingPreviewImageProps, StyledDropZonePropsType } from './props';\n\nexport const Container = styled(Stack)({\n position: 'relative',\n width: '100%',\n borderRadius: 8,\n overflow: 'hidden',\n\n '&:hover .actions': {\n display: 'flex',\n },\n});\n\nexport const Actions = styled(Stack)({\n position: 'absolute',\n top: 4,\n right: 4,\n gap: 0.5,\n '& svg': {\n width: 16,\n height: 16,\n },\n});\n\nexport const StyledDropZone = styled(Box, {\n shouldForwardProp: prop =>\n !['isDragActive', 'isError', 'disabled'].includes(prop as string),\n})<StyledDropZonePropsType>(({ theme, isDragActive, isError, disabled }) => ({\n outline: 'none',\n cursor: 'pointer',\n overflow: 'hidden',\n position: 'relative',\n padding: theme.spacing(5),\n borderRadius: theme.shape.borderRadius,\n transition: theme.transitions.create('padding'),\n backgroundColor: theme.palette.background.neutral,\n border: `dashed 1px ${theme.palette.divider}`,\n ...(isDragActive && {\n opacity: 0.72,\n }),\n ...(isError && {\n color: theme.palette.error.main,\n backgroundColor: theme.palette.error.lighter,\n borderColor: theme.palette.error.light,\n }),\n ...(disabled && {\n opacity: 0.48,\n pointerEvents: 'none',\n }),\n '&:hover': {\n opacity: 0.72,\n },\n}));\n\nexport const CloseIconButton = styled(IconButtonMui)(({ theme }) => ({\n position: 'relative',\n zIndex: 999,\n pointerEvents: 'auto',\n color: theme.palette.grey[700],\n backgroundColor: theme.palette.grey[100],\n\n '&:hover': {\n color: theme.palette.grey[900],\n backgroundColor: theme.palette.grey[300],\n },\n}));\n\nexport const DragWrapper = styled('div')({\n position: 'relative',\n zIndex: 1,\n userSelect: 'none',\n '&:hover': {\n zIndex: 2,\n },\n});\n\nexport const FrameFileThumbnail = styled(Stack, {\n shouldForwardProp: prop => !['isDragging'].includes(prop as string),\n})<{\n width: number;\n isDragging: boolean;\n}>(({ theme, width, isDragging }) => ({\n width,\n height: 100,\n alignItems: 'center',\n display: 'inline-flex',\n justifyContent: 'center',\n margin: theme.spacing(0.5),\n padding: theme.spacing(2, 1, 2, 1),\n gap: theme.spacing(1),\n borderRadius: theme.spacing(1.25),\n overflow: 'hidden',\n position: 'relative',\n border: `solid 1px ${theme.palette.divider}`,\n backgroundColor: theme.palette.common.white,\n zIndex: 1,\n transition: 'box-shadow 150ms ease-in-out',\n boxShadow: !isDragging\n ? '0px 0px 0px 0px rgba(0, 0, 0, 0)'\n : `0 0 0 2px ${theme.palette.primary.main}, ${theme.customShadows.z8}, inset 0 0 0 1000px ${alpha(\n theme.palette.primary.main,\n 0.06,\n )}`,\n}));\n\nexport const FrameImageThumbnail = styled(m.div)<{\n width: number;\n isDragging: boolean;\n}>(({ theme, width, isDragging }) => ({\n width,\n height: 60,\n alignItems: 'center',\n display: 'inline-flex',\n justifyContent: 'center',\n margin: theme.spacing(0.5),\n padding: theme.spacing(2),\n borderRadius: theme.spacing(1.25),\n overflow: 'hidden',\n position: 'relative',\n border: `solid 1px ${theme.palette.divider}`,\n backgroundColor: theme.palette.common.white,\n zIndex: 1,\n transition: 'box-shadow 150ms ease-in-out',\n boxShadow: !isDragging\n ? '0px 0px 0px 0px rgba(0, 0, 0, 0)'\n : `0 0 0 2px ${theme.palette.primary.main}, ${theme.customShadows.z8}, inset 0 0 0 1000px ${alpha(\n theme.palette.primary.main,\n 0.06,\n )}`,\n}));\n\nexport const DeleteButton = styled(IconButton)(({ theme }) => ({\n top: 16,\n right: 16,\n zIndex: 9,\n position: 'absolute',\n color: theme.palette.common.white,\n backgroundColor: alpha(theme.palette.grey[900], 0.72),\n '&:hover': {\n backgroundColor: alpha(theme.palette.grey[900], 0.48),\n },\n}));\n\nexport const BoxUpload = styled(Box, {\n shouldForwardProp: prop =>\n prop !== 'isDragActive' && prop !== 'disabled' && prop !== 'hasError',\n})<{\n isDragActive: boolean;\n disabled: boolean;\n hasError: boolean;\n}>(({ theme, isDragActive, disabled, hasError }) => ({\n width: 64,\n height: 64,\n flexShrink: 0,\n display: 'flex',\n borderRadius: 1,\n cursor: 'pointer',\n alignItems: 'center',\n color: theme.palette.text.disabled,\n justifyContent: 'center',\n backgroundColor: alpha(theme.palette.grey[500], 0.08),\n border: `dashed 1px ${alpha(theme.palette.grey[500], 0.16)}`,\n ...(isDragActive && { opacity: 0.72 }),\n ...(disabled && { opacity: 0.48, pointerEvents: 'none' }),\n ...(hasError && {\n color: theme.palette.error.main,\n borderColor: theme.palette.error.main,\n backgroundColor: alpha(theme.palette.error.main, 0.08),\n }),\n '&:hover': { opacity: 0.72 },\n}));\n\nexport const SingleFilePreviewBox = styled(Box)(({ theme }) => ({\n padding: theme.spacing(1),\n top: 0,\n left: 0,\n width: '100%',\n height: '100%',\n position: 'absolute',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n transition: 'all 0.3s ease-in-out',\n filter: 'blur(0)',\n '&:hover .single-file-preview-img': {\n filter: 'blur(3px)',\n transition: 'all 0.1s ease-in-out',\n },\n '&:hover .single-file-preview-hover-overlay': {\n opacity: 1,\n },\n}));\n\nexport const SingleFilePreviewImg = styled('img', {\n shouldForwardProp: prop =>\n prop !== 'aspectRatio' &&\n prop !== 'isLoading' &&\n prop !== 'isUploading' &&\n prop !== 'maxWidth' &&\n prop !== 'maxHeight' &&\n prop !== 'cropSize' &&\n prop !== 'fill',\n})<\n LoadingPreviewImageProps & {\n maxWidth: number | string;\n maxHeight: number | string;\n }\n>(\n ({\n theme,\n aspectRatio,\n maxWidth,\n maxHeight,\n isLoading,\n isUploading,\n fill,\n }) => ({\n borderRadius: theme.shape.borderRadius,\n objectFit: 'cover',\n position: 'absolute',\n top: '50%',\n left: '50%',\n transform: 'translate(-50%, -50%) scale(1)',\n filter: 'blur(0)',\n zIndex: 1,\n backgroundColor: theme.palette.background.paper,\n ...(fill && {\n width: '100%',\n height: '100%',\n }),\n ...(!fill &&\n Math.abs(aspectRatio) >= 1 && {\n maxWidth,\n maxHeight,\n aspectRatio: Math.abs(aspectRatio),\n width: 'calc(100% - 16px)',\n height: undefined,\n }),\n ...(!fill &&\n Math.abs(aspectRatio) < 1 && {\n maxWidth,\n maxHeight,\n aspectRatio: Math.abs(aspectRatio),\n width: undefined,\n height: 'calc(100% - 16px)',\n }),\n transition: 'all 0.3s ease-in-out',\n ...(isLoading || isUploading\n ? {\n opacity: 0,\n filter: 'blur(1.5rem)',\n transform: 'translate(-50%, -50%) scale(0.7)',\n }\n : {}),\n }),\n);\n\nexport const SingleFilePreviewBlurImg = styled('img', {\n shouldForwardProp: prop => prop !== 'isLoading' && prop !== 'isUploading',\n})<{\n isLoading?: boolean;\n isUploading?: boolean;\n}>(({ isLoading, isUploading }) => ({\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n top: 0,\n left: 0,\n filter: 'blur(1.5rem)',\n transform: 'scale(1.1)',\n position: 'absolute',\n zIndex: 0,\n transition: 'opacity 0.3s ease-in-out',\n ...(isLoading && { opacity: 0 }),\n ...(isUploading && { opacity: 0.7, filter: 'blur(2rem)' }),\n}));\n\nexport const SingleFilePreviewHoverOverlay = styled(Stack)(({ theme }) => ({\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: alpha(theme.palette.primary.darker, 0.75),\n zIndex: 2,\n pointerEvents: 'none',\n opacity: 0,\n transition: 'opacity 0.3s ease-in-out',\n}));\n\nexport const AvatarContainer = styled(Stack)({\n width: '100%',\n height: '100%',\n position: 'relative',\n overflow: 'hidden',\n borderRadius: '50%',\n justifyContent: 'center',\n alignItems: 'center',\n});\n\nexport const RejectionFilesPaper = styled(Paper)(({ theme }) => ({\n py: 1,\n px: 2,\n mt: 3,\n textAlign: 'left',\n borderStyle: 'dashed',\n borderColor: 'error.main',\n backgroundColor: alpha(theme.palette.error.main, 0.08),\n}));\n\nexport const UploadPlaceholder = styled(Box, {\n shouldForwardProp: prop => prop !== 'isError' && prop !== 'hasFile',\n})<{ isError: boolean; hasFile: boolean }>(({ theme, isError, hasFile }) => ({\n top: 0,\n gap: theme.spacing(1),\n left: 0,\n width: '100%',\n height: '100%',\n zIndex: 9,\n display: 'flex',\n borderRadius: '50%',\n position: 'absolute',\n alignItems: 'center',\n color: theme.palette.text.disabled,\n flexDirection: 'column',\n justifyContent: 'center',\n backgroundColor: alpha(theme.palette.grey[500], 0.08),\n transition: theme.transitions.create(['opacity'], {\n duration: theme.transitions.duration.shorter,\n }),\n '&:hover': { opacity: 0.92 },\n ...(isError && {\n color: theme.palette.error.main,\n }),\n ...(hasFile && {\n zIndex: 9,\n opacity: 0,\n color: theme.palette.common.white,\n backgroundColor: alpha(theme.palette.common.black, 0.54),\n }),\n}));\n\nexport const PlaceholderLoading = styled(Stack)({\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n position: 'absolute',\n zIndex: 10,\n alignItems: 'center',\n justifyContent: 'center',\n opacity: 0.8,\n});\n\nexport const PlaceholderUploadImageAltBox = styled(Stack)(({ theme }) => ({\n padding: 20,\n justifyContent: 'center',\n alignItems: 'center',\n gap: 4,\n alignSelf: 'stretch',\n borderRadius: 12,\n background: theme.palette.divider,\n color: theme.palette.text.disabled,\n height: 160,\n}));\n\nexport const UploadAvatarBox = styled(Box, {\n shouldForwardProp: prop =>\n prop !== 'isDragActive' && prop !== 'isError' && prop !== 'hasFile',\n})<{\n isDragActive: boolean;\n disabled?: string;\n isError: boolean;\n hasFile: boolean;\n}>(({ theme, isDragActive, disabled, isError, hasFile }) => ({\n padding: theme.spacing(1),\n margin: 'auto',\n width: 144,\n height: 144,\n cursor: 'pointer',\n overflow: 'hidden',\n borderRadius: '50%',\n border: `1px dashed ${theme.palette.divider}`,\n ...(isDragActive && { opacity: 0.72 }),\n ...(disabled && { opacity: 0.48, pointerEvents: 'none' }),\n ...(isError && { borderColor: 'error.main' }),\n ...(hasFile && {\n ...(isError && {\n bgcolor: alpha(theme.palette.error.main, 0.08),\n }),\n '&:hover .upload-placeholder': { opacity: 1 },\n '& img': {\n filter: 'blur(0)',\n },\n '&:hover img': {\n filter: 'blur(3px)',\n },\n }),\n}));\n\nexport const ImagePreview = styled('img')({\n width: '100%',\n height: '100%',\n borderRadius: '50%',\n objectFit: 'cover',\n transition: 'all 0.3s ease-in-out',\n});\n\nexport const ActionsIconButton = styled(IconButton)<{\n icon: string;\n}>(({ theme }) => ({\n backgroundColor: alpha(theme.palette.grey[900], 0.72),\n color: theme.palette.common.white,\n '&:hover': {\n backgroundColor: alpha(theme.palette.grey[600], 0.64),\n color: theme.palette.common.white,\n },\n '& svg': {\n width: 14,\n height: 14,\n },\n}));\n","import { memo } from 'react';\nimport Badge from '@mui/material/Badge';\n\nimport { varFade } from 'components/animate';\nimport DragButton from 'components/DragButton';\nimport { FileThumbnail } from 'components/FileUpload';\n\nimport { ThumbnailBadgeProps } from '../props';\nimport { Actions, ActionsIconButton, FrameImageThumbnail } from '../styles';\n\nconst ThumbnailBadge = ({\n onRemove,\n sx,\n file,\n disableDrag,\n attributes,\n listeners,\n innerWidth,\n isDragging,\n}: ThumbnailBadgeProps) => {\n const id = file?.id;\n if (!id) return null;\n\n return (\n <Badge\n key={`badge-${id}`}\n anchorOrigin={{ vertical: 'top', horizontal: 'left' }}\n >\n <FrameImageThumbnail\n width={innerWidth}\n isDragging={isDragging}\n data-testid={`preview-multi-img-${id}`}\n {...varFade().inUp}\n sx={sx}\n >\n <DragButton disableDrag={disableDrag} {...attributes} {...listeners} />\n\n <FileThumbnail imageView file={file} />\n\n <Actions sx={{ position: 'absolute', right: 3, top: 3, zIndex: 1 }}>\n {onRemove && (\n <ActionsIconButton\n size=\"small\"\n label=\"Remover arquivo\"\n onClick={() => onRemove(file)}\n icon=\"DELETE_MARK_BUTTON_02\"\n />\n )}\n </Actions>\n </FrameImageThumbnail>\n </Badge>\n );\n};\n\nexport default memo(ThumbnailBadge);\n","import { memo, useRef } from 'react';\n\nimport type { SingleFilePreviewProps } from '../props';\nimport {\n SingleFilePreviewBlurImg,\n SingleFilePreviewBox,\n SingleFilePreviewHoverOverlay,\n} from '../styles';\n\nimport LoadingPreviewImage from './LoadingPreviewImage';\n\nconst SingleFilePreview = ({\n file,\n aspectRatio = 1,\n isUploading,\n isLoading,\n onLoading,\n cropSize,\n maxWidth,\n maxHeight,\n hoverAlt,\n fill,\n}: SingleFilePreviewProps) => {\n const imageRef = useRef<HTMLImageElement>(null);\n const fileId = file?.id || '';\n const fileName = file?.name || '';\n const previewUrl = URL.createObjectURL(file);\n\n if (!fileId) {\n return null;\n }\n\n return (\n <SingleFilePreviewBox className=\"single-file-preview-box\">\n <LoadingPreviewImage\n className=\"single-file-preview-img\"\n key={`image-preview-${fileId}`}\n aspectRatio={aspectRatio}\n cropSize={cropSize}\n isLoading={isLoading}\n isUploading={isUploading}\n alt={fileName}\n src={previewUrl}\n ref={imageRef}\n loading=\"lazy\"\n onLoading={onLoading}\n onLoad={() => onLoading?.(false)}\n onError={() => onLoading?.(false)}\n maxWidth={maxWidth}\n maxHeight={maxHeight}\n fill={fill}\n />\n <SingleFilePreviewBlurImg\n className=\"single-file-preview-bg\"\n alt={fileName}\n src={previewUrl}\n isLoading={isLoading}\n isUploading={isUploading}\n />\n\n {hoverAlt && (\n <SingleFilePreviewHoverOverlay className=\"single-file-preview-hover-overlay\">\n {hoverAlt}\n </SingleFilePreviewHoverOverlay>\n )}\n </SingleFilePreviewBox>\n );\n};\n\nexport default memo(SingleFilePreview);\n","import { forwardRef, useLayoutEffect, useMemo } from 'react';\n\nimport useMount from 'hooks/useMount';\n\nimport { LoadingPreviewImageProps } from '../props';\nimport { SingleFilePreviewImg } from '../styles';\n\n// Componente de imagem que gerencia o estado de carrisLoadingegamento e o cálculo de tamanho\nconst LoadingPreviewImage = forwardRef<\n HTMLImageElement,\n LoadingPreviewImageProps\n>(({ onLoading, aspectRatio, cropSize, ...props }, imageRef) => {\n const { maxWidth, maxHeight } = useMemo(() => {\n if (cropSize && typeof cropSize === 'object') {\n return {\n maxWidth: cropSize.width,\n maxHeight: cropSize.height,\n };\n }\n if (cropSize && typeof cropSize === 'number') {\n return {\n maxWidth: cropSize,\n maxHeight: cropSize,\n };\n }\n\n return {\n maxWidth: '100%',\n maxHeight: '100%',\n };\n }, [cropSize]);\n\n useMount(() => {\n onLoading?.(true);\n });\n\n useLayoutEffect(() => {\n if (typeof imageRef === 'object' && imageRef?.current) {\n onLoading?.(!imageRef.current.complete);\n } else {\n onLoading?.(false);\n }\n }, [imageRef, onLoading]);\n\n function handleFinish() {\n onLoading?.(false);\n }\n\n return (\n <SingleFilePreviewImg\n {...props}\n maxWidth={maxWidth}\n maxHeight={maxHeight}\n ref={imageRef}\n aspectRatio={aspectRatio}\n onLoad={handleFinish}\n onError={handleFinish}\n />\n );\n});\n\nLoadingPreviewImage.displayName = 'LoadingPreviewImage';\n\nexport default LoadingPreviewImage;\n","import Box from '@mui/material/Box';\nimport ButtonBase from '@mui/material/ButtonBase';\nimport IconButton from '@mui/material/IconButton';\nimport Stack from '@mui/material/Stack';\nimport Tooltip from '@mui/material/Tooltip';\n\nimport Icon from 'components/Icon';\nimport { Icon as IconEnum } from 'types/icon';\n\nimport type { FileThumbnailProps } from './types';\nimport { fileFormat, fileThumb } from './utils';\n\nexport const fileThumbnailClasses = {\n root: 'mnl__file__thumbnail__root',\n img: 'mnl__file__thumbnail__img',\n icon: 'mnl__file__thumbnail__icon',\n removeBtn: 'mnl__file__thumbnail__remove__button',\n downloadBtn: 'mnl__file__thumbnail__download__button',\n};\n\nexport const FileThumbnail = ({\n sx,\n file,\n tooltip,\n onRemove,\n imageView,\n slotProps,\n onDownload,\n ...other\n}: FileThumbnailProps) => {\n const previewUrl = URL.createObjectURL(file);\n const name = file?.name || '';\n const isImageFile = file.type.startsWith('image/');\n const format = isImageFile ? 'image' : fileFormat(previewUrl);\n\n const renderImg = (\n <Box\n component=\"img\"\n src={previewUrl}\n className={fileThumbnailClasses.img}\n sx={{\n width: 1,\n height: 1,\n objectFit: 'cover',\n borderRadius: 'inherit',\n ...slotProps?.img,\n }}\n />\n );\n\n const renderIcon = (\n <Icon\n icon={fileThumb(format) as keyof typeof IconEnum}\n sx={{\n width: 32,\n height: 32,\n flexShrink: 0,\n ...sx,\n }}\n />\n );\n\n const renderContent = (\n <Stack\n component=\"span\"\n className={fileThumbnailClasses.root}\n sx={{\n width: 36,\n height: 36,\n flexShrink: 0,\n borderRadius: 1.25,\n alignItems: 'center',\n position: 'relative',\n display: 'inline-flex',\n justifyContent: 'center',\n ...sx,\n }}\n {...other}\n >\n {format === 'image' && imageView ? renderImg : renderIcon}\n\n {onRemove && (\n <ButtonBase\n onClick={onRemove}\n className={fileThumbnailClasses.removeBtn}\n sx={slotProps?.removeBtn}\n >\n <Icon icon=\"CLOSE_MARK_BUTTON\" width={24} />\n </ButtonBase>\n )}\n\n {onDownload && (\n <IconButton\n onClick={onDownload}\n className={fileThumbnailClasses.downloadBtn}\n sx={slotProps?.downloadBtn}\n size=\"small\"\n >\n <Icon icon=\"ARROW_DOWN_CICLE\" width={12} />\n </IconButton>\n )}\n </Stack>\n );\n\n if (tooltip) {\n return (\n <Tooltip\n arrow\n title={name}\n slotProps={{\n popper: {\n modifiers: [{ name: 'offset', options: { offset: [0, -12] } }],\n },\n }}\n >\n {renderContent}\n </Tooltip>\n );\n }\n\n return renderContent;\n};\n","import { useEffect, useMemo, useRef, useState } from 'react';\nimport { FileRejection, useDropzone } from 'react-dropzone';\nimport { Area } from 'react-easy-crop';\n\nimport useApiMessage from 'hooks/useApiMessage';\nimport { fData } from 'utils/formatNumber';\n\nimport {\n ExtendFile,\n UseDropzoneUploaderProps,\n UseDropzoneUploaderReturn,\n} from '../props';\nimport { compressImageWithoutCrop, convertToWebP } from '../utils';\n\nconst useDropzoneUploader = ({\n onFilesSelect,\n onFileSelect,\n onReorder,\n onRemove,\n uploadFiles,\n filesPreview,\n dropzoneOptions,\n enableCrop = false,\n customAspectRatio,\n convertToWebp = true,\n cropSize,\n maxFiles,\n compressionQuality = 0.8,\n maxCompressedWidth,\n maxCompressedHeight,\n}: UseDropzoneUploaderProps): UseDropzoneUploaderReturn => {\n const { showErrorMessage } = useApiMessage();\n\n const aspectRatio = useMemo(() => {\n if (customAspectRatio) {\n return customAspectRatio;\n }\n\n if (cropSize && typeof cropSize !== 'number') {\n return cropSize.width / cropSize.height;\n }\n\n return 1;\n }, [customAspectRatio, cropSize]);\n\n const [internalFiles, setInternalFiles] = useState<Array<ExtendFile>>([]);\n const [cropModalOpen, setCropModalOpen] = useState(false);\n const [originalImage, setOriginalImage] = useState<File | null>(null);\n const [croppedAreaPixels, setCroppedAreaPixels] = useState<Area | null>(null);\n const [imagePreview, setImagePreview] = useState<string>('');\n const [cropLoading, setCropLoading] = useState(false);\n const [pendingImages, setPendingImages] = useState<Array<ExtendFile>>([]);\n const [currentImageIndex, setCurrentImageIndex] = useState<number>(0);\n const [totalPendingImages, setTotalPendingImages] = useState<number>(0);\n\n const processNextImage = (images: Array<ExtendFile>) => {\n if (images.length < 1) return;\n const nextImageData = images[0];\n setOriginalImage(nextImageData);\n setCurrentImageIndex(prev => prev + 1);\n\n const reader = new FileReader();\n reader.onload = () => {\n setImagePreview(reader.result as string);\n setCropModalOpen(true);\n };\n reader.readAsDataURL(nextImageData);\n };\n\n const onCropInitialized = (_croppedArea: Area, croppedAreaPixels: Area) => {\n setCroppedAreaPixels(croppedAreaPixels);\n };\n\n const createCroppedImage = async (\n fileId: string,\n ): Promise<ExtendFile | null> => {\n if (!originalImage || !croppedAreaPixels) return null;\n\n return new Promise(resolve => {\n const canvas = document.createElement('canvas');\n const ctx = canvas.getContext('2d');\n const img = new Image();\n\n img.onload = async () => {\n const { width, height, x, y } = croppedAreaPixels;\n const ratio = Math.abs(aspectRatio);\n let finalWidth = width;\n let finalHeight = height;\n\n if (cropSize && typeof cropSize === 'object') {\n finalWidth = cropSize.width;\n finalHeight = cropSize.height;\n } else if (cropSize && typeof cropSize === 'number') {\n finalWidth = cropSize;\n finalHeight = cropSize / ratio;\n }\n\n canvas.width = finalWidth;\n canvas.height = finalHeight;\n\n if (ctx) {\n ctx.drawImage(\n img,\n x,\n y,\n width,\n height,\n 0,\n 0,\n finalWidth,\n finalHeight,\n );\n\n canvas.toBlob(async blob => {\n if (blob) {\n let croppedFile = new File([blob], originalImage.name, {\n type: originalImage.type,\n lastModified: Date.now(),\n });\n\n if (convertToWebp) {\n try {\n croppedFile = await convertToWebP(\n croppedFile,\n compressionQuality,\n );\n } catch (error) {\n showErrorMessage(error, 'Erro ao converter para WebP');\n }\n }\n\n // Converter File para ExtendFile adicionando o ID\n const extendedFile = croppedFile as ExtendFile;\n extendedFile.id = fileId;\n\n resolve(extendedFile);\n } else {\n resolve(null);\n }\n }, 'image/png');\n } else {\n resolve(null);\n }\n };\n\n img.src = imagePreview;\n });\n };\n\n const handleCropSave = async () => {\n if (!originalImage || !croppedAreaPixels || pendingImages.length === 0)\n return;\n\n setCropLoading(true);\n try {\n const currentImageData = pendingImages[0];\n const croppedImage = await createCroppedImage(currentImageData.id);\n\n if (croppedImage) {\n const files = await uploadFiles([croppedImage]);\n if (files) {\n if (!onFilesSelect && !onFileSelect) {\n setInternalFiles(prev => [...prev, ...files]);\n }\n onFilesSelect?.([...(filesPreview || []), ...files]);\n onFileSelect?.(croppedImage);\n }\n }\n\n setCropModalOpen(false);\n setCropLoading(false);\n setImagePreview('');\n setOriginalImage(null);\n\n const remainingImages = pendingImages.slice(1);\n setPendingImages(remainingImages);\n processNextImage(remainingImages);\n } catch (error) {\n showErrorMessage(error, 'Erro ao processar imagem');\n setCropLoading(false);\n }\n };\n\n const handleCropCancel = () => {\n setCropModalOpen(false);\n setCropLoading(false);\n setImagePreview('');\n setOriginalImage(null);\n setPendingImages([]);\n setCurrentImageIndex(0);\n setTotalPendingImages(0);\n };\n\n const onDrop = async (acceptedFiles: File[]) => {\n if (acceptedFiles.length === 0) return;\n\n const isImageUpload = Object.keys(dropzoneOptions?.accept || {}).some(key =>\n key.includes('image/'),\n );\n const totalFiles = internalFiles.length + acceptedFiles.length;\n\n if (maxFiles && totalFiles > maxFiles) {\n showErrorMessage(\n new Error(`Máximo de ${maxFiles} arquivos`),\n 'Erro ao fazer upload',\n );\n return;\n }\n\n try {\n if (isImageUpload && enableCrop) {\n const imageFiles = acceptedFiles.filter(file =>\n file.type.startsWith('image/'),\n );\n\n const imageFilesWithTempIds = imageFiles.map((file, index) => {\n const extendedFile = file as ExtendFile;\n extendedFile.id = `temp-crop-${Date.now()}-${index}`;\n return extendedFile;\n });\n\n setTotalPendingImages(imageFilesWithTempIds.length);\n setCurrentImageIndex(0);\n setPendingImages(imageFilesWithTempIds);\n processNextImage(imageFilesWithTempIds);\n } else {\n const processedFiles: File[] = [];\n\n for (const file of acceptedFiles) {\n if (file.type.startsWith('image/') && convertToWebp) {\n try {\n const compressedFile = await compressImageWithoutCrop(\n file,\n compressionQuality,\n maxCompressedWidth,\n maxCompressedHeight,\n );\n processedFiles.push(compressedFile);\n } catch (error) {\n showErrorMessage(error, 'Erro ao comprimir imagem');\n processedFiles.push(file);\n }\n } else {\n processedFiles.push(file);\n }\n }\n\n const files = await uploadFiles(processedFiles);\n if (files) {\n if (!onFilesSelect && !onFileSelect) {\n setInternalFiles(prev => [...prev, ...files]);\n }\n onFilesSelect?.([...(filesPreview || []), ...files]);\n onFileSelect?.(files[0]);\n }\n }\n } catch (error) {\n showErrorMessage(error, 'Erro ao processar arquivos');\n }\n };\n\n const handleDropRejected = (fileRejections: FileRejection[]) => {\n if (!fileRejections.length) return;\n\n const errorCode = fileRejections[0]?.errors[0]?.code;\n const maxSizeInBytes = dropzoneOptions?.maxSize || 3145728; // 3MB padrão\n if (errorCode === 'file-too-large') {\n showErrorMessage(\n new Error(\n `O arquivo excede o tamanho máximo de ${fData(maxSizeInBytes)}`,\n ),\n 'Erro ao fazer upload',\n );\n } else if (errorCode === 'file-invalid-type') {\n showErrorMessage(\n new Error('Formato de arquivo não suportado'),\n 'Erro ao fazer upload',\n );\n } else {\n showErrorMessage(\n fileRejections[0]?.errors[0] || new Error('Erro ao enviar arquivo'),\n 'Erro ao fazer upload',\n );\n }\n };\n\n const {\n getRootProps,\n getInputProps,\n isDragActive,\n isDragReject,\n fileRejections,\n } = useDropzone({\n onDrop,\n onDropRejected: handleDropRejected,\n ...dropzoneOptions,\n });\n\n const handleRemove = (fileToRemove?: ExtendFile) => {\n if (!fileToRemove) {\n if (!onRemove) setInternalFiles([]);\n onRemove?.(undefined);\n return;\n }\n\n const newFiles = internalFiles.filter(file => file.id !== fileToRemove.id);\n if (!onRemove) setInternalFiles(newFiles);\n onRemove?.(fileToRemove);\n };\n\n const handleReorder = (\n oldIndex: number,\n newIndex: number,\n files: ExtendFile[],\n ) => {\n onReorder?.(oldIndex, newIndex, files);\n };\n\n const filesIdRef = useRef<string>('');\n useEffect(() => {\n const idRef = filesPreview?.map(file => file.id).join(',') || '';\n if (idRef !== filesIdRef.current) {\n filesIdRef.current = idRef;\n setInternalFiles(filesPreview || []);\n }\n }, [filesPreview]);\n\n return {\n file: internalFiles?.[0],\n files: internalFiles,\n aspectRatio,\n dropzoneProps: {\n getRootProps,\n getInputProps,\n isDragActive,\n isDragReject,\n fileRejections,\n },\n cropState: {\n cropModalOpen,\n imagePreview,\n cropLoading,\n setCropModalOpen,\n onCropInitialized,\n handleCropSave,\n handleCropCancel,\n currentImageIndex,\n totalPendingImages,\n },\n setInitialFiles: setInternalFiles,\n handleRemove,\n handleReorder,\n };\n};\n\nexport default useDropzoneUploader;\n","export const isImageFile = (mimeType: string): boolean => {\n return mimeType.startsWith('image/');\n};\n\nexport const convertToWebP = (file: File, quality = 0.8): Promise<File> => {\n return new Promise((resolve, reject) => {\n const canvas = document.createElement('canvas');\n const ctx = canvas.getContext('2d');\n const img = new Image();\n\n img.onload = () => {\n canvas.width = img.width;\n canvas.height = img.height;\n\n if (ctx) {\n ctx.drawImage(img, 0, 0);\n\n canvas.toBlob(\n blob => {\n if (blob) {\n const webpFile = new File(\n [blob],\n file.name.replace(/\\.[^/.]+$/, '.webp'),\n {\n type: 'image/webp',\n lastModified: Date.now(),\n },\n );\n resolve(webpFile);\n } else {\n reject(new Error('Falha ao converter para WebP'));\n }\n },\n 'image/webp',\n quality,\n );\n } else {\n reject(new Error('Não foi possível obter contexto do canvas'));\n }\n };\n\n img.onerror = () => reject(new Error('Falha ao carregar imagem'));\n img.src = URL.createObjectURL(file);\n });\n};\n\nexport const compressImageWithoutCrop = (\n file: File,\n quality = 0.8,\n maxWidth?: number,\n maxHeight?: number,\n): Promise<File> => {\n return new Promise((resolve, reject) => {\n const canvas = document.createElement('canvas');\n const ctx = canvas.getContext('2d');\n const img = new Image();\n\n img.onload = () => {\n let { width, height } = img;\n\n if (maxWidth && width > maxWidth) {\n height = (height * maxWidth) / width;\n width = maxWidth;\n }\n if (maxHeight && height > maxHeight) {\n width = (width * maxHeight) / height;\n height = maxHeight;\n }\n\n canvas.width = width;\n canvas.height = height;\n\n if (ctx) {\n ctx.imageSmoothingEnabled = true;\n ctx.imageSmoothingQuality = 'high';\n\n ctx.drawImage(img, 0, 0, width, height);\n\n canvas.toBlob(\n blob => {\n if (blob) {\n const compressedFile = new File(\n [blob],\n file.name.replace(/\\.[^/.]+$/, '.webp'),\n {\n type: 'image/webp',\n lastModified: Date.now(),\n },\n );\n resolve(compressedFile);\n } else {\n reject(new Error('Falha ao comprimir imagem'));\n }\n },\n 'image/webp',\n quality,\n );\n } else {\n reject(new Error('Não foi possível obter contexto do canvas'));\n }\n };\n\n img.onerror = () => reject(new Error('Falha ao carregar imagem'));\n img.src = URL.createObjectURL(file);\n });\n};\n\nexport const getFileNameFromContentDisposition = (\n contentDisposition: string,\n): string => {\n const match = contentDisposition.match(\n /filename\\*=UTF-8''([^;]+)|filename=\"?([^\";]+)\"?/i,\n );\n const filename = match?.[1] || match?.[2];\n\n return filename || '';\n};\n\nexport const encodeFilenameForHeader = (filename: string): string => {\n const encodedFilename = encodeURIComponent(filename);\n\n return `UTF-8''${encodedFilename}`;\n};\n","import { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport useApiMessage from 'hooks/useApiMessage';\n\nimport {\n ContentType,\n ExtendFile,\n FileContentType,\n FileDetails,\n FileUploadProps,\n} from '../props';\nimport {\n encodeFilenameForHeader,\n getFileNameFromContentDisposition,\n} from '../utils';\n\nconst useFileUploadService = ({\n createFilesMutation,\n filesDetails,\n}: FileUploadProps) => {\n const { showErrorMessage } = useApiMessage();\n const [isUploadingFiles, setIsUploadingFiles] = useState(false);\n const [isLoadingPreview, setIsLoadingPreview] = useState(false);\n const [uploadFilesError, setUploadFilesError] = useState<unknown | null>(\n null,\n );\n const [filesPreview, setFilesPreview] = useState<ExtendFile[]>([]);\n\n const filePreview = useMemo(() => filesPreview?.[0], [filesPreview]);\n const isUploadOrLoadingFiles = isLoadingPreview || isUploadingFiles;\n\n const fetchFiles = useCallback(\n async (details: FileDetails[]) => {\n if (!details.length) {\n setFilesPreview([]);\n setIsLoadingPreview(false);\n return;\n }\n\n setIsLoadingPreview(true);\n try {\n const newFiles = await Promise.all(\n details.map(async ({ url, id, name }) => {\n try {\n if (!url) return null;\n\n const response = await fetch(url);\n if (!response.ok) {\n throw new Error(response.statusText);\n }\n\n const blob = await response.blob();\n\n let nameFromDisposition: string | null = null;\n if (!name) {\n const contentDisposition =\n response.headers.get('content-disposition') || undefined;\n\n if (contentDisposition) {\n const filename =\n getFileNameFromContentDisposition(contentDisposition);\n if (filename) {\n try {\n nameFromDisposition = decodeURIComponent(filename);\n } catch {\n nameFromDisposition = filename;\n }\n }\n }\n }\n\n const filename = nameFromDisposition || name || id;\n const previewFile = new File([blob], filename, {\n type: blob.type,\n }) as ExtendFile;\n previewFile.id = id;\n previewFile.url = url;\n\n return previewFile;\n } catch (error) {\n return null;\n }\n }),\n );\n\n const validFiles = newFiles.filter(Boolean) as ExtendFile[];\n setFilesPreview(validFiles);\n setIsLoadingPreview(false);\n } catch (error) {\n showErrorMessage(error, 'Erro ao carregar arquivos');\n setFilesPreview([]);\n setIsLoadingPreview(false);\n }\n },\n [showErrorMessage],\n );\n\n const filesUrlRef = useRef('');\n useEffect(() => {\n const urlKey = filesDetails?.map(({ id }) => id).join(',') || '';\n\n if (urlKey !== filesUrlRef.current) {\n const run = async () => {\n filesUrlRef.current = urlKey;\n await fetchFiles(filesDetails);\n };\n\n run();\n }\n }, [filesDetails, fetchFiles]);\n\n const uploadFiles = async (files: File[]) => {\n if (!files || !Array.isArray(files)) {\n throw new Error('Arquivos inválidos');\n }\n\n const newFiles = files.filter(file => file instanceof File);\n if (!newFiles?.length) return;\n\n setIsUploadingFiles(true);\n\n try {\n const filesWithContentType = newFiles.map(file => {\n const mimeType =\n (file.type as ContentType) || ContentType.APPLICATION_OCTET_STREAM;\n const contentTypeEnum = FileContentType[mimeType];\n\n if (!contentTypeEnum) {\n throw new Error(`Tipo de arquivo não suportado: ${mimeType}`);\n }\n\n return { file, mimeType, contentTypeEnum };\n });\n\n const createResponse = await createFilesMutation({\n files: filesWithContentType.map(({ file, contentTypeEnum }) => ({\n content_type: contentTypeEnum,\n name: file.name,\n })),\n }).unwrap();\n\n // Converte cada File para ExtendFile adicionando o ID e URL recebidos\n const extendedFiles: ExtendFile[] = createResponse.files.map(\n (responseFile, index) => {\n const originalFile = filesWithContentType[index].file;\n const extendedFile = originalFile as ExtendFile;\n extendedFile.id = responseFile.id;\n extendedFile.url = URL.createObjectURL(originalFile);\n return extendedFile;\n },\n );\n\n // Upload dos arquivos com ID e nome no header\n const responses = await Promise.all(\n createResponse.files.map((responseFile, index) => {\n const { mimeType } = filesWithContentType[index];\n const extendedFile = extendedFiles[index];\n\n return fetch(responseFile.url, {\n method: 'PUT',\n headers: {\n 'Content-Type': mimeType,\n 'Content-Disposition': `inline; filename*=${encodeFilenameForHeader(extendedFile.name)}`,\n 'X-File-Id': responseFile.id,\n },\n body: extendedFile,\n });\n }),\n );\n\n // Garante que o upload foi concluído\n await responses.forEach(async response => {\n if (!response.ok) {\n throw new Error('Erro no upload do arquivo.');\n }\n });\n\n return extendedFiles;\n } catch (error) {\n setUploadFilesError(error);\n showErrorMessage(error, 'Erro no upload');\n throw error;\n } finally {\n setIsUploadingFiles(false);\n }\n };\n\n const uploadErrorText = useMemo(() => {\n if (uploadFilesError && uploadFilesError instanceof Error) {\n return uploadFilesError.message;\n }\n\n return uploadFilesError as string;\n }, [uploadFilesError]);\n\n return {\n setFilesPreview,\n uploadFiles,\n filesPreview,\n filePreview,\n isLoadingPreview,\n isUploadingFiles,\n isUploadOrLoadingFiles,\n uploadErrorText,\n };\n};\n\nexport default useFileUploadService;\n","import type {\n DropzoneInputProps,\n DropzoneRootProps,\n FileRejection,\n useDropzone,\n} from 'react-dropzone';\nimport type { DropzoneOptions } from 'react-dropzone';\nimport { Area } from 'react-easy-crop';\nimport {\n DraggableAttributes,\n DraggableSyntheticListeners,\n} from '@dnd-kit/core';\nimport type { StackProps } from '@mui/material/Stack';\nimport type { SxProps, Theme } from '@mui/material/styles';\n\nimport type { FileThumbnailProps } from 'components/FileUpload';\n\nexport interface ExtendFile extends File {\n id: string;\n url: string;\n}\n\nexport interface FileDetails {\n id: string;\n url: string;\n name?: string;\n}\n\nexport interface FileUpload {\n url: string;\n file: ExtendFile;\n contentType: string;\n resourceIds: string[];\n}\n\nexport type CropSize =\n | {\n width: number;\n height: number;\n }\n | number;\n\nexport type CreateFilesMutation = (\n files: ExtendFile[],\n) => Promise<string[] | undefined>;\n\nexport interface FileCreateRequest {\n files: Array<{\n content_type: keyof typeof ContentType;\n name: string;\n }>;\n}\n\nexport interface FileGetResponse {\n id: string;\n name: string;\n organization_id: string;\n url: string;\n status: 'PENDING' | 'COMPLETED' | 'FAILED';\n content_type: string;\n content_length: number;\n created_by: string;\n created_at: string;\n updated_by: string;\n updated_at: string;\n}\n\nexport interface FileCreateResponse {\n files: FileGetResponse[];\n}\n\nexport interface FileQueryRequest {\n ids: string[];\n}\n\nexport interface FileQueryResponse {\n files: FileGetResponse[];\n}\n\nexport interface SingleFilePreviewProps extends StackProps {\n file: ExtendFile;\n aspectRatio?: number;\n isLoading?: boolean;\n cropSize?: CropSize;\n onLoading?: (isLoading: boolean) => void;\n isUploading?: boolean;\n maxWidth?: number;\n maxHeight?: number;\n hoverAlt?: React.ReactNode;\n fill?: boolean;\n}\n\nexport interface LoadingPreviewImageProps\n extends React.ImgHTMLAttributes<HTMLImageElement> {\n aspectRatio: number;\n maxWidth?: number | string;\n maxHeight?: number | string;\n isLoading?: boolean;\n isUploading?: boolean;\n cropSize?: CropSize;\n onLoading?: (isLoading: boolean) => void;\n alt?: string;\n src?: string;\n loading: 'lazy';\n fill?: boolean;\n}\n\nexport interface PlaceholderProps extends StackProps {\n header?: React.ReactNode;\n description?: React.ReactNode;\n}\n\nexport interface FileUploadProps {\n createFilesMutation: (params: FileCreateRequest) => {\n unwrap: () => Promise<FileCreateResponse>;\n };\n filesDetails: FileDetails[];\n}\n\nexport interface SingleFileUploadProps extends DropzoneOptions {\n onRemove?: (file?: ExtendFile) => void;\n onFileSelect?: (file: ExtendFile) => void;\n createFilesMutation: FileUploadProps['createFilesMutation'];\n fileDetails?: FileDetails;\n placeholderProps?: PlaceholderProps;\n placeholderAlt?: React.ReactNode;\n name?: string;\n label?: string;\n id?: string;\n disabled?: boolean;\n error?: string;\n helperText?: string | React.ReactNode;\n sx?: SxProps<Theme>;\n dropZoneSxProps?: SxProps<Theme>;\n uploading?: boolean;\n tabIndex?: number;\n maxSize?: number;\n}\n\nexport interface SingleImageUploadProps extends SingleFileUploadProps {\n aspectRatio?: number;\n enableCrop?: boolean;\n convertToWebp?: boolean;\n cropSize?: CropSize;\n maxWidth?: number;\n maxHeight?: number;\n compressionQuality?: number;\n maxCompressedWidth?: number;\n maxCompressedHeight?: number;\n hoverAlt?: React.ReactNode;\n fill?: boolean;\n}\n\nexport interface MultiFileUploadProps\n extends Omit<SingleFileUploadProps, 'filesDetails' | 'onFileSelect'> {\n onFilesSelect?: (files: ExtendFile[]) => void;\n onRemoveAll?: (files?: ExtendFile[]) => void;\n onReorder?: (oldIndex: number, newIndex: number, files: ExtendFile[]) => void;\n filesDetails?: FileDetails[];\n maxFiles?: number;\n thumbnail?: boolean;\n}\n\nexport interface MultiImageUploadProps extends MultiFileUploadProps {\n aspectRatio?: number;\n enableCrop?: boolean;\n convertToWebp?: boolean;\n cropSize?: CropSize;\n maxWidth?: number;\n maxHeight?: number;\n compressionQuality?: number;\n maxCompressedWidth?: number;\n maxCompressedHeight?: number;\n}\n\nexport interface SortableItemProps extends StackProps {\n onRemove?: (file?: ExtendFile) => void;\n file: ExtendFile;\n thumbnail?: boolean;\n disableDrag?: boolean;\n disableTransitions?: boolean;\n}\n\nexport interface MultiFilePreviewProps extends StackProps {\n onReorder?: (oldIndex: number, newIndex: number, files: ExtendFile[]) => void;\n onRemove?: (file?: ExtendFile) => void;\n files: ExtendFile[];\n lastNode?: React.ReactNode;\n firstNode?: React.ReactNode;\n thumbnail: boolean;\n slotProps?: {\n thumbnail?: Omit<FileThumbnailProps, 'file'>;\n };\n}\n\nexport interface StyledDropZoneProps extends StackProps {\n isDragActive: boolean;\n isError: boolean;\n disabled: boolean;\n}\n\nexport type StyledDropZonePropsType = Omit<\n DropzoneRootProps,\n 'children' | 'onDrop' | 'onError'\n> &\n StyledDropZoneProps;\n\nexport interface RejectionFilesProps extends StackProps {\n files: FileRejection[];\n}\n\nexport interface ThumbnailBadgeProps {\n onRemove?: (file?: ExtendFile) => void;\n file: ExtendFile;\n attributes: DraggableAttributes;\n listeners: DraggableSyntheticListeners;\n innerWidth: number;\n isDragging: boolean;\n disableDrag?: boolean;\n sx?: SxProps<Theme>;\n}\n\nexport interface DropZoneProps {\n sx?: SxProps;\n uploading?: boolean;\n id?: string;\n tabIndex?: number;\n getRootProps: () => DropzoneRootProps;\n getInputProps: () => DropzoneInputProps;\n isDragActive: boolean;\n isError: boolean;\n disabled?: boolean;\n dropZoneSxProps?: SxProps<Theme>;\n dropZoneContent?: React.ReactNode;\n children?: React.ReactNode;\n name?: string;\n}\n\nexport interface HelperTextProps {\n helperText?: string | React.ReactNode;\n disabled?: boolean;\n isError?: boolean;\n}\n\nexport interface UseDropzoneUploaderProps {\n onReorder?: (oldIndex: number, newIndex: number, files: ExtendFile[]) => void;\n onFileSelect?: (file: ExtendFile) => void;\n onFilesSelect?: (files: ExtendFile[]) => void;\n onRemove?: (file?: ExtendFile) => void;\n uploadFiles: (files: File[]) => Promise<ExtendFile[] | undefined>;\n filesPreview?: ExtendFile[];\n dropzoneOptions?: Omit<DropzoneOptions, 'onDrop' | 'onDropRejected'>;\n enableCrop?: boolean;\n customAspectRatio?: number;\n convertToWebp?: boolean;\n maxFiles?: number;\n cropSize?: { width: number; height: number } | number;\n compressionQuality?: number;\n maxCompressedWidth?: number;\n maxCompressedHeight?: number;\n}\n\nexport interface UseDropzoneUploaderReturn {\n file: ExtendFile | null;\n files: ExtendFile[];\n aspectRatio: number;\n dropzoneProps: {\n getRootProps: ReturnType<typeof useDropzone>['getRootProps'];\n getInputProps: ReturnType<typeof useDropzone>['getInputProps'];\n isDragActive: boolean;\n isDragReject: boolean;\n fileRejections: readonly FileRejection[];\n };\n cropState: {\n cropModalOpen: boolean;\n imagePreview: string;\n cropLoading: boolean;\n setCropModalOpen: React.Dispatch<React.SetStateAction<boolean>>;\n onCropInitialized: (croppedArea: Area, croppedAreaPixels: Area) => void;\n handleCropSave: () => Promise<void>;\n handleCropCancel: () => void;\n currentImageIndex: number;\n totalPendingImages: number;\n };\n setInitialFiles?: (files: ExtendFile[]) => void;\n handleRemove: (fileToRemove?: ExtendFile) => void;\n handleReorder: (\n oldIndex: number,\n newIndex: number,\n files: ExtendFile[],\n ) => void;\n}\n\nexport enum ContentType {\n APPLICATION_OCTET_STREAM = 'application/octet-stream',\n IMAGE_JPEG = 'image/jpeg',\n IMAGE_JPG = 'image/jpg',\n IMAGE_PNG = 'image/png',\n IMAGE_GIF = 'image/gif',\n IMAGE_WEBP = 'image/webp',\n IMAGE_SVG = 'image/svg+xml',\n IMAGE_BMP = 'image/bmp',\n IMAGE_TIFF = 'image/tiff',\n IMAGE_ICO = 'image/x-icon',\n IMAGE_AVIF = 'image/avif',\n APPLICATION_PDF = 'application/pdf',\n TEXT_PLAIN = 'text/plain',\n TEXT_CSV = 'text/csv',\n APPLICATION_RTF = 'application/rtf',\n APPLICATION_MSWORD = 'application/msword',\n APPLICATION_DOCX = 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n APPLICATION_MSEXCEL = 'application/vnd.ms-excel',\n APPLICATION_XLSX = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n APPLICATION_MSPOWERPOINT = 'application/vnd.ms-powerpoint',\n APPLICATION_PPTX = 'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n APPLICATION_ODT = 'application/vnd.oasis.opendocument.text',\n APPLICATION_ODS = 'application/vnd.oasis.opendocument.spreadsheet',\n APPLICATION_ODP = 'application/vnd.oasis.opendocument.presentation',\n APPLICATION_XML = 'application/xml',\n TEXT_XML = 'text/xml',\n TEXT_HTML = 'text/html',\n TEXT_CSS = 'text/css',\n APPLICATION_JSON = 'application/json',\n TEXT_JAVASCRIPT = 'text/javascript',\n APPLICATION_ZIP = 'application/zip',\n APPLICATION_GZIP = 'application/gzip',\n APPLICATION_RAR = 'application/vnd.rar',\n APPLICATION_7Z = 'application/x-7z-compressed',\n AUDIO_MPEG = 'audio/mpeg',\n AUDIO_WAV = 'audio/wav',\n AUDIO_OGG = 'audio/ogg',\n AUDIO_WEBM = 'audio/webm',\n AUDIO_AAC = 'audio/aac',\n VIDEO_MP4 = 'video/mp4',\n VIDEO_MPEG = 'video/mpeg',\n VIDEO_OGG = 'video/ogg',\n VIDEO_WEBM = 'video/webm',\n VIDEO_QUICKTIME = 'video/quicktime',\n}\n\nexport enum FileContentType {\n 'application/octet-stream' = 'APPLICATION_OCTET_STREAM',\n 'image/jpeg' = 'IMAGE_JPEG',\n 'image/jpg' = 'IMAGE_JPG',\n 'image/png' = 'IMAGE_PNG',\n 'image/gif' = 'IMAGE_GIF',\n 'image/webp' = 'IMAGE_WEBP',\n 'image/svg+xml' = 'IMAGE_SVG',\n 'image/bmp' = 'IMAGE_BMP',\n 'image/tiff' = 'IMAGE_TIFF',\n 'image/x-icon' = 'IMAGE_ICO',\n 'image/avif' = 'IMAGE_AVIF',\n 'application/pdf' = 'APPLICATION_PDF',\n 'text/plain' = 'TEXT_PLAIN',\n 'text/csv' = 'TEXT_CSV',\n 'application/rtf' = 'APPLICATION_RTF',\n 'application/msword' = 'APPLICATION_MSWORD',\n 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' = 'APPLICATION_DOCX',\n 'application/vnd.ms-excel' = 'APPLICATION_MSEXCEL',\n 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' = 'APPLICATION_XLSX',\n 'application/vnd.ms-powerpoint' = 'APPLICATION_MSPOWERPOINT',\n 'application/vnd.openxmlformats-officedocument.presentationml.presentation' = 'APPLICATION_PPTX',\n 'application/vnd.oasis.opendocument.text' = 'APPLICATION_ODT',\n 'application/vnd.oasis.opendocument.spreadsheet' = 'APPLICATION_ODS',\n 'application/vnd.oasis.opendocument.presentation' = 'APPLICATION_ODP',\n 'application/xml' = 'APPLICATION_XML',\n 'text/xml' = 'TEXT_XML',\n 'text/html' = 'TEXT_HTML',\n 'text/css' = 'TEXT_CSS',\n 'application/json' = 'APPLICATION_JSON',\n 'text/javascript' = 'TEXT_JAVASCRIPT',\n 'application/zip' = 'APPLICATION_ZIP',\n 'application/gzip' = 'APPLICATION_GZIP',\n 'application/vnd.rar' = 'APPLICATION_RAR',\n 'application/x-7z-compressed' = 'APPLICATION_7Z',\n 'audio/mpeg' = 'AUDIO_MPEG',\n 'audio/wav' = 'AUDIO_WAV',\n 'audio/ogg' = 'AUDIO_OGG',\n 'audio/webm' = 'AUDIO_WEBM',\n 'audio/aac' = 'AUDIO_AAC',\n 'video/mp4' = 'VIDEO_MP4',\n 'video/mpeg' = 'VIDEO_MPEG',\n 'video/ogg' = 'VIDEO_OGG',\n 'video/webm' = 'VIDEO_WEBM',\n 'video/quicktime' = 'VIDEO_QUICKTIME',\n}\n","import { memo } from 'react';\nimport Box from '@mui/material/Box';\nimport Stack from '@mui/material/Stack';\n\nimport DropZone from './components/DropZone';\nimport DropZonePlaceholder from './components/DropZonePlaceholder';\nimport HelperText from './components/HelperText';\nimport MultiFilePreview from './components/MultiFilePreview';\nimport useDropzoneUploader from './hooks/useDropzoneUploader';\nimport useFileUploadService from './hooks/useFileUploadService';\nimport { MultiFileUploadProps } from './props';\n\nconst MultipleFileUpload = ({\n onRemove,\n onReorder,\n onFilesSelect,\n createFilesMutation,\n filesDetails = [],\n id,\n disabled,\n error,\n helperText,\n thumbnail,\n dropZoneSxProps,\n uploading,\n tabIndex,\n maxFiles,\n placeholderAlt,\n placeholderProps,\n ...other\n}: MultiFileUploadProps) => {\n const { filesPreview, isUploadOrLoadingFiles, uploadErrorText, uploadFiles } =\n useFileUploadService({\n createFilesMutation,\n filesDetails,\n });\n\n const { files, dropzoneProps, handleRemove, handleReorder } =\n useDropzoneUploader({\n onFilesSelect,\n onReorder,\n onRemove,\n filesPreview,\n dropzoneOptions: {\n multiple: true,\n disabled,\n ...other,\n },\n maxFiles,\n uploadFiles,\n });\n\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n dropzoneProps;\n const hasFiles = !!files?.filter(file => !!file.id).length;\n const isError = isDragReject || !!error || !!uploadErrorText;\n\n return (\n <DropZone\n id={id}\n uploading={uploading || isUploadOrLoadingFiles}\n disabled={disabled}\n dropZoneSxProps={dropZoneSxProps}\n tabIndex={tabIndex}\n getRootProps={getRootProps}\n getInputProps={getInputProps}\n isDragActive={isDragActive}\n isError={isError}\n dropZoneContent={\n <>\n {placeholderAlt ? (\n <Stack>{placeholderAlt}</Stack>\n ) : (\n <DropZonePlaceholder\n header={placeholderProps?.header}\n description={placeholderProps?.description}\n />\n )}\n </>\n }\n >\n <HelperText\n disabled={disabled}\n helperText={helperText}\n isError={isError}\n />\n {error ? <HelperText helperText={error} isError /> : null}\n {uploadErrorText ? (\n <HelperText helperText={uploadErrorText} isError />\n ) : null}\n\n {hasFiles && (\n <Box sx={{ my: 3 }}>\n <MultiFilePreview\n files={files}\n thumbnail={!!thumbnail}\n onRemove={onRemove ? handleRemove : undefined}\n onReorder={onReorder ? handleReorder : undefined}\n />\n </Box>\n )}\n </DropZone>\n );\n};\n\nexport default memo(MultipleFileUpload);\n","import Box from '@mui/material/Box';\n\nimport FixedProgressBar from 'components/FixedProgressBar';\n\nimport { DropZoneProps } from '../props';\nimport { Container, StyledDropZone } from '../styles';\n\nconst DropZone = ({\n sx,\n id,\n name,\n tabIndex,\n uploading,\n getRootProps,\n getInputProps,\n isDragActive,\n isError,\n disabled,\n dropZoneSxProps,\n dropZoneContent,\n children,\n ...props\n}: DropZoneProps) => {\n return (\n <Container>\n {uploading && (\n <FixedProgressBar\n data-testid=\"uploading-progress-bar\"\n sx={{ zIndex: 1 }}\n />\n )}\n <Box sx={{ width: 1, position: 'relative', ...sx }}>\n <StyledDropZone\n {...getRootProps()}\n data-testid=\"drop-zone-styled-area\"\n isError={isError}\n isDragActive={isDragActive}\n disabled={!!disabled}\n sx={dropZoneSxProps}\n {...props}\n >\n <input {...getInputProps()} id={id} tabIndex={tabIndex} name={name} />\n\n {dropZoneContent}\n </StyledDropZone>\n {children}\n </Box>\n </Container>\n );\n};\n\nexport default DropZone;\n","import { memo } from 'react';\nimport Stack from '@mui/material/Stack';\nimport Typography from '@mui/material/Typography';\n\nimport UploadIllustration from 'assets/illustrations/UploadIllustration';\n\nimport { PlaceholderProps } from '../props';\n\nconst DropZonePlaceholder = ({\n header,\n description,\n sx,\n ...other\n}: PlaceholderProps) => {\n return (\n <Stack\n spacing={5}\n alignItems=\"center\"\n justifyContent=\"center\"\n direction={{\n xs: 'column',\n md: 'row',\n }}\n sx={{\n width: 1,\n textAlign: {\n xs: 'center',\n md: 'left',\n },\n ...sx,\n }}\n {...other}\n >\n <UploadIllustration sx={{ width: 220 }} />\n\n <div>\n <Typography gutterBottom variant=\"h5\">\n {header || 'Soltar ou selecionar arquivos'}\n </Typography>\n\n <Typography variant=\"body2\" sx={{ color: 'text.secondary' }}>\n {description || (\n <>\n Solte os arquivos aqui ou clique\n <Typography\n variant=\"body2\"\n component=\"span\"\n sx={{\n mx: 0.5,\n color: 'primary.main',\n textDecoration: 'underline',\n }}\n >\n procurar\n </Typography>\n na sua máquina\n </>\n )}\n </Typography>\n </div>\n </Stack>\n );\n};\n\nexport default memo(DropZonePlaceholder);\n","import { memo, useMemo } from 'react';\nimport Box from '@mui/material/Box';\nimport Stack from '@mui/material/Stack';\n\nimport ImageCropModal from '../EasyCropModal';\n\nimport DropZone from './components/DropZone';\nimport DropZonePlaceholder from './components/DropZonePlaceholder';\nimport HelperText from './components/HelperText';\nimport MultiFilePreview from './components/MultiFilePreview';\nimport useDropzoneUploader from './hooks/useDropzoneUploader';\nimport useFileUploadService from './hooks/useFileUploadService';\nimport { MultiImageUploadProps } from './props';\n\nconst MultipleImageUpload = ({\n onRemove,\n onReorder,\n onFilesSelect,\n createFilesMutation,\n filesDetails = [],\n id,\n disabled,\n error,\n helperText,\n dropZoneSxProps,\n placeholderProps,\n placeholderAlt,\n uploading,\n tabIndex,\n maxFiles,\n aspectRatio: customAspectRatio,\n enableCrop = true,\n convertToWebp = true,\n cropSize,\n name,\n label: customLabel,\n ...other\n}: MultiImageUploadProps) => {\n const { filesPreview, isUploadOrLoadingFiles, uploadErrorText, uploadFiles } =\n useFileUploadService({\n createFilesMutation,\n filesDetails,\n });\n const isLoading = uploading || isUploadOrLoadingFiles;\n\n const {\n files,\n dropzoneProps,\n cropState,\n aspectRatio,\n handleRemove,\n handleReorder,\n } = useDropzoneUploader({\n onFilesSelect,\n onReorder,\n onRemove,\n filesPreview,\n dropzoneOptions: {\n accept: {\n 'image/*': ['.jpeg', '.jpg', '.png', '.gif', '.webp'],\n },\n multiple: true,\n disabled,\n ...other,\n },\n enableCrop,\n customAspectRatio,\n convertToWebp,\n maxFiles,\n cropSize,\n uploadFiles,\n });\n\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n dropzoneProps;\n\n const {\n cropModalOpen,\n imagePreview,\n cropLoading,\n onCropInitialized,\n handleCropSave,\n handleCropCancel,\n currentImageIndex,\n totalPendingImages,\n } = cropState;\n\n const hasFiles = !!files?.filter(file => !!file.id).length;\n const isError = isDragReject || !!error || !!uploadErrorText;\n\n const label = useMemo(() => {\n const labelText = customLabel ?? 'Ajustar Imagem';\n const labelProcessing =\n totalPendingImages > 1 || currentImageIndex > 1\n ? ` (${currentImageIndex} de ${totalPendingImages})`\n : '';\n return `${labelText}${labelProcessing}`;\n }, [customLabel, totalPendingImages, currentImageIndex]);\n\n return (\n <DropZone\n id={id}\n name={name}\n uploading={isLoading}\n disabled={disabled}\n dropZoneSxProps={dropZoneSxProps}\n tabIndex={tabIndex}\n getRootProps={getRootProps}\n getInputProps={getInputProps}\n isDragActive={isDragActive}\n isError={isError}\n dropZoneContent={\n <>\n {placeholderAlt ? (\n <Stack>{placeholderAlt}</Stack>\n ) : (\n <DropZonePlaceholder\n header={placeholderProps?.header}\n description={placeholderProps?.description}\n />\n )}\n </>\n }\n >\n <HelperText\n disabled={disabled}\n helperText={helperText}\n isError={isError}\n />\n {error ? <HelperText helperText={error} isError /> : null}\n {uploadErrorText ? (\n <HelperText helperText={uploadErrorText} isError />\n ) : null}\n\n {hasFiles && (\n <Box sx={{ my: 3, ml: 0.5 }}>\n <MultiFilePreview\n files={files}\n thumbnail={true}\n onRemove={handleRemove}\n onReorder={onReorder ? handleReorder : undefined}\n />\n </Box>\n )}\n <ImageCropModal\n open={cropModalOpen}\n onClose={handleCropCancel}\n label={label}\n imageSrc={imagePreview}\n aspectRatio={aspectRatio}\n onInitialized={onCropInitialized}\n onSave={handleCropSave}\n loading={cropLoading}\n cropSize={cropSize}\n />\n </DropZone>\n );\n};\n\nexport default memo(MultipleImageUpload);\n","import { memo, useCallback } from 'react';\nimport Stack from '@mui/material/Stack';\nimport Typography from '@mui/material/Typography';\nimport { m } from 'framer-motion';\n\nimport { varFade } from 'components/animate';\nimport { FileThumbnail, useFileUploadService } from 'components/FileUpload';\nimport Icon from 'components/Icon';\nimport Tooltip from 'components/Tooltip';\nimport { fData } from 'utils/formatNumber';\n\nimport DropZone from './components/DropZone';\nimport DropZonePlaceholder from './components/DropZonePlaceholder';\nimport HelperText from './components/HelperText';\nimport useDropzoneUploader from './hooks/useDropzoneUploader';\nimport { SingleFileUploadProps } from './props';\nimport { CloseIconButton } from './styles';\n\nconst SingleFileUpload = ({\n onFileSelect,\n onRemove,\n createFilesMutation,\n fileDetails,\n id,\n disabled,\n error,\n helperText,\n sx,\n dropZoneSxProps,\n uploading,\n tabIndex,\n placeholderAlt,\n placeholderProps,\n ...other\n}: SingleFileUploadProps) => {\n const { filesPreview, isUploadOrLoadingFiles, uploadErrorText, uploadFiles } =\n useFileUploadService({\n createFilesMutation,\n filesDetails: fileDetails ? [fileDetails] : [],\n });\n const isLoading = isUploadOrLoadingFiles || uploading;\n const {\n file,\n dropzoneProps,\n handleRemove: onRemoveFile,\n } = useDropzoneUploader({\n uploadFiles,\n onFileSelect,\n onRemove,\n filesPreview,\n dropzoneOptions: {\n multiple: false,\n disabled,\n ...other,\n },\n });\n\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n dropzoneProps;\n\n const handleRemove = useCallback(\n (e: React.MouseEvent<HTMLButtonElement>) => {\n e.stopPropagation();\n onRemoveFile(file || undefined);\n },\n [file, onRemoveFile],\n );\n\n const hasFile = !!file;\n const isNotFormatFile = typeof file === 'string';\n const isError = isDragReject || !!error || !!uploadErrorText;\n\n return (\n <DropZone\n id={id}\n uploading={isLoading}\n disabled={disabled}\n dropZoneSxProps={dropZoneSxProps}\n tabIndex={tabIndex}\n getRootProps={getRootProps}\n getInputProps={getInputProps}\n isDragActive={isDragActive}\n isError={isError}\n dropZoneContent={\n <>\n {!hasFile &&\n (placeholderAlt ? (\n <Stack {...placeholderProps}>{placeholderAlt}</Stack>\n ) : (\n <DropZonePlaceholder />\n ))}\n\n {hasFile && (\n <Stack\n component={m.div}\n {...varFade().inUp}\n spacing={2}\n direction=\"row\"\n alignItems=\"center\"\n sx={{\n my: 1,\n px: 1,\n py: 0.75,\n borderRadius: 0.75,\n border: theme => `solid 1px ${theme.palette.divider}`,\n ...sx,\n }}\n >\n <FileThumbnail file={file} />\n\n <Stack flexGrow={1} sx={{ minWidth: 0 }}>\n <Typography variant=\"subtitle2\" noWrap>\n {isNotFormatFile ? file : file.name}\n </Typography>\n\n <Typography variant=\"caption\" sx={{ color: 'text.secondary' }}>\n {isNotFormatFile ? '' : fData(file.size)}\n </Typography>\n </Stack>\n\n {onRemove && (\n <Tooltip title=\"Remover arquivo\">\n <CloseIconButton\n edge=\"end\"\n size=\"small\"\n disabled={disabled}\n aria-label=\"Remover arquivo\"\n onClick={handleRemove}\n >\n <Icon icon=\"DELETE_MARK_BUTTON_02\" width={16} />\n </CloseIconButton>\n </Tooltip>\n )}\n </Stack>\n )}\n </>\n }\n >\n <HelperText\n disabled={disabled}\n helperText={helperText}\n isError={isError}\n />\n {error ? <HelperText helperText={error} isError /> : null}\n {uploadErrorText ? (\n <HelperText helperText={uploadErrorText} isError />\n ) : null}\n </DropZone>\n );\n};\n\nexport default memo(SingleFileUpload);\n","import { CSSProperties, memo, useCallback, useEffect, useState } from 'react';\nimport Stack from '@mui/material/Stack';\n\nimport ImageCropModal from 'components/EasyCropModal';\nimport FixedProgressBar from 'components/FixedProgressBar';\nimport Icon from 'components/Icon';\n\nimport DropZone from './components/DropZone';\nimport DropZonePlaceholder from './components/DropZonePlaceholder';\nimport HelperText from './components/HelperText';\nimport SingleFilePreview from './components/SingleFilePreview';\nimport useDropzoneUploader from './hooks/useDropzoneUploader';\nimport useFileUploadService from './hooks/useFileUploadService';\nimport { SingleImageUploadProps } from './props';\nimport { Container, DeleteButton } from './styles';\n\nconst SingleImageUpload = ({\n onRemove,\n onFileSelect,\n createFilesMutation,\n fileDetails,\n id,\n disabled,\n error,\n helperText,\n dropZoneSxProps,\n placeholderProps,\n placeholderAlt,\n hoverAlt,\n uploading,\n tabIndex,\n aspectRatio: customAspectRatio,\n enableCrop = true,\n convertToWebp = true,\n name,\n label,\n cropSize,\n sx,\n maxWidth,\n maxHeight,\n compressionQuality = 0.8,\n maxCompressedWidth,\n maxCompressedHeight,\n fill,\n ...other\n}: SingleImageUploadProps) => {\n const { filesPreview, isUploadOrLoadingFiles, uploadErrorText, uploadFiles } =\n useFileUploadService({\n createFilesMutation,\n filesDetails: fileDetails ? [fileDetails] : [],\n });\n\n const [imagePreviewLoading, setImagePreviewLoading] = useState(false);\n const {\n file,\n dropzoneProps,\n cropState,\n handleRemove: onRemoveFile,\n aspectRatio,\n } = useDropzoneUploader({\n onFileSelect,\n onRemove,\n dropzoneOptions: {\n accept: {\n 'image/*': ['.jpeg', '.jpg', '.png', '.gif', '.webp'],\n },\n multiple: false,\n disabled,\n ...other,\n },\n filesPreview,\n enableCrop,\n customAspectRatio,\n convertToWebp,\n cropSize,\n uploadFiles,\n compressionQuality,\n maxCompressedWidth,\n maxCompressedHeight,\n });\n\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n dropzoneProps;\n\n const {\n cropModalOpen,\n imagePreview,\n cropLoading,\n onCropInitialized,\n handleCropSave,\n handleCropCancel,\n } = cropState;\n\n const handleRemove = useCallback(() => {\n onRemoveFile(file || undefined);\n }, [file, onRemoveFile]);\n\n const hasFile = !!file;\n const isError = isDragReject || !!error || !!uploadErrorText;\n const isLoading = uploading || isUploadOrLoadingFiles;\n\n const hidePlaceholder = hasFile ? { opacity: 0 } : { opacity: 1 };\n const dropZoneSxWidth = (dropZoneSxProps as CSSProperties)?.width;\n\n useEffect(() => {\n if (!hasFile) setImagePreviewLoading(false);\n }, [hasFile]);\n\n return (\n <Container\n sx={{\n ...sx,\n ...(dropZoneSxWidth && { width: dropZoneSxWidth }),\n }}\n >\n {(isLoading || imagePreviewLoading) && <FixedProgressBar />}\n <DropZone\n id={id}\n uploading={isLoading}\n disabled={disabled}\n dropZoneSxProps={dropZoneSxProps}\n tabIndex={tabIndex}\n getRootProps={getRootProps}\n getInputProps={getInputProps}\n isDragActive={isDragActive}\n isError={isError}\n name={name}\n dropZoneContent={\n <>\n {placeholderAlt ? (\n <Stack sx={hidePlaceholder}>{placeholderAlt}</Stack>\n ) : (\n <DropZonePlaceholder\n sx={hidePlaceholder}\n header={placeholderProps?.title}\n description={placeholderProps?.description}\n />\n )}\n\n {hasFile && (\n <SingleFilePreview\n file={file}\n cropSize={cropSize}\n isLoading={imagePreviewLoading}\n isUploading={isLoading}\n onLoading={setImagePreviewLoading}\n aspectRatio={aspectRatio}\n maxWidth={maxWidth}\n maxHeight={maxHeight}\n hoverAlt={hoverAlt}\n fill={fill}\n />\n )}\n </>\n }\n >\n <HelperText\n disabled={disabled}\n helperText={helperText}\n isError={isError}\n />\n {error ? <HelperText helperText={error} isError /> : null}\n {uploadErrorText ? (\n <HelperText helperText={uploadErrorText} isError />\n ) : null}\n\n {hasFile && onRemove && (\n <DeleteButton\n size=\"small\"\n onClick={handleRemove}\n disabled={disabled}\n label=\"Remover arquivo\"\n >\n <Icon icon=\"DELETE_MARK_BUTTON_02\" width={16} />\n </DeleteButton>\n )}\n\n <ImageCropModal\n open={cropModalOpen}\n onClose={handleCropCancel}\n label={label ?? 'Ajustar Imagem'}\n imageSrc={imagePreview}\n aspectRatio={aspectRatio}\n onInitialized={onCropInitialized}\n onSave={handleCropSave}\n loading={cropLoading}\n cropSize={cropSize}\n />\n </DropZone>\n </Container>\n );\n};\n\nexport default memo(SingleImageUpload);\n","import { memo, useCallback, useEffect, useRef, useState } from 'react';\nimport CircularProgress from '@mui/material/CircularProgress';\nimport Stack from '@mui/material/Stack';\nimport Typography from '@mui/material/Typography';\n\nimport ImageCropModal from 'components/EasyCropModal';\nimport Icon from 'components/Icon';\n\nimport HelperText from './components/HelperText';\nimport useDropzoneUploader from './hooks/useDropzoneUploader';\nimport useFileUploadService from './hooks/useFileUploadService';\nimport { SingleImageUploadProps } from './props';\nimport {\n AvatarContainer,\n ImagePreview,\n PlaceholderLoading,\n UploadAvatarBox,\n UploadPlaceholder,\n} from './styles';\n\nconst UploadAvatar = ({\n onRemove,\n onFileSelect,\n createFilesMutation,\n fileDetails,\n disabled,\n label,\n id,\n tabIndex,\n error,\n helperText,\n sx,\n name,\n maxSize,\n uploading,\n aspectRatio = 1,\n enableCrop = true,\n convertToWebp = true,\n cropSize,\n ...other\n}: SingleImageUploadProps) => {\n const [imagePreviewLoading, setImagePreviewLoading] = useState(false);\n const { filesPreview, isUploadOrLoadingFiles, uploadErrorText, uploadFiles } =\n useFileUploadService({\n createFilesMutation,\n filesDetails: fileDetails ? [fileDetails] : [],\n });\n\n const {\n file,\n dropzoneProps,\n cropState,\n handleRemove: onRemoveFile,\n } = useDropzoneUploader({\n filesPreview,\n onFileSelect,\n onRemove,\n dropzoneOptions: {\n accept: {\n 'image/*': ['.jpeg', '.jpg', '.png', '.gif', '.webp'],\n },\n multiple: false,\n disabled,\n maxSize,\n ...other,\n },\n enableCrop,\n customAspectRatio: aspectRatio,\n convertToWebp,\n cropSize,\n uploadFiles,\n });\n\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n dropzoneProps;\n const {\n cropModalOpen,\n imagePreview,\n cropLoading,\n onCropInitialized,\n handleCropSave,\n handleCropCancel,\n } = cropState;\n\n const isError = isDragReject || !!error || !!uploadErrorText;\n const isLoading = imagePreviewLoading || isUploadOrLoadingFiles || uploading;\n const canRemove = !!onRemove;\n\n const imgSrc = useRef(fileDetails?.url || '');\n const loadedFileKey = useRef<string | number | undefined>();\n\n useEffect(() => {\n if (!file) {\n imgSrc.current = '';\n loadedFileKey.current = undefined;\n return;\n }\n\n if (loadedFileKey.current === file.id) return;\n loadedFileKey.current = file.id;\n setImagePreviewLoading(true);\n const objectUrl = URL.createObjectURL(file);\n imgSrc.current = objectUrl;\n\n return () => {\n URL.revokeObjectURL(objectUrl);\n };\n }, [file]);\n\n const handleImageLoad = () => {\n setImagePreviewLoading(false);\n };\n\n const handleClick = useCallback(() => {\n if (canRemove && file) {\n return () => onRemoveFile(file);\n }\n\n return getRootProps().onClick;\n }, [canRemove, file, getRootProps, onRemoveFile]);\n\n return (\n <>\n <Stack sx={{ alignItems: 'center' }}>\n <UploadAvatarBox\n sx={sx}\n isError={isError}\n isDragActive={isDragActive}\n hasFile={!!file}\n {...getRootProps()}\n onClick={handleClick()}\n >\n <AvatarContainer>\n {isLoading && (\n <PlaceholderLoading>\n <CircularProgress size={135} thickness={2} color=\"primary\" />\n </PlaceholderLoading>\n )}\n\n {file && (\n <ImagePreview\n alt=\"Avatar Preview\"\n src={imgSrc.current}\n onLoad={handleImageLoad}\n {...(isLoading && {\n sx: {\n filter: 'blur(5px) !important',\n scale: 1.2,\n opacity: 0.7,\n },\n })}\n />\n )}\n\n {!file && !isLoading && (\n <UploadPlaceholder isError={isError} hasFile={false}>\n <Icon icon=\"ADD_IMAGE\" width={32} />\n\n <Typography\n variant=\"caption\"\n textAlign=\"center\"\n sx={{ color: isError ? 'error.main' : 'text.disabled' }}\n >\n Adicionar foto\n </Typography>\n </UploadPlaceholder>\n )}\n\n {file && !isLoading && (\n <UploadPlaceholder isError={isError} hasFile={true}>\n <Icon\n icon={!canRemove ? 'ADD_IMAGE' : 'DELETE_MARK_BUTTON_02'}\n width={32}\n />\n\n <Typography\n variant=\"caption\"\n textAlign=\"center\"\n sx={{ color: isError ? 'error.main' : 'common.white' }}\n >\n {!canRemove ? 'Alterar foto' : 'Remover foto'}\n </Typography>\n </UploadPlaceholder>\n )}\n </AvatarContainer>\n <input name={name} id={id} tabIndex={tabIndex} {...getInputProps()} />\n </UploadAvatarBox>\n\n <Stack sx={{ alignItems: 'center', mt: -0.5 }}>\n <HelperText\n helperText={helperText}\n disabled={disabled}\n isError={isError}\n />\n </Stack>\n {uploadErrorText ? (\n <HelperText helperText={uploadErrorText} isError />\n ) : null}\n {error ? <HelperText helperText={error} isError /> : null}\n </Stack>\n\n {cropModalOpen && imagePreview && (\n <ImageCropModal\n open={cropModalOpen}\n onClose={handleCropCancel}\n label={label ?? 'Ajustar Imagem'}\n imageSrc={imagePreview}\n aspectRatio={aspectRatio}\n onInitialized={onCropInitialized}\n onSave={handleCropSave}\n loading={cropLoading}\n cropSize={cropSize}\n cropShape=\"round\"\n />\n )}\n </>\n );\n};\n\nexport default memo(UploadAvatar);\n","import { memo } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { SingleFileUploadProps } from './props';\nimport { BoxUpload } from './styles';\n\nconst UploadBox = ({\n error,\n name,\n disabled,\n sx,\n ...other\n}: SingleFileUploadProps) => {\n const { getRootProps, getInputProps, isDragActive, isDragReject } =\n useDropzone({\n disabled,\n ...other,\n });\n\n const hasError = isDragReject || error;\n\n return (\n <BoxUpload\n {...getRootProps()}\n isDragActive={isDragActive}\n hasError={!!hasError}\n disabled={!!disabled}\n sx={sx}\n data-testid=\"upload-box\"\n >\n <input name={name} {...getInputProps()} />\n Selecionar arquivo\n </BoxUpload>\n );\n};\n\nexport default memo(UploadBox);\n"]}
@@ -0,0 +1,5 @@
1
+ var o=["pdf"],c=["txt"],a=["psd"],n=["doc","docx"],r=["xls","xlsx"],p=["zip","rar","iso"],l=["ai","eps"],f=["ppt","pptx"],u=["wav","aif","mp3","aac"],I=["jpg","jpeg","gif","bmp","png","svg","webp"],O=["m4v","avi","mpg","mp4","webm"];function d(t){let e,s=i(t);return c.includes(s)?e="txt":p.includes(s)?e="zip":u.includes(s)?e="audio":I.includes(s)?e="image":O.includes(s)?e="video":n.includes(s)?e="word":r.includes(s)?e="excel":f.includes(s)?e="powerpoint":o.includes(s)?e="pdf":a.includes(s)?e="photoshop":l.includes(s)?e="illustrator":t?.startsWith("http")?e="image":e=i(t),e}function _(t){let e;switch(d(t)){case"folder":e="IC_FOLDER";break;case"txt":e="IC_TXT";break;case"zip":e="IC_ZIP";break;case"audio":e="IC_AUDIO";break;case"video":e="IC_VIDEO";break;case"word":e="IC_WORD";break;case"excel":e="IC_EXCEL";break;case"powerpoint":e="IC_POWER_POINT";break;case"pdf":e="IC_PDF";break;case"photoshop":e="IC_PTS";break;case"illustrator":e="IC_AI";break;case"image":e="IC_IMG";break;default:e="IC_FILE";}return e}function i(t){return t&&t.split(".").pop()||""}function T(t){return t.split("/").pop()}
2
+
3
+ export { d as a, _ as b, i as c, T as d };
4
+ //# sourceMappingURL=out.js.map
5
+ //# sourceMappingURL=chunk-WQSRNCNF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/FileUpload/FileThumbnail/utils.ts"],"names":["FORMAT_PDF","FORMAT_TEXT","FORMAT_PHOTOSHOP","FORMAT_WORD","FORMAT_EXCEL","FORMAT_ZIP","FORMAT_ILLUSTRATOR","FORMAT_POWERPOINT","FORMAT_AUDIO","FORMAT_IMG","FORMAT_VIDEO","fileFormat","fileUrl","format","fileByUrl","fileTypeByUrl","fileThumb","thumb","fileNameByUrl"],"mappings":"AAAA,IAAMA,EAAa,CAAC,KAAK,EACnBC,EAAc,CAAC,KAAK,EACpBC,EAAmB,CAAC,KAAK,EACzBC,EAAc,CAAC,MAAO,MAAM,EAC5BC,EAAe,CAAC,MAAO,MAAM,EAC7BC,EAAa,CAAC,MAAO,MAAO,KAAK,EACjCC,EAAqB,CAAC,KAAM,KAAK,EACjCC,EAAoB,CAAC,MAAO,MAAM,EAClCC,EAAe,CAAC,MAAO,MAAO,MAAO,KAAK,EAC1CC,EAAa,CAAC,MAAO,OAAQ,MAAO,MAAO,MAAO,MAAO,MAAM,EAC/DC,EAAe,CAAC,MAAO,MAAO,MAAO,MAAO,MAAM,EAEjD,SAASC,EAAWC,EAAiB,CAC1C,IAAIC,EAEEC,EAAYC,EAAcH,CAAO,EAEvC,OAAIX,EAAY,SAASa,CAAS,EAChCD,EAAS,MACAR,EAAW,SAASS,CAAS,EACtCD,EAAS,MACAL,EAAa,SAASM,CAAS,EACxCD,EAAS,QACAJ,EAAW,SAASK,CAAS,EACtCD,EAAS,QACAH,EAAa,SAASI,CAAS,EACxCD,EAAS,QACAV,EAAY,SAASW,CAAS,EACvCD,EAAS,OACAT,EAAa,SAASU,CAAS,EACxCD,EAAS,QACAN,EAAkB,SAASO,CAAS,EAC7CD,EAAS,aACAb,EAAW,SAASc,CAAS,EACtCD,EAAS,MACAX,EAAiB,SAASY,CAAS,EAC5CD,EAAS,YACAP,EAAmB,SAASQ,CAAS,EAC9CD,EAAS,cACAD,GAAS,WAAW,MAAM,EACnCC,EAAS,QAETA,EAASE,EAAcH,CAAO,EAGzBC,CACT,CAEO,SAASG,EAAUJ,EAAiB,CACzC,IAAIK,EAEJ,OAAQN,EAAWC,CAAO,EAAG,CAC3B,IAAK,SACHK,EAAQ,YACR,MACF,IAAK,MACHA,EAAQ,SACR,MACF,IAAK,MACHA,EAAQ,SACR,MACF,IAAK,QACHA,EAAQ,WACR,MACF,IAAK,QACHA,EAAQ,WACR,MACF,IAAK,OACHA,EAAQ,UACR,MACF,IAAK,QACHA,EAAQ,WACR,MACF,IAAK,aACHA,EAAQ,iBACR,MACF,IAAK,MACHA,EAAQ,SACR,MACF,IAAK,YACHA,EAAQ,SACR,MACF,IAAK,cACHA,EAAQ,QACR,MACF,IAAK,QACHA,EAAQ,SACR,MACF,QACEA,EAAQ,SACZ,CACA,OAAOA,CACT,CAEO,SAASF,EAAcH,EAAiB,CAC7C,OAAQA,GAAWA,EAAQ,MAAM,GAAG,EAAE,IAAI,GAAM,EAClD,CAEO,SAASM,EAAcN,EAAiB,CAC7C,OAAOA,EAAQ,MAAM,GAAG,EAAE,IAAI,CAChC","sourcesContent":["const FORMAT_PDF = ['pdf'];\nconst FORMAT_TEXT = ['txt'];\nconst FORMAT_PHOTOSHOP = ['psd'];\nconst FORMAT_WORD = ['doc', 'docx'];\nconst FORMAT_EXCEL = ['xls', 'xlsx'];\nconst FORMAT_ZIP = ['zip', 'rar', 'iso'];\nconst FORMAT_ILLUSTRATOR = ['ai', 'eps'];\nconst FORMAT_POWERPOINT = ['ppt', 'pptx'];\nconst FORMAT_AUDIO = ['wav', 'aif', 'mp3', 'aac'];\nconst FORMAT_IMG = ['jpg', 'jpeg', 'gif', 'bmp', 'png', 'svg', 'webp'];\nconst FORMAT_VIDEO = ['m4v', 'avi', 'mpg', 'mp4', 'webm'];\n\nexport function fileFormat(fileUrl: string) {\n let format;\n\n const fileByUrl = fileTypeByUrl(fileUrl);\n\n if (FORMAT_TEXT.includes(fileByUrl)) {\n format = 'txt';\n } else if (FORMAT_ZIP.includes(fileByUrl)) {\n format = 'zip';\n } else if (FORMAT_AUDIO.includes(fileByUrl)) {\n format = 'audio';\n } else if (FORMAT_IMG.includes(fileByUrl)) {\n format = 'image';\n } else if (FORMAT_VIDEO.includes(fileByUrl)) {\n format = 'video';\n } else if (FORMAT_WORD.includes(fileByUrl)) {\n format = 'word';\n } else if (FORMAT_EXCEL.includes(fileByUrl)) {\n format = 'excel';\n } else if (FORMAT_POWERPOINT.includes(fileByUrl)) {\n format = 'powerpoint';\n } else if (FORMAT_PDF.includes(fileByUrl)) {\n format = 'pdf';\n } else if (FORMAT_PHOTOSHOP.includes(fileByUrl)) {\n format = 'photoshop';\n } else if (FORMAT_ILLUSTRATOR.includes(fileByUrl)) {\n format = 'illustrator';\n } else if (fileUrl?.startsWith('http')) {\n format = 'image';\n } else {\n format = fileTypeByUrl(fileUrl);\n }\n\n return format;\n}\n\nexport function fileThumb(fileUrl: string) {\n let thumb;\n\n switch (fileFormat(fileUrl)) {\n case 'folder':\n thumb = 'IC_FOLDER';\n break;\n case 'txt':\n thumb = 'IC_TXT';\n break;\n case 'zip':\n thumb = 'IC_ZIP';\n break;\n case 'audio':\n thumb = 'IC_AUDIO';\n break;\n case 'video':\n thumb = 'IC_VIDEO';\n break;\n case 'word':\n thumb = 'IC_WORD';\n break;\n case 'excel':\n thumb = 'IC_EXCEL';\n break;\n case 'powerpoint':\n thumb = 'IC_POWER_POINT';\n break;\n case 'pdf':\n thumb = 'IC_PDF';\n break;\n case 'photoshop':\n thumb = 'IC_PTS';\n break;\n case 'illustrator':\n thumb = 'IC_AI';\n break;\n case 'image':\n thumb = 'IC_IMG';\n break;\n default:\n thumb = 'IC_FILE';\n }\n return thumb;\n}\n\nexport function fileTypeByUrl(fileUrl: string) {\n return (fileUrl && fileUrl.split('.').pop()) || '';\n}\n\nexport function fileNameByUrl(fileUrl: string) {\n return fileUrl.split('/').pop();\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { a } from './chunk-KIWSLR76.js';
2
2
  import { f } from './chunk-OF6623HG.js';
3
- import { a as a$1 } from './chunk-CMZI4PHD.js';
3
+ import { a as a$1 } from './chunk-NQNNMRLC.js';
4
4
  import { forwardRef, useState, useRef, useMemo, useCallback } from 'react';
5
5
  import T from '@mui/material/IconButton';
6
6
  import R from '@mui/material/InputAdornment';
@@ -10,4 +10,4 @@ var C=forwardRef(({name:M,increment:e=1,updadteForMultiple:P,allowNegative:u=!1,
10
10
 
11
11
  export { S as a };
12
12
  //# sourceMappingURL=out.js.map
13
- //# sourceMappingURL=chunk-5SIAWCDO.js.map
13
+ //# sourceMappingURL=chunk-XZFBTUAG.js.map
@@ -1,4 +1,4 @@
1
- import { a } from './chunk-DPT3E7PD.js';
1
+ import { a } from './chunk-RFRLNTFN.js';
2
2
  import { a as a$1 } from './chunk-KGLU4CR2.js';
3
3
  import { b } from './chunk-RPO7AI5K.js';
4
4
  import P from '@mui/lab/LoadingButton';
@@ -14,4 +14,4 @@ var w=({imageSrc:c,aspectRatio:p,cropShape:g,cropSize:u,onInitialized:h})=>{let[
14
14
 
15
15
  export { q as a };
16
16
  //# sourceMappingURL=out.js.map
17
- //# sourceMappingURL=chunk-N7R22QVG.js.map
17
+ //# sourceMappingURL=chunk-ZFRNMT3P.js.map
@@ -1,5 +1,5 @@
1
1
  import { a as a$2 } from './chunk-45OMMG7D.js';
2
- import { a as a$3 } from './chunk-CMZI4PHD.js';
2
+ import { a as a$3 } from './chunk-NQNNMRLC.js';
3
3
  import { a as a$1 } from './chunk-IAOMC4C4.js';
4
4
  import { a } from './chunk-CFNATBO2.js';
5
5
  import { memo } from 'react';
@@ -10,4 +10,4 @@ var l=({label:t="Copiar conte\xFAdo",message:c="Conte\xFAdo copiado!",toCopy:m})
10
10
 
11
11
  export { I as a };
12
12
  //# sourceMappingURL=out.js.map
13
- //# sourceMappingURL=chunk-YPQCLH3D.js.map
13
+ //# sourceMappingURL=chunk-ZGSSTXUO.js.map
@@ -1,5 +1,5 @@
1
- export { a as default } from '../../chunk-EKIESGNJ.js';
2
- import '../../chunk-CMZI4PHD.js';
1
+ export { a as default } from '../../chunk-LEMPYV5U.js';
2
+ import '../../chunk-NQNNMRLC.js';
3
3
  import '../../chunk-CIGSMWKF.js';
4
4
  //# sourceMappingURL=out.js.map
5
5
  //# sourceMappingURL=index.js.map
@@ -1,5 +1,5 @@
1
- export { a as default } from '../../chunk-FBSNLBJM.js';
2
- import '../../chunk-CMZI4PHD.js';
1
+ export { a as default } from '../../chunk-LY3IB5VH.js';
2
+ import '../../chunk-NQNNMRLC.js';
3
3
  import '../../chunk-CIGSMWKF.js';
4
4
  //# sourceMappingURL=out.js.map
5
5
  //# sourceMappingURL=index.js.map
@@ -11,7 +11,7 @@ interface ImageContainerProps {
11
11
 
12
12
  declare const Avatar: react.ForwardRefExoticComponent<Omit<PropsWithChildren<ImageContainerProps & _mui_material_Avatar.AvatarOwnProps & _mui_material_Avatar.AvatarSlotsAndSlotProps & _mui_material_OverridableComponent.CommonProps & Omit<Omit<react.DetailedHTMLProps<react.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
13
13
  ref?: ((instance: HTMLDivElement | null) => void) | react.RefObject<HTMLDivElement> | null | undefined;
14
- }, "children" | "className" | "style" | "classes" | "sx" | "variant" | "slots" | "slotProps" | "alt" | "src" | "sizes" | "srcSet" | "imgProps"> & {
14
+ }, "children" | "className" | "style" | "classes" | "sx" | "variant" | "slots" | "slotProps" | "sizes" | "alt" | "src" | "srcSet" | "imgProps"> & {
15
15
  component?: react.ElementType<any, keyof react.JSX.IntrinsicElements> | undefined;
16
16
  }>, "ref"> & react.RefAttributes<HTMLDivElement>>;
17
17
 
@@ -2,18 +2,18 @@ import { a as a$4 } from '../../chunk-5EKUS6HX.js';
2
2
  import { a as a$5 } from '../../chunk-VCHDZXTF.js';
3
3
  import { a } from '../../chunk-CO2KQFUN.js';
4
4
  import { a as a$2 } from '../../chunk-7R6ZYEQS.js';
5
- import { a as a$3 } from '../../chunk-CMZI4PHD.js';
5
+ import { a as a$3 } from '../../chunk-NQNNMRLC.js';
6
6
  import '../../chunk-CIGSMWKF.js';
7
7
  import { a as a$1 } from '../../chunk-LQRRMVFN.js';
8
8
  import '../../chunk-UHXAPEIF.js';
9
- import '../../chunk-CU7PKEY2.js';
9
+ import '../../chunk-VPKUUY5Q.js';
10
10
  import '../../chunk-LDGBS7ZI.js';
11
+ import '../../chunk-WUFEPE2G.js';
11
12
  import '../../chunk-2WG6OWB4.js';
12
13
  import '../../chunk-6W52DPH4.js';
13
14
  import '../../chunk-TWSAWMZ3.js';
14
15
  import '../../chunk-ROVD7OGE.js';
15
16
  import '../../chunk-EQYL7U3J.js';
16
- import '../../chunk-WUFEPE2G.js';
17
17
  import '../../chunk-GLRLKFPS.js';
18
18
  import j from '@mui/material/Avatar';
19
19
  import d from '@mui/material/Divider';
@@ -1,5 +1,5 @@
1
- import { a as a$1 } from '../../chunk-LBYTNLD3.js';
2
- import '../../chunk-CMZI4PHD.js';
1
+ import { a as a$1 } from '../../chunk-U7BH6DMJ.js';
2
+ import '../../chunk-NQNNMRLC.js';
3
3
  import '../../chunk-CIGSMWKF.js';
4
4
  import a from '@mui/material/Stack';
5
5
  import { styled, alpha } from '@mui/material/styles';
@@ -1,4 +1,4 @@
1
- import { a as a$2 } from '../../chunk-CMZI4PHD.js';
1
+ import { a as a$2 } from '../../chunk-NQNNMRLC.js';
2
2
  import '../../chunk-CIGSMWKF.js';
3
3
  import { a as a$1 } from '../../chunk-E3R7W7GK.js';
4
4
  import a from '@mui/material/Stack';
@@ -0,0 +1,64 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import { ReactNode } from 'react';
3
+ import { Option } from '../../types/option.js';
4
+ import '../../types/icon.js';
5
+
6
+ type BulkEditColumnType = 'text' | 'number' | 'boolean' | 'entity';
7
+ interface BulkEditModalColumn<TItem extends Record<string, unknown>> {
8
+ field: keyof TItem;
9
+ headerName: string;
10
+ type: BulkEditColumnType;
11
+ readOnly?: boolean;
12
+ options?: Option[];
13
+ }
14
+ interface BulkEditModalFieldChangeParams<TItem extends Record<string, unknown>> {
15
+ itemId: string;
16
+ field: keyof TItem;
17
+ value: unknown;
18
+ previousValue?: unknown;
19
+ }
20
+ interface BulkEditToolbarProps {
21
+ setFilterButtonEl: (button: HTMLButtonElement | null) => void;
22
+ }
23
+ interface BulkEditModalProps<TItem extends Record<string, unknown>> {
24
+ open: boolean;
25
+ onClose: () => void;
26
+ title: string | ReactNode;
27
+ header?: ReactNode;
28
+ items: TItem[];
29
+ columns: BulkEditModalColumn<TItem>[];
30
+ getItemId: (item: TItem) => string;
31
+ isLoading?: boolean;
32
+ page: number;
33
+ perPage: number;
34
+ total: number;
35
+ onPageChange: (page: number, pageSize: number) => void;
36
+ onRowsPerPageChange: (pageSize: number) => void;
37
+ onFieldChange: (params: BulkEditModalFieldChangeParams<TItem>) => void | Promise<void>;
38
+ isFieldDisabled?: (params: {
39
+ item: TItem;
40
+ field: keyof TItem;
41
+ }) => boolean;
42
+ showColumnButton?: boolean;
43
+ }
44
+ type BulkEditModalInnerProps<TItem extends Record<string, unknown>> = BulkEditModalProps<TItem>;
45
+ interface HeaderProps {
46
+ onClose: () => void;
47
+ total: number;
48
+ title: string | ReactNode;
49
+ }
50
+ interface BulkEditGridCellProps<TItem extends Record<string, unknown>> {
51
+ column: BulkEditModalColumn<TItem>;
52
+ item: TItem;
53
+ rowIndex: number;
54
+ itemId: string;
55
+ onFieldChange: (params: BulkEditModalFieldChangeParams<TItem>) => void | Promise<void>;
56
+ isFieldDisabled?: (params: {
57
+ item: TItem;
58
+ field: keyof TItem;
59
+ }) => boolean;
60
+ }
61
+
62
+ declare const BulkEditModal: <TItem extends Record<string, unknown>>(props: BulkEditModalProps<TItem>) => react_jsx_runtime.JSX.Element;
63
+
64
+ export { BulkEditColumnType, BulkEditGridCellProps, BulkEditModalColumn, BulkEditModalFieldChangeParams, BulkEditModalInnerProps, BulkEditModalProps, BulkEditToolbarProps, HeaderProps, BulkEditModal as default };
@@ -0,0 +1,28 @@
1
+ import { a } from '../../chunk-JZ55NEMI.js';
2
+ import { j as j$1 } from '../../chunk-QVU6HSYP.js';
3
+ import { a as a$3 } from '../../chunk-IN7SP2ND.js';
4
+ import '../../chunk-UVPQR2Q2.js';
5
+ import { a as a$1 } from '../../chunk-RBTYTONM.js';
6
+ import '../../chunk-LY3IB5VH.js';
7
+ import { a as a$2 } from '../../chunk-NQNNMRLC.js';
8
+ import '../../chunk-CIGSMWKF.js';
9
+ import { memo, useEffect, useState, useMemo, useCallback } from 'react';
10
+ import { useFormContext, useWatch, useForm, FormProvider } from 'react-hook-form';
11
+ import Ht from '@mui/material/LinearProgress';
12
+ import et from '@mui/material/Typography';
13
+ import Ct from '@mui/material/Switch';
14
+ import wt from '@mui/material/TextField';
15
+ import $ from '@mui/material/Box';
16
+ import ft from '@mui/material/Button';
17
+ import gt from '@mui/material/Chip';
18
+ import ht from '@mui/material/Dialog';
19
+ import v from '@mui/material/Stack';
20
+ import { styled } from '@mui/material/styles';
21
+ import { DataGridPremium, GridToolbarColumnsButton } from '@mui/x-data-grid-premium';
22
+ import { jsx, jsxs } from 'react/jsx-runtime';
23
+
24
+ var U=styled(ht)({"& .MuiDialog-paper":{margin:0,borderRadius:0,maxHeight:"100vh",padding:0,height:"100vh",width:"100%",maxWidth:"100%"}}),K=styled(v)({height:"100%",minHeight:0}),j=styled(gt)(({theme:t})=>({padding:0,"& .MuiChip-label":{color:t.palette.text.secondary,fontWeight:"700"}})),X=styled(ft)(({theme:t})=>({color:t.palette.text.secondary})),Z=styled($)({flex:1,minHeight:0,padding:0,display:"flex",alignItems:"stretch"}),q=styled(DataGridPremium)(({theme:t})=>({flex:1,height:"100%",minHeight:320,borderRadius:t.shape.borderRadius,backgroundColor:t.palette.background.paper,"& .MuiDataGrid-columnHeaders":{borderBottom:`1px solid ${t.palette.divider}`,minHeight:48,maxHeight:48},"& .MuiDataGrid-columnHeader":{borderTop:`1px solid ${t.palette.divider} !important`,borderBottom:`1px solid ${t.palette.divider} !important`,minWidth:"120px !important"},"& .MuiDataGrid-cell":{alignItems:"stretch",borderTop:`1px solid ${t.palette.divider}`,minWidth:120,width:"100%",borderLeft:`1px solid ${t.palette.divider}`,padding:0},"& .MuiDataGrid-cell:focus, & .MuiDataGrid-columnHeader:focus":{outline:"none"},"& .MuiDataGrid-withBorderColor":{borderColor:t.palette.divider},"& .MuiDataGrid-virtualScroller":{overflowX:"auto"},"& .MuiDataGrid-footerContainer":{borderTop:`1px solid ${t.palette.divider}`}})),I=styled($)({display:"flex",alignItems:"center",width:"100%",height:"100%",padding:0,boxSizing:"border-box","& .MuiTypography-root":{width:"100%",overflow:"hidden",textOverflow:"ellipsis"}}),J=styled(et)(({theme:t})=>({color:t.palette.text.primary})),Q=styled(v)(({theme:t})=>({flexDirection:"row",alignItems:"center",justifyContent:"space-between",borderTop:`1px solid ${t.palette.divider}`,padding:t.spacing(2,3),gap:t.spacing(2),flexWrap:"wrap"})),Y=styled(v)(({theme:t})=>({flexDirection:"row",alignItems:"center",gap:t.spacing(.5)}));var St={"& .MuiOutlinedInput-root":{px:0,borderRadius:0,background:"transparent","& fieldset, &:hover fieldset, &.Mui-focused fieldset":{background:"transparent",borderRadius:0,border:"none"}},"& .MuiInputBase-input":{py:0,height:56,background:"transparent"}},Bt=t=>({disableUnderline:!0,sx:{px:0,"& input":{textAlign:t?"right":"left"}}}),Mt=(t,o)=>{if(t==null||t==="")return null;if(o.type==="entity"&&o.options){let a=o.options.find(f=>f.value?.toString()===t?.toString());if(a)return a.label}if(typeof t=="object"){if("name"in t)return String(t.name);if("label"in t)return String(t.label);if("value"in t)return String(t.value)}return typeof t=="boolean"?t?"Sim":"N\xE3o":String(t)},Pt=({column:t,item:o,rowIndex:a$1,itemId:f,onFieldChange:T,isFieldDisabled:x})=>{let{setValue:g,control:S}=useFormContext(),d=t.field,e=`items.${a$1}.${String(d)}`,h=useWatch({control:S,name:e,defaultValue:o?.[d]}),l=h===void 0?o?.[d]:h,b=t.readOnly||(x?x({item:o,field:d}):!1),B=String(d)==="id";if(t.readOnly||B){let n=Mt(l,t);return jsx(I,{children:n?jsx(J,{variant:"body2",children:n}):jsx(et,{variant:"body2",color:"text.disabled",children:"-"})})}if(t.type==="boolean")return jsx(I,{sx:{justifyContent:"center"},children:jsx(Ct,{color:"primary",checked:!!l,inputProps:{"aria-label":t.headerName},onChange:n=>{let i=n.target.checked,p=l;g(e,i,{shouldDirty:!0,shouldTouch:!0});let u=T({itemId:f,field:d,value:i,previousValue:p});u&&typeof u.catch=="function"&&u.catch(()=>{g(e,p,{shouldDirty:!0,shouldTouch:!0});});},disabled:b})});if(t.type==="entity"){let n="";if(l!=null&&l!=="")if(typeof l=="object"){let i=l;"id"in i?n=String(i.id??""):"value"in i&&(n=String(i.value??""));}else n=String(l);return jsx(I,{children:jsx(a,{fullWidth:!0,name:e,value:n,options:t.options??[],disabled:b,size:"small",placeholder:"Preencher",sx:St,disableClearable:!0,onSelectOption:i=>{let p=l,u=T({itemId:f,field:d,value:i,previousValue:p});u&&typeof u.catch=="function"&&u.catch(()=>{g(e,p,{shouldDirty:!0,shouldTouch:!0});});}})})}let y=t.type==="number",G=l??"";return jsx(I,{sx:{justifyContent:y?"flex-end":"flex-start"},children:jsx(wt,{fullWidth:!0,size:"small",type:y?"number":"text",placeholder:"Preencher","aria-label":t.headerName,name:e,value:G,variant:"standard",InputProps:Bt(y),disabled:b,onKeyDown:n=>{(n.key===" "||n.key==="Spacebar")&&n.stopPropagation();},onChange:n=>{let i=n.target.value,p=y?i===""?"":Number(i):i;g(e,p,{shouldDirty:!0,shouldTouch:!0}),T({itemId:f,field:d,value:p});}})})},tt=memo(Pt,(t,o)=>t.itemId===o.itemId&&t.rowIndex===o.rowIndex&&t.column===o.column&&t.isFieldDisabled===o.isFieldDisabled);var O="bulk-edit-datagrid-actions",Dt=({setFilterButtonEl:t})=>{let o=useCallback(a=>{t(a);},[t]);return jsx(a$3,{container:O,children:jsx(GridToolbarColumnsButton,{ref:o,slotProps:{button:{color:"inherit",startIcon:jsx(a$2,{icon:"COLUMNS"}),children:"Colunas"}}})})},ot=Dt;var nt=({onClose:t,total:o,title:a})=>jsxs(v,{direction:"row",alignItems:"center",gap:3,sx:{px:3,py:0,minHeight:"var(--layout-nav-horizontal-height)"},children:[jsx(X,{variant:"text",size:"small",startIcon:jsx(a$2,{icon:"CHEVRON_LEFT"}),onClick:t,children:"Sair"}),jsxs(v,{flex:1,direction:"row",alignItems:"center",component:"h2",m:0,gap:1,children:[jsx(et,{component:"span",variant:"h6",children:"Editando"}),typeof o=="number"&&jsx(j,{component:"span",disabled:!0,label:o,size:"small",color:"default"}),jsx(et,{component:"span",variant:"h6",children:a})]}),jsx(v,{direction:"row",alignItems:"center",justifyContent:"flex-end",gap:1,id:O})]});var at=[10,25,50,100],Vt=t=>t.type==="number"?"right":t.type==="boolean"?"center":"left",At=({open:t,onClose:o,title:a,header:f,items:T,columns:x,getItemId:g,isLoading:S,page:d,perPage:e,total:h,onPageChange:l,onRowsPerPageChange:b,onFieldChange:B,isFieldDisabled:y,showColumnButton:G})=>{let[n,i]=useState(null),p=T,u=e>0?Math.ceil(h/e):0,lt=u>0?u-1:0,C=Math.min(Math.max(d,0),lt),dt=useMemo(()=>({page:C,pageSize:e}),[e,C]),st=useMemo(()=>{let r=e?[e,...at]:at;return Array.from(new Set(r)).sort((M,D)=>M-D)},[e]),w=useCallback(r=>{r.pageSize!==e&&b(r.pageSize),(r.page!==d||r.pageSize!==e)&&l(r.page,r.pageSize);},[l,b,d,e]),pt=useCallback(r=>{w({page:r,pageSize:e});},[w,e]),ut=useCallback(r=>{w({page:C,pageSize:r});},[w,C]),mt=useMemo(()=>x.map(r=>{let M=Vt(r),D=r.type==="boolean"?100:180;return {field:String(r.field),headerName:r.headerName,flex:1,minWidth:D,disableColumnMenu:!0,headerAlign:M,align:M,renderCell:P=>{let R=P.api.getRowIndexRelativeToVisibleRows(P.id),ct=typeof R=="number"&&R>-1?R:0;return jsx(tt,{column:r,item:P.row,rowIndex:ct,itemId:g(P.row),onFieldChange:B,isFieldDisabled:y})}}}),[x,g,y,B]);return jsx(U,{open:t,onClose:o,fullWidth:!0,children:jsxs(K,{children:[f??jsx(nt,{onClose:o,total:h,title:a}),S&&jsx(Ht,{sx:{height:2}}),jsx(Z,{children:jsx(q,{columns:mt,rows:p,getRowId:r=>g(r),hideFooterSelectedRowCount:!0,hideFooter:!0,disableRowSelectionOnClick:!0,paginationModel:dt,onPaginationModelChange:w,pageSizeOptions:st,paginationMode:"server",rowCount:h,rowHeight:56,loading:S,slots:{loadingOverlay:a$1,...G&&{toolbar:ot}},slotProps:{panel:{anchorEl:n},toolbar:{setFilterButtonEl:i}}})}),jsxs(Q,{children:[jsxs(Y,{component:"p",children:[jsx(et,{component:"span",variant:"body2",color:"text.disabled",children:"Total de itens:"}),jsx(et,{component:"span",variant:"body2",children:h})]}),jsx(j$1,{count:h,page:C,rowsPerPage:e,onPageChange:pt,onRowsPerPageChange:ut})]})]})})},zt=t=>{let{items:o}=t,a=useForm({defaultValues:{items:o}});return useEffect(()=>{a.reset({items:o});},[a,o]),jsx(FormProvider,{...a,children:jsx(At,{...t})})},Do=zt;
25
+
26
+ export { Do as default };
27
+ //# sourceMappingURL=out.js.map
28
+ //# sourceMappingURL=index.js.map