@zydon/common 2.7.63 → 2.7.64
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.
- package/README.md +1 -0
- package/dist/{chunk-VPKUUY5Q.js → chunk-4RNGASI4.js} +3 -3
- package/dist/chunk-QVUHCBI2.js +35 -0
- package/dist/chunk-QVUHCBI2.js.map +1 -0
- package/dist/components/AvatarButton/index.js +3 -3
- package/dist/components/Common/index.js +3 -3
- package/dist/components/DatePicker/index.d.ts +2 -1
- package/dist/components/DatePicker/index.js +3 -3
- package/dist/components/DatePicker/index.js.map +1 -1
- package/dist/components/DragContainer/index.js +2 -2
- package/dist/components/DragContainer/index.js.map +1 -1
- package/dist/components/FileUpload/index.js +1 -4
- package/dist/components/ImageCropModal/index.js +14 -4
- package/dist/components/ImageCropModal/index.js.map +1 -1
- package/dist/components/ToggleTheme/index.js +3 -3
- package/dist/components/form/Codes/index.d.ts +2 -1
- package/dist/components/form/Codes/index.js +4 -4
- package/dist/components/form/Codes/index.js.map +1 -1
- package/dist/components/form/FileUpload/index.js +2 -5
- package/dist/components/form/FileUpload/index.js.map +1 -1
- package/dist/contexts/PushNotifications/index.js +1 -1
- package/dist/hooks/useThemeToggle.js +3 -3
- package/dist/hooks/useUpload.js +6 -1
- package/dist/hooks/useUpload.js.map +1 -1
- package/dist/hooks/useUploadImage.js +7 -2
- package/dist/hooks/useUploadImage.js.map +1 -1
- package/dist/index.d.ts +1 -3
- package/dist/index.js +3 -7
- package/dist/index.js.map +1 -1
- package/dist/theme/theme-provider.js +3 -3
- package/dist/utils/dnd.js +4 -4
- package/dist/utils/dnd.js.map +1 -1
- package/package.json +4 -1
- package/dist/chunk-33C6UWPV.js +0 -7
- package/dist/chunk-33C6UWPV.js.map +0 -1
- package/dist/chunk-6WGKIN5L.js +0 -18
- package/dist/chunk-6WGKIN5L.js.map +0 -1
- package/dist/chunk-DTIGB5NW.js +0 -10
- package/dist/chunk-DTIGB5NW.js.map +0 -1
- package/dist/chunk-IEGF6HVV.js +0 -43
- package/dist/chunk-IEGF6HVV.js.map +0 -1
- package/dist/chunk-JFZOAS75.js +0 -23
- package/dist/chunk-JFZOAS75.js.map +0 -1
- package/dist/chunk-KR3DUHA6.js +0 -16
- package/dist/chunk-KR3DUHA6.js.map +0 -1
- package/dist/chunk-SBMEL2IJ.js +0 -9
- package/dist/chunk-SBMEL2IJ.js.map +0 -1
- package/dist/chunk-VYNBVZSA.js +0 -37
- package/dist/chunk-VYNBVZSA.js.map +0 -1
- package/dist/chunk-WQSRNCNF.js +0 -5
- package/dist/chunk-WQSRNCNF.js.map +0 -1
- package/dist/chunk-YCEQDXLR.js +0 -8
- package/dist/chunk-YCEQDXLR.js.map +0 -1
- package/dist/components/form/UploadAvatarWithCrop/index.d.ts +0 -21
- package/dist/components/form/UploadAvatarWithCrop/index.js +0 -23
- package/dist/components/form/UploadAvatarWithCrop/index.js.map +0 -1
- package/dist/components/form/UploadWithCrop/index.d.ts +0 -21
- package/dist/components/form/UploadWithCrop/index.js +0 -29
- package/dist/components/form/UploadWithCrop/index.js.map +0 -1
- package/dist/components/upload/index.d.ts +0 -70
- package/dist/components/upload/index.js +0 -31
- package/dist/components/upload/index.js.map +0 -1
- /package/dist/{chunk-VPKUUY5Q.js.map → chunk-4RNGASI4.js.map} +0 -0
package/dist/chunk-VYNBVZSA.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { a as a$6 } from './chunk-DTIGB5NW.js';
|
|
2
|
-
import { a as a$4, b } from './chunk-WQSRNCNF.js';
|
|
3
|
-
import { a as a$7 } from './chunk-ZFRNMT3P.js';
|
|
4
|
-
import { a } from './chunk-LNXA53QR.js';
|
|
5
|
-
import { e } from './chunk-OF6623HG.js';
|
|
6
|
-
import { a as a$2 } from './chunk-N4DW7EIC.js';
|
|
7
|
-
import { x } from './chunk-33C6UWPV.js';
|
|
8
|
-
import { a as a$3 } from './chunk-45OMMG7D.js';
|
|
9
|
-
import { a as a$8 } from './chunk-6U5LS7MP.js';
|
|
10
|
-
import { a as a$5 } from './chunk-NQNNMRLC.js';
|
|
11
|
-
import { j } from './chunk-VITOOMKK.js';
|
|
12
|
-
import { a as a$9 } from './chunk-SVX7EWV4.js';
|
|
13
|
-
import { a as a$1 } from './chunk-XNKYJHNL.js';
|
|
14
|
-
import { memo, forwardRef, useMemo, useLayoutEffect, useState, useCallback, useRef, useEffect } from 'react';
|
|
15
|
-
import Ho from '@mui/material/FormHelperText';
|
|
16
|
-
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
17
|
-
import { useSensors, useSensor, PointerSensor, KeyboardSensor, DndContext, closestCenter } from '@dnd-kit/core';
|
|
18
|
-
import { restrictToHorizontalAxis, restrictToParentElement, restrictToWindowEdges } from '@dnd-kit/modifiers';
|
|
19
|
-
import { useSortable, sortableKeyboardCoordinates, SortableContext, horizontalListSortingStrategy } from '@dnd-kit/sortable';
|
|
20
|
-
import { m, AnimatePresence } from 'framer-motion';
|
|
21
|
-
import xe from '@mui/material/Stack';
|
|
22
|
-
import Je from '@mui/material/Typography';
|
|
23
|
-
import De from '@mui/material/Box';
|
|
24
|
-
import Xo from '@mui/material/IconButton';
|
|
25
|
-
import Vo from '@mui/material/Paper';
|
|
26
|
-
import { styled, alpha } from '@mui/material/styles';
|
|
27
|
-
import Qo from '@mui/material/Badge';
|
|
28
|
-
import yr from '@mui/material/ButtonBase';
|
|
29
|
-
import Or from '@mui/material/Tooltip';
|
|
30
|
-
import { useDropzone } from 'react-dropzone';
|
|
31
|
-
import _t from '@mui/material/CircularProgress';
|
|
32
|
-
|
|
33
|
-
var $o=({helperText:e,disabled:o,isError:r})=>e?jsx(Ho,{error:r,sx:t=>({mx:"14px",color:o?t.palette.grey[500]:void 0}),children:e}):null,y=memo($o);var Me=styled(xe)({position:"relative",width:"100%",borderRadius:8,overflow:"hidden","&:hover .actions":{display:"flex"}}),Ne=styled(xe)({position:"absolute",top:4,right:4,gap:.5,"& svg":{width:16,height:16}}),lo=styled(De,{shouldForwardProp:e=>!["isDragActive","isError","disabled"].includes(e)})(({theme:e,isDragActive:o,isError:r,disabled:t})=>({outline:"none",cursor:"pointer",overflow:"hidden",position:"relative",padding:e.spacing(5),borderRadius:e.shape.borderRadius,transition:e.transitions.create("padding"),backgroundColor:e.palette.background.neutral,border:`dashed 1px ${e.palette.divider}`,...o&&{opacity:.72},...r&&{color:e.palette.error.main,backgroundColor:e.palette.error.lighter,borderColor:e.palette.error.light},...t&&{opacity:.48,pointerEvents:"none"},"&:hover":{opacity:.72}})),po=styled(Xo)(({theme:e})=>({position:"relative",zIndex:999,pointerEvents:"auto",color:e.palette.grey[700],backgroundColor:e.palette.grey[100],"&:hover":{color:e.palette.grey[900],backgroundColor:e.palette.grey[300]}})),He=styled("div")({position:"relative",zIndex:1,userSelect:"none","&:hover":{zIndex:2}}),mo=styled(xe,{shouldForwardProp:e=>!["isDragging"].includes(e)})(({theme:e,width:o,isDragging:r})=>({width:o,height:100,alignItems:"center",display:"inline-flex",justifyContent:"center",margin:e.spacing(.5),padding:e.spacing(2,1,2,1),gap:e.spacing(1),borderRadius:e.spacing(1.25),overflow:"hidden",position:"relative",border:`solid 1px ${e.palette.divider}`,backgroundColor:e.palette.common.white,zIndex:1,transition:"box-shadow 150ms ease-in-out",boxShadow:r?`0 0 0 2px ${e.palette.primary.main}, ${e.customShadows.z8}, inset 0 0 0 1000px ${alpha(e.palette.primary.main,.06)}`:"0px 0px 0px 0px rgba(0, 0, 0, 0)"})),co=styled(m.div)(({theme:e,width:o,isDragging:r})=>({width:o,height:60,alignItems:"center",display:"inline-flex",justifyContent:"center",margin:e.spacing(.5),padding:e.spacing(2),borderRadius:e.spacing(1.25),overflow:"hidden",position:"relative",border:`solid 1px ${e.palette.divider}`,backgroundColor:e.palette.common.white,zIndex:1,transition:"box-shadow 150ms ease-in-out",boxShadow:r?`0 0 0 2px ${e.palette.primary.main}, ${e.customShadows.z8}, inset 0 0 0 1000px ${alpha(e.palette.primary.main,.06)}`:"0px 0px 0px 0px rgba(0, 0, 0, 0)"})),go=styled(a)(({theme:e})=>({top:16,right:16,zIndex:9,position:"absolute",color:e.palette.common.white,backgroundColor:alpha(e.palette.grey[900],.72),"&:hover":{backgroundColor:alpha(e.palette.grey[900],.48)}})),uo=styled(De,{shouldForwardProp:e=>e!=="isDragActive"&&e!=="disabled"&&e!=="hasError"})(({theme:e,isDragActive:o,disabled:r,hasError:t})=>({width:64,height:64,flexShrink:0,display:"flex",borderRadius:1,cursor:"pointer",alignItems:"center",color:e.palette.text.disabled,justifyContent:"center",backgroundColor:alpha(e.palette.grey[500],.08),border:`dashed 1px ${alpha(e.palette.grey[500],.16)}`,...o&&{opacity:.72},...r&&{opacity:.48,pointerEvents:"none"},...t&&{color:e.palette.error.main,borderColor:e.palette.error.main,backgroundColor:alpha(e.palette.error.main,.08)},"&:hover":{opacity:.72}})),fo=styled(De)(({theme:e})=>({padding:e.spacing(1),top:0,left:0,width:"100%",height:"100%",position:"absolute",display:"flex",justifyContent:"center",alignItems:"center",transition:"all 0.3s ease-in-out",filter:"blur(0)","&:hover .single-file-preview-img":{filter:"blur(3px)",transition:"all 0.1s ease-in-out"},"&:hover .single-file-preview-hover-overlay":{opacity:1}})),xo=styled("img",{shouldForwardProp:e=>e!=="aspectRatio"&&e!=="isLoading"&&e!=="isUploading"&&e!=="maxWidth"&&e!=="maxHeight"&&e!=="cropSize"&&e!=="fill"})(({theme:e,aspectRatio:o,maxWidth:r,maxHeight:t,isLoading:l,isUploading:s,fill:i})=>({borderRadius:e.shape.borderRadius,objectFit:"cover",position:"absolute",top:"50%",left:"50%",transform:"translate(-50%, -50%) scale(1)",filter:"blur(0)",zIndex:1,backgroundColor:e.palette.background.paper,...i&&{width:"100%",height:"100%"},...!i&&Math.abs(o)>=1&&{maxWidth:r,maxHeight:t,aspectRatio:Math.abs(o),width:"calc(100% - 16px)",height:void 0},...!i&&Math.abs(o)<1&&{maxWidth:r,maxHeight:t,aspectRatio:Math.abs(o),width:void 0,height:"calc(100% - 16px)"},transition:"all 0.3s ease-in-out",...l||s?{opacity:0,filter:"blur(1.5rem)",transform:"translate(-50%, -50%) scale(0.7)"}:{}})),ho=styled("img",{shouldForwardProp:e=>e!=="isLoading"&&e!=="isUploading"})(({isLoading:e,isUploading:o})=>({width:"100%",height:"100%",objectFit:"cover",top:0,left:0,filter:"blur(1.5rem)",transform:"scale(1.1)",position:"absolute",zIndex:0,transition:"opacity 0.3s ease-in-out",...e&&{opacity:0},...o&&{opacity:.7,filter:"blur(2rem)"}})),bo=styled(xe)(({theme:e})=>({position:"absolute",top:0,left:0,right:0,bottom:0,display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:alpha(e.palette.primary.darker,.75),zIndex:2,pointerEvents:"none",opacity:0,transition:"opacity 0.3s ease-in-out"})),Po=styled(xe)({width:"100%",height:"100%",position:"relative",overflow:"hidden",borderRadius:"50%",justifyContent:"center",alignItems:"center"});styled(Vo)(({theme:e})=>({py:1,px:2,mt:3,textAlign:"left",borderStyle:"dashed",borderColor:"error.main",backgroundColor:alpha(e.palette.error.main,.08)}));var $e=styled(De,{shouldForwardProp:e=>e!=="isError"&&e!=="hasFile"})(({theme:e,isError:o,hasFile:r})=>({top:0,gap:e.spacing(1),left:0,width:"100%",height:"100%",zIndex:9,display:"flex",borderRadius:"50%",position:"absolute",alignItems:"center",color:e.palette.text.disabled,flexDirection:"column",justifyContent:"center",backgroundColor:alpha(e.palette.grey[500],.08),transition:e.transitions.create(["opacity"],{duration:e.transitions.duration.shorter}),"&:hover":{opacity:.92},...o&&{color:e.palette.error.main},...r&&{zIndex:9,opacity:0,color:e.palette.common.white,backgroundColor:alpha(e.palette.common.black,.54)}})),Io=styled(xe)({top:0,left:0,right:0,bottom:0,position:"absolute",zIndex:10,alignItems:"center",justifyContent:"center",opacity:.8});styled(xe)(({theme:e})=>({padding:20,justifyContent:"center",alignItems:"center",gap:4,alignSelf:"stretch",borderRadius:12,background:e.palette.divider,color:e.palette.text.disabled,height:160}));var vo=styled(De,{shouldForwardProp:e=>e!=="isDragActive"&&e!=="isError"&&e!=="hasFile"})(({theme:e,isDragActive:o,disabled:r,isError:t,hasFile:l})=>({padding:e.spacing(1),margin:"auto",width:144,height:144,cursor:"pointer",overflow:"hidden",borderRadius:"50%",border:`1px dashed ${e.palette.divider}`,...o&&{opacity:.72},...r&&{opacity:.48,pointerEvents:"none"},...t&&{borderColor:"error.main"},...l&&{...t&&{bgcolor:alpha(e.palette.error.main,.08)},"&:hover .upload-placeholder":{opacity:1},"& img":{filter:"blur(0)"},"&:hover img":{filter:"blur(3px)"}}})),Eo=styled("img")({width:"100%",height:"100%",borderRadius:"50%",objectFit:"cover",transition:"all 0.3s ease-in-out"}),wo=styled(a)(({theme:e})=>({backgroundColor:alpha(e.palette.grey[900],.72),color:e.palette.common.white,"&:hover":{backgroundColor:alpha(e.palette.grey[600],.64),color:e.palette.common.white},"& svg":{width:14,height:14}}));var Yo=({onRemove:e,sx:o,file:r,disableDrag:t,attributes:l,listeners:s,innerWidth:i,isDragging:p})=>{let d=r?.id;return d?jsx(Qo,{anchorOrigin:{vertical:"top",horizontal:"left"},children:jsxs(co,{width:i,isDragging:p,"data-testid":`preview-multi-img-${d}`,...j().inUp,sx:o,children:[jsx(a$2,{disableDrag:t,...l,...s}),jsx(Ee,{imageView:!0,file:r}),jsx(Ne,{sx:{position:"absolute",right:3,top:3,zIndex:1},children:e&&jsx(wo,{size:"small",label:"Remover arquivo",onClick:()=>e(r),icon:"DELETE_MARK_BUTTON_02"})})]})},`badge-${d}`):null},Fo=memo(Yo);var ir=({file:e$1,thumbnail:o,onRemove:r,sx:t,disableDrag:l=!1,disableTransitions:s=!1})=>{let i=e$1.size||0,p=e$1.name||e$1.id,d=e$1.id,m=typeof e$1=="string",a$1=l?70:80,{attributes:g,listeners:x$1,setNodeRef:P,transform:A,transition:I,isDragging:C}=useSortable({id:d,disabled:l}),h={transform:s?void 0:x.Transform.toString(A),transition:s?"none":I,opacity:s?.2:1,display:"inline-block",alignItems:"center",justifyContent:"center",width:`${a$1+8}px`,height:"68px"};return o&&e$1?jsx(He,{ref:P,style:h,children:jsx(Fo,{innerWidth:a$1,isDragging:C,sx:t,file:e$1,disableDrag:l,attributes:g,listeners:x$1,onRemove:r})}):jsx(He,{ref:P,style:{...h,height:"80px",width:`${a$1+38}px`},children:jsxs(mo,{width:a$1+30,isDragging:C,"data-testid":`preview-multi-img-${d}`,...j().inUp,sx:t,children:[jsx(a$2,{disableDrag:l,...g,...x$1}),e$1&&jsx(Ee,{file:e$1}),jsxs(xe,{flexGrow:1,sx:{width:"100%"},children:[jsx(a$3,{title:p,children:jsx(Je,{variant:"subtitle2",noWrap:!0,children:p})}),jsx(Je,{variant:"caption",sx:{color:"text.secondary"},children:m?"":e(i)})]}),jsx(Ne,{children:r&&jsx(a,{size:"small",label:"Remover arquivo",onClick:()=>r(e$1),icon:"DELETE_MARK_BUTTON_02"})})]})})},Ro=memo(ir);var Ir=({thumbnail:e,files:o,onRemove:r,onReorder:t,sx:l})=>{let[s,i]=useState(!1),p=useSensors(useSensor(PointerSensor,{activationConstraint:{distance:8}}),useSensor(KeyboardSensor,{coordinateGetter:sortableKeyboardCoordinates})),d=useCallback(a=>{let{active:g,over:x}=a;if(!(!g||!x||g.id===x.id)&&t){let P=o.findIndex(({id:I})=>I===g.id),A=o.findIndex(({id:I})=>I===x.id);P!==-1&&A!==-1&&(t(P,A,o),i(!0),setTimeout(()=>{i(!1);},300));}},[o,t]),m=jsx(AnimatePresence,{initial:!1,children:o.map(a=>jsx(Ro,{sx:l,id:`preview-file-${a.id}`,file:a,onRemove:r,thumbnail:e,disableDrag:!t,disableTransitions:s},`preview-file-${a.id}`))});return t?jsx(DndContext,{sensors:p,collisionDetection:closestCenter,onDragEnd:d,modifiers:[restrictToHorizontalAxis,restrictToParentElement,restrictToWindowEdges],children:jsx(SortableContext,{items:o.map(a=>a.id),strategy:horizontalListSortingStrategy,children:m})}):m},Se=memo(Ir);var _o=forwardRef(({onLoading:e,aspectRatio:o,cropSize:r,...t},l)=>{let{maxWidth:s,maxHeight:i}=useMemo(()=>r&&typeof r=="object"?{maxWidth:r.width,maxHeight:r.height}:r&&typeof r=="number"?{maxWidth:r,maxHeight:r}:{maxWidth:"100%",maxHeight:"100%"},[r]);a$1(()=>{e?.(!0);}),useLayoutEffect(()=>{typeof l=="object"&&l?.current?e?.(!l.current.complete):e?.(!1);},[l,e]);function p(){e?.(!1);}return jsx(xo,{...t,maxWidth:s,maxHeight:i,ref:l,aspectRatio:o,onLoad:p,onError:p})});_o.displayName="LoadingPreviewImage";var yo=_o;var Rr=({file:e,aspectRatio:o=1,isUploading:r,isLoading:t,onLoading:l,cropSize:s,maxWidth:i,maxHeight:p,hoverAlt:d,fill:m})=>{let a=useRef(null),g=e?.id||"",x=e?.name||"",P=URL.createObjectURL(e);return g?jsxs(fo,{className:"single-file-preview-box",children:[jsx(yo,{className:"single-file-preview-img",aspectRatio:o,cropSize:s,isLoading:t,isUploading:r,alt:x,src:P,ref:a,loading:"lazy",onLoading:l,onLoad:()=>l?.(!1),onError:()=>l?.(!1),maxWidth:i,maxHeight:p,fill:m},`image-preview-${g}`),jsx(ho,{className:"single-file-preview-bg",alt:x,src:P,isLoading:t,isUploading:r}),d&&jsx(bo,{className:"single-file-preview-hover-overlay",children:d})]}):null},Xe=memo(Rr);var ke={root:"mnl__file__thumbnail__root",img:"mnl__file__thumbnail__img",icon:"mnl__file__thumbnail__icon",removeBtn:"mnl__file__thumbnail__remove__button",downloadBtn:"mnl__file__thumbnail__download__button"},Ee=({sx:e,file:o,tooltip:r,onRemove:t,imageView:l,slotProps:s,onDownload:i,...p})=>{let d=URL.createObjectURL(o),m=o?.name||"",g=o.type.startsWith("image/")?"image":a$4(d),x=jsx(De,{component:"img",src:d,className:ke.img,sx:{width:1,height:1,objectFit:"cover",borderRadius:"inherit",...s?.img}}),P=jsx(a$5,{icon:b(g),sx:{width:32,height:32,flexShrink:0,...e}}),A=jsxs(xe,{component:"span",className:ke.root,sx:{width:36,height:36,flexShrink:0,borderRadius:1.25,alignItems:"center",position:"relative",display:"inline-flex",justifyContent:"center",...e},...p,children:[g==="image"&&l?x:P,t&&jsx(yr,{onClick:t,className:ke.removeBtn,sx:s?.removeBtn,children:jsx(a$5,{icon:"CLOSE_MARK_BUTTON",width:24})}),i&&jsx(Xo,{onClick:i,className:ke.downloadBtn,sx:s?.downloadBtn,size:"small",children:jsx(a$5,{icon:"ARROW_DOWN_CICLE",width:12})})]});return r?jsx(Or,{arrow:!0,title:m,slotProps:{popper:{modifiers:[{name:"offset",options:{offset:[0,-12]}}]}},children:A}):A};var Ji=e=>e.startsWith("image/"),Uo=(e,o=.8)=>new Promise((r,t)=>{let l=document.createElement("canvas"),s=l.getContext("2d"),i=new Image;i.onload=()=>{l.width=i.width,l.height=i.height,s?(s.drawImage(i,0,0),l.toBlob(p=>{if(p){let d=new File([p],e.name.replace(/\.[^/.]+$/,".webp"),{type:"image/webp",lastModified:Date.now()});r(d);}else t(new Error("Falha ao converter para WebP"));},"image/webp",o)):t(new Error("N\xE3o foi poss\xEDvel obter contexto do canvas"));},i.onerror=()=>t(new Error("Falha ao carregar imagem")),i.src=URL.createObjectURL(e);}),To=(e,o=.8,r,t)=>new Promise((l,s)=>{let i=document.createElement("canvas"),p=i.getContext("2d"),d=new Image;d.onload=()=>{let{width:m,height:a}=d;r&&m>r&&(a=a*r/m,m=r),t&&a>t&&(m=m*t/a,a=t),i.width=m,i.height=a,p?(p.imageSmoothingEnabled=!0,p.imageSmoothingQuality="high",p.drawImage(d,0,0,m,a),i.toBlob(g=>{if(g){let x=new File([g],e.name.replace(/\.[^/.]+$/,".webp"),{type:"image/webp",lastModified:Date.now()});l(x);}else s(new Error("Falha ao comprimir imagem"));},"image/webp",o)):s(new Error("N\xE3o foi poss\xEDvel obter contexto do canvas"));},d.onerror=()=>s(new Error("Falha ao carregar imagem")),d.src=URL.createObjectURL(e);}),Oo=e=>{let o=e.match(/filename\*=UTF-8''([^;]+)|filename="?([^";]+)"?/i);return o?.[1]||o?.[2]||""},Lo=e=>`UTF-8''${encodeURIComponent(e)}`;var kr=({onFilesSelect:e$1,onFileSelect:o,onReorder:r,onRemove:t,uploadFiles:l,filesPreview:s,dropzoneOptions:i,enableCrop:p=!1,customAspectRatio:d,convertToWebp:m=!0,cropSize:a,maxFiles:g,compressionQuality:x=.8,maxCompressedWidth:P,maxCompressedHeight:A})=>{let{showErrorMessage:I}=a$9(),C=useMemo(()=>d||(a&&typeof a!="number"?a.width/a.height:1),[d,a]),[h,w]=useState([]),[v,b]=useState(!1),[S,L]=useState(null),[u,E]=useState(null),[c,R]=useState(""),[z,O]=useState(!1),[T,M]=useState([]),[B,K]=useState(0),[oe,j]=useState(0),ne=f=>{if(f.length<1)return;let F=f[0];L(F),K(_=>_+1);let D=new FileReader;D.onload=()=>{R(D.result),b(!0);},D.readAsDataURL(F);},ge=(f,F)=>{E(F);},se=async f=>!S||!u?null:new Promise(F=>{let D=document.createElement("canvas"),_=D.getContext("2d"),N=new Image;N.onload=async()=>{let{width:G,height:pe,x:_e,y:Go}=u,Wo=Math.abs(C),ye=G,Ue=pe;a&&typeof a=="object"?(ye=a.width,Ue=a.height):a&&typeof a=="number"&&(ye=a,Ue=a/Wo),D.width=ye,D.height=Ue,_?(_.drawImage(N,_e,Go,G,pe,0,0,ye,Ue),D.toBlob(async oo=>{if(oo){let Ze=new File([oo],S.name,{type:S.type,lastModified:Date.now()});if(m)try{Ze=await Uo(Ze,x);}catch(jo){I(jo,"Erro ao converter para WebP");}let ro=Ze;ro.id=f,F(ro);}else F(null);},"image/png")):F(null);},N.src=c;}),le=async()=>{if(!(!S||!u||T.length===0)){O(!0);try{let f=T[0],F=await se(f.id);if(F){let _=await l([F]);_&&(!e$1&&!o&&w(N=>[...N,..._]),e$1?.([...s||[],..._]),o?.(F));}b(!1),O(!1),R(""),L(null);let D=T.slice(1);M(D),ne(D);}catch(f){I(f,"Erro ao processar imagem"),O(!1);}}},Z=()=>{b(!1),O(!1),R(""),L(null),M([]),K(0),j(0);},J=async f=>{if(f.length===0)return;let F=Object.keys(i?.accept||{}).some(_=>_.includes("image/")),D=h.length+f.length;if(g&&D>g){I(new Error(`M\xE1ximo de ${g} arquivos`),"Erro ao fazer upload");return}try{if(F&&p){let N=f.filter(G=>G.type.startsWith("image/")).map((G,pe)=>{let _e=G;return _e.id=`temp-crop-${Date.now()}-${pe}`,_e});j(N.length),K(0),M(N),ne(N);}else {let _=[];for(let G of f)if(G.type.startsWith("image/")&&m)try{let pe=await To(G,x,P,A);_.push(pe);}catch(pe){I(pe,"Erro ao comprimir imagem"),_.push(G);}else _.push(G);let N=await l(_);N&&(!e$1&&!o&&w(G=>[...G,...N]),e$1?.([...s||[],...N]),o?.(N[0]));}}catch(_){I(_,"Erro ao processar arquivos");}},Q=f=>{if(!f.length)return;let F=f[0]?.errors[0]?.code,D=i?.maxSize||3145728;I(F==="file-too-large"?new Error(`O arquivo excede o tamanho m\xE1ximo de ${e(D)}`):F==="file-invalid-type"?new Error("Formato de arquivo n\xE3o suportado"):f[0]?.errors[0]||new Error("Erro ao enviar arquivo"),"Erro ao fazer upload");},{getRootProps:re,getInputProps:H,isDragActive:n,isDragReject:ue,fileRejections:te}=useDropzone({onDrop:J,onDropRejected:Q,...i}),Fe=f=>{if(!f){t||w([]),t?.(void 0);return}let F=h.filter(D=>D.id!==f.id);t||w(F),t?.(f);},fe=(f,F,D)=>{r?.(f,F,D);},be=useRef("");return useEffect(()=>{let f=s?.map(F=>F.id).join(",")||"";f!==be.current&&(be.current=f,w(s||[]));},[s]),{file:h?.[0],files:h,aspectRatio:C,dropzoneProps:{getRootProps:re,getInputProps:H,isDragActive:n,isDragReject:ue,fileRejections:te},cropState:{cropModalOpen:v,imagePreview:c,cropLoading:z,setCropModalOpen:b,onCropInitialized:ge,handleCropSave:le,handleCropCancel:Z,currentImageIndex:B,totalPendingImages:oe},setInitialFiles:w,handleRemove:Fe,handleReorder:fe}},q=kr;var Ve=(n=>(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))(Ve||{}),Be=(e=>(e["application/octet-stream"]="APPLICATION_OCTET_STREAM",e["image/jpeg"]="IMAGE_JPEG",e["image/jpg"]="IMAGE_JPG",e["image/png"]="IMAGE_PNG",e["image/gif"]="IMAGE_GIF",e["image/webp"]="IMAGE_WEBP",e["image/svg+xml"]="IMAGE_SVG",e["image/bmp"]="IMAGE_BMP",e["image/tiff"]="IMAGE_TIFF",e["image/x-icon"]="IMAGE_ICO",e["image/avif"]="IMAGE_AVIF",e["application/pdf"]="APPLICATION_PDF",e["text/plain"]="TEXT_PLAIN",e["text/csv"]="TEXT_CSV",e["application/rtf"]="APPLICATION_RTF",e["application/msword"]="APPLICATION_MSWORD",e["application/vnd.openxmlformats-officedocument.wordprocessingml.document"]="APPLICATION_DOCX",e["application/vnd.ms-excel"]="APPLICATION_MSEXCEL",e["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"]="APPLICATION_XLSX",e["application/vnd.ms-powerpoint"]="APPLICATION_MSPOWERPOINT",e["application/vnd.openxmlformats-officedocument.presentationml.presentation"]="APPLICATION_PPTX",e["application/vnd.oasis.opendocument.text"]="APPLICATION_ODT",e["application/vnd.oasis.opendocument.spreadsheet"]="APPLICATION_ODS",e["application/vnd.oasis.opendocument.presentation"]="APPLICATION_ODP",e["application/xml"]="APPLICATION_XML",e["text/xml"]="TEXT_XML",e["text/html"]="TEXT_HTML",e["text/css"]="TEXT_CSS",e["application/json"]="APPLICATION_JSON",e["text/javascript"]="TEXT_JAVASCRIPT",e["application/zip"]="APPLICATION_ZIP",e["application/gzip"]="APPLICATION_GZIP",e["application/vnd.rar"]="APPLICATION_RAR",e["application/x-7z-compressed"]="APPLICATION_7Z",e["audio/mpeg"]="AUDIO_MPEG",e["audio/wav"]="AUDIO_WAV",e["audio/ogg"]="AUDIO_OGG",e["audio/webm"]="AUDIO_WEBM",e["audio/aac"]="AUDIO_AAC",e["video/mp4"]="VIDEO_MP4",e["video/mpeg"]="VIDEO_MPEG",e["video/ogg"]="VIDEO_OGG",e["video/webm"]="VIDEO_WEBM",e["video/quicktime"]="VIDEO_QUICKTIME",e))(Be||{});var jr=({createFilesMutation:e,filesDetails:o})=>{let{showErrorMessage:r}=a$9(),[t,l]=useState(!1),[s,i]=useState(!1),[p,d]=useState(null),[m,a]=useState([]),g=useMemo(()=>m?.[0],[m]),x=s||t,P=useCallback(async h=>{if(!h.length){a([]),i(!1);return}i(!0);try{let v=(await Promise.all(h.map(async({url:b,id:S,name:L})=>{try{if(!b)return null;let u=await fetch(b);if(!u.ok)throw new Error(u.statusText);let E=await u.blob(),c=null;if(!L){let O=u.headers.get("content-disposition")||void 0;if(O){let T=Oo(O);if(T)try{c=decodeURIComponent(T);}catch{c=T;}}}let R=c||L||S,z=new File([E],R,{type:E.type});return z.id=S,z.url=b,z}catch{return null}}))).filter(Boolean);a(v),i(!1);}catch(w){r(w,"Erro ao carregar arquivos"),a([]),i(!1);}},[r]),A=useRef("");useEffect(()=>{let h=o?.map(({id:w})=>w).join(",")||"";h!==A.current&&(async()=>(A.current=h,await P(o)))();},[o,P]);let I=async h=>{if(!h||!Array.isArray(h))throw new Error("Arquivos inv\xE1lidos");let w=h.filter(v=>v instanceof File);if(w?.length){l(!0);try{let v=w.map(u=>{let E=u.type||"application/octet-stream",c=Be[E];if(!c)throw new Error(`Tipo de arquivo n\xE3o suportado: ${E}`);return {file:u,mimeType:E,contentTypeEnum:c}}),b=await e({files:v.map(({file:u,contentTypeEnum:E})=>({content_type:E,name:u.name}))}).unwrap(),S=b.files.map((u,E)=>{let c=v[E].file,R=c;return R.id=u.id,R.url=URL.createObjectURL(c),R});return await(await Promise.all(b.files.map((u,E)=>{let{mimeType:c}=v[E],R=S[E];return fetch(u.url,{method:"PUT",headers:{"Content-Type":c,"Content-Disposition":`inline; filename*=${Lo(R.name)}`,"X-File-Id":u.id},body:R})}))).forEach(async u=>{if(!u.ok)throw new Error("Erro no upload do arquivo.")}),S}catch(v){throw d(v),r(v,"Erro no upload"),v}finally{l(!1);}}},C=useMemo(()=>p&&p instanceof Error?p.message:p,[p]);return {setFilesPreview:a,uploadFiles:I,filesPreview:m,filePreview:g,isLoadingPreview:s,isUploadingFiles:t,isUploadOrLoadingFiles:x,uploadErrorText:C}},X=jr;var Hr=({sx:e,id:o,name:r,tabIndex:t,uploading:l,getRootProps:s,getInputProps:i,isDragActive:p,isError:d,disabled:m,dropZoneSxProps:a,dropZoneContent:g,children:x,...P})=>jsxs(Me,{children:[l&&jsx(a$8,{"data-testid":"uploading-progress-bar",sx:{zIndex:1}}),jsxs(De,{sx:{width:1,position:"relative",...e},children:[jsxs(lo,{...s(),"data-testid":"drop-zone-styled-area",isError:d,isDragActive:p,disabled:!!m,sx:a,...P,children:[jsx("input",{...i(),id:o,tabIndex:t,name:r}),g]}),x]})]}),de=Hr;var Xr=({header:e,description:o,sx:r,...t})=>jsxs(xe,{spacing:5,alignItems:"center",justifyContent:"center",direction:{xs:"column",md:"row"},sx:{width:1,textAlign:{xs:"center",md:"left"},...r},...t,children:[jsx(a$6,{sx:{width:220}}),jsxs("div",{children:[jsx(Je,{gutterBottom:!0,variant:"h5",children:e||"Soltar ou selecionar arquivos"}),jsx(Je,{variant:"body2",sx:{color:"text.secondary"},children:o||jsxs(Fragment,{children:["Solte os arquivos aqui ou clique",jsx(Je,{variant:"body2",component:"span",sx:{mx:.5,color:"primary.main",textDecoration:"underline"},children:"procurar"}),"na sua m\xE1quina"]})})]})]}),me=memo(Xr);var Yr=({onRemove:e,onReorder:o,onFilesSelect:r,createFilesMutation:t,filesDetails:l=[],id:s,disabled:i,error:p,helperText:d,thumbnail:m,dropZoneSxProps:a,uploading:g,tabIndex:x,maxFiles:P,placeholderAlt:A,placeholderProps:I,...C})=>{let{filesPreview:h,isUploadOrLoadingFiles:w,uploadErrorText:v,uploadFiles:b}=X({createFilesMutation:t,filesDetails:l}),{files:S,dropzoneProps:L,handleRemove:u,handleReorder:E}=q({onFilesSelect:r,onReorder:o,onRemove:e,filesPreview:h,dropzoneOptions:{multiple:!0,disabled:i,...C},maxFiles:P,uploadFiles:b}),{getRootProps:c,getInputProps:R,isDragActive:z,isDragReject:O}=L,T=!!S?.filter(B=>!!B.id).length,M=O||!!p||!!v;return jsxs(de,{id:s,uploading:g||w,disabled:i,dropZoneSxProps:a,tabIndex:x,getRootProps:c,getInputProps:R,isDragActive:z,isError:M,dropZoneContent:jsx(Fragment,{children:A?jsx(xe,{children:A}):jsx(me,{header:I?.header,description:I?.description})}),children:[jsx(y,{disabled:i,helperText:d,isError:M}),p?jsx(y,{helperText:p,isError:!0}):null,v?jsx(y,{helperText:v,isError:!0}):null,T&&jsx(De,{sx:{my:3},children:jsx(Se,{files:S,thumbnail:!!m,onRemove:e?u:void 0,onReorder:o?E:void 0})})]})},et=memo(Yr);var st=({onRemove:e,onReorder:o,onFilesSelect:r,createFilesMutation:t,filesDetails:l=[],id:s,disabled:i,error:p,helperText:d,dropZoneSxProps:m,placeholderProps:a,placeholderAlt:g,uploading:x,tabIndex:P,maxFiles:A,aspectRatio:I,enableCrop:C=!0,convertToWebp:h=!0,cropSize:w,name:v,label:b,...S})=>{let{filesPreview:L,isUploadOrLoadingFiles:u,uploadErrorText:E,uploadFiles:c}=X({createFilesMutation:t,filesDetails:l}),R=x||u,{files:z,dropzoneProps:O,cropState:T,aspectRatio:M,handleRemove:B,handleReorder:K}=q({onFilesSelect:r,onReorder:o,onRemove:e,filesPreview:L,dropzoneOptions:{accept:{"image/*":[".jpeg",".jpg",".png",".gif",".webp"]},multiple:!0,disabled:i,...S},enableCrop:C,customAspectRatio:I,convertToWebp:h,maxFiles:A,cropSize:w,uploadFiles:c}),{getRootProps:oe,getInputProps:j,isDragActive:ne,isDragReject:ge}=O,{cropModalOpen:se,imagePreview:le,cropLoading:Z,onCropInitialized:J,handleCropSave:Q,handleCropCancel:re,currentImageIndex:H,totalPendingImages:n}=T,ue=!!z?.filter(fe=>!!fe.id).length,te=ge||!!p||!!E,Fe=useMemo(()=>{let fe=b??"Ajustar Imagem",be=n>1||H>1?` (${H} de ${n})`:"";return `${fe}${be}`},[b,n,H]);return jsxs(de,{id:s,name:v,uploading:R,disabled:i,dropZoneSxProps:m,tabIndex:P,getRootProps:oe,getInputProps:j,isDragActive:ne,isError:te,dropZoneContent:jsx(Fragment,{children:g?jsx(xe,{children:g}):jsx(me,{header:a?.header,description:a?.description})}),children:[jsx(y,{disabled:i,helperText:d,isError:te}),p?jsx(y,{helperText:p,isError:!0}):null,E?jsx(y,{helperText:E,isError:!0}):null,ue&&jsx(De,{sx:{my:3,ml:.5},children:jsx(Se,{files:z,thumbnail:!0,onRemove:B,onReorder:o?K:void 0})}),jsx(a$7,{open:se,onClose:re,label:Fe,imageSrc:le,aspectRatio:M,onInitialized:J,onSave:Q,loading:Z,cropSize:w})]})},lt=memo(st);var ut=({onFileSelect:e$1,onRemove:o,createFilesMutation:r,fileDetails:t,id:l,disabled:s,error:i,helperText:p,sx:d,dropZoneSxProps:m$1,uploading:a,tabIndex:g,placeholderAlt:x,placeholderProps:P,...A})=>{let{filesPreview:I,isUploadOrLoadingFiles:C,uploadErrorText:h,uploadFiles:w}=X({createFilesMutation:r,filesDetails:t?[t]:[]}),v=C||a,{file:b,dropzoneProps:S,handleRemove:L}=q({uploadFiles:w,onFileSelect:e$1,onRemove:o,filesPreview:I,dropzoneOptions:{multiple:!1,disabled:s,...A}}),{getRootProps:u,getInputProps:E,isDragActive:c,isDragReject:R}=S,z=useCallback(B=>{B.stopPropagation(),L(b||void 0);},[b,L]),O=!!b,T=typeof b=="string",M=R||!!i||!!h;return jsxs(de,{id:l,uploading:v,disabled:s,dropZoneSxProps:m$1,tabIndex:g,getRootProps:u,getInputProps:E,isDragActive:c,isError:M,dropZoneContent:jsxs(Fragment,{children:[!O&&(x?jsx(xe,{...P,children:x}):jsx(me,{})),O&&jsxs(xe,{component:m.div,...j().inUp,spacing:2,direction:"row",alignItems:"center",sx:{my:1,px:1,py:.75,borderRadius:.75,border:B=>`solid 1px ${B.palette.divider}`,...d},children:[jsx(Ee,{file:b}),jsxs(xe,{flexGrow:1,sx:{minWidth:0},children:[jsx(Je,{variant:"subtitle2",noWrap:!0,children:T?b:b.name}),jsx(Je,{variant:"caption",sx:{color:"text.secondary"},children:T?"":e(b.size)})]}),o&&jsx(a$3,{title:"Remover arquivo",children:jsx(po,{edge:"end",size:"small",disabled:s,"aria-label":"Remover arquivo",onClick:z,children:jsx(a$5,{icon:"DELETE_MARK_BUTTON_02",width:16})})})]})]}),children:[jsx(y,{disabled:s,helperText:p,isError:M}),i?jsx(y,{helperText:i,isError:!0}):null,h?jsx(y,{helperText:h,isError:!0}):null]})},ft=memo(ut);var Et=({onRemove:e,onFileSelect:o,createFilesMutation:r,fileDetails:t,id:l,disabled:s,error:i,helperText:p,dropZoneSxProps:d,placeholderProps:m,placeholderAlt:a,hoverAlt:g,uploading:x,tabIndex:P,aspectRatio:A,enableCrop:I=!0,convertToWebp:C=!0,name:h,label:w,cropSize:v,sx:b,maxWidth:S,maxHeight:L,compressionQuality:u=.8,maxCompressedWidth:E,maxCompressedHeight:c,fill:R,...z})=>{let{filesPreview:O,isUploadOrLoadingFiles:T,uploadErrorText:M,uploadFiles:B}=X({createFilesMutation:r,filesDetails:t?[t]:[]}),[K,oe]=useState(!1),{file:j,dropzoneProps:ne,cropState:ge,handleRemove:se,aspectRatio:le}=q({onFileSelect:o,onRemove:e,dropzoneOptions:{accept:{"image/*":[".jpeg",".jpg",".png",".gif",".webp"]},multiple:!1,disabled:s,...z},filesPreview:O,enableCrop:I,customAspectRatio:A,convertToWebp:C,cropSize:v,uploadFiles:B,compressionQuality:u,maxCompressedWidth:E,maxCompressedHeight:c}),{getRootProps:Z,getInputProps:J,isDragActive:Q,isDragReject:re}=ne,{cropModalOpen:H,imagePreview:n,cropLoading:ue,onCropInitialized:te,handleCropSave:Fe,handleCropCancel:fe}=ge,be=useCallback(()=>{se(j||void 0);},[j,se]),f=!!j,F=re||!!i||!!M,D=x||T,_=f?{opacity:0}:{opacity:1},N=d?.width;return useEffect(()=>{f||oe(!1);},[f]),jsxs(Me,{sx:{...b,...N&&{width:N}},children:[(D||K)&&jsx(a$8,{}),jsxs(de,{id:l,uploading:D,disabled:s,dropZoneSxProps:d,tabIndex:P,getRootProps:Z,getInputProps:J,isDragActive:Q,isError:F,name:h,dropZoneContent:jsxs(Fragment,{children:[a?jsx(xe,{sx:_,children:a}):jsx(me,{sx:_,header:m?.title,description:m?.description}),f&&jsx(Xe,{file:j,cropSize:v,isLoading:K,isUploading:D,onLoading:oe,aspectRatio:le,maxWidth:S,maxHeight:L,hoverAlt:g,fill:R})]}),children:[jsx(y,{disabled:s,helperText:p,isError:F}),i?jsx(y,{helperText:i,isError:!0}):null,M?jsx(y,{helperText:M,isError:!0}):null,f&&e&&jsx(go,{size:"small",onClick:be,disabled:s,label:"Remover arquivo",children:jsx(a$5,{icon:"DELETE_MARK_BUTTON_02",width:16})}),jsx(a$7,{open:H,onClose:fe,label:w??"Ajustar Imagem",imageSrc:n,aspectRatio:le,onInitialized:te,onSave:Fe,loading:ue,cropSize:v})]})]})},wt=memo(Et);var yt=({onRemove:e,onFileSelect:o,createFilesMutation:r,fileDetails:t,disabled:l,label:s,id:i,tabIndex:p,error:d,helperText:m,sx:a,name:g,maxSize:x,uploading:P,aspectRatio:A=1,enableCrop:I=!0,convertToWebp:C=!0,cropSize:h,...w})=>{let[v,b]=useState(!1),{filesPreview:S,isUploadOrLoadingFiles:L,uploadErrorText:u,uploadFiles:E}=X({createFilesMutation:r,filesDetails:t?[t]:[]}),{file:c,dropzoneProps:R,cropState:z,handleRemove:O}=q({filesPreview:S,onFileSelect:o,onRemove:e,dropzoneOptions:{accept:{"image/*":[".jpeg",".jpg",".png",".gif",".webp"]},multiple:!1,disabled:l,maxSize:x,...w},enableCrop:I,customAspectRatio:A,convertToWebp:C,cropSize:h,uploadFiles:E}),{getRootProps:T,getInputProps:M,isDragActive:B,isDragReject:K}=R,{cropModalOpen:oe,imagePreview:j,cropLoading:ne,onCropInitialized:ge,handleCropSave:se,handleCropCancel:le}=z,Z=K||!!d||!!u,J=v||L||P,Q=!!e,re=useRef(t?.url||""),H=useRef();useEffect(()=>{if(!c){re.current="",H.current=void 0;return}if(H.current===c.id)return;H.current=c.id,b(!0);let te=URL.createObjectURL(c);return re.current=te,()=>{URL.revokeObjectURL(te);}},[c]);let n=()=>{b(!1);},ue=useCallback(()=>Q&&c?()=>O(c):T().onClick,[Q,c,T,O]);return jsxs(Fragment,{children:[jsxs(xe,{sx:{alignItems:"center"},children:[jsxs(vo,{sx:a,isError:Z,isDragActive:B,hasFile:!!c,...T(),onClick:ue(),children:[jsxs(Po,{children:[J&&jsx(Io,{children:jsx(_t,{size:135,thickness:2,color:"primary"})}),c&&jsx(Eo,{alt:"Avatar Preview",src:re.current,onLoad:n,...J&&{sx:{filter:"blur(5px) !important",scale:1.2,opacity:.7}}}),!c&&!J&&jsxs($e,{isError:Z,hasFile:!1,children:[jsx(a$5,{icon:"ADD_IMAGE",width:32}),jsx(Je,{variant:"caption",textAlign:"center",sx:{color:Z?"error.main":"text.disabled"},children:"Adicionar foto"})]}),c&&!J&&jsxs($e,{isError:Z,hasFile:!0,children:[jsx(a$5,{icon:Q?"DELETE_MARK_BUTTON_02":"ADD_IMAGE",width:32}),jsx(Je,{variant:"caption",textAlign:"center",sx:{color:Z?"error.main":"common.white"},children:Q?"Remover foto":"Alterar foto"})]})]}),jsx("input",{name:g,id:i,tabIndex:p,...M()})]}),jsx(xe,{sx:{alignItems:"center",mt:-.5},children:jsx(y,{helperText:m,disabled:l,isError:Z})}),u?jsx(y,{helperText:u,isError:!0}):null,d?jsx(y,{helperText:d,isError:!0}):null]}),oe&&j&&jsx(a$7,{open:oe,onClose:le,label:s??"Ajustar Imagem",imageSrc:j,aspectRatio:A,onInitialized:ge,onSave:se,loading:ne,cropSize:h,cropShape:"round"})]})},Ut=memo(yt);var Ct=({error:e,name:o,disabled:r,sx:t,...l})=>{let{getRootProps:s,getInputProps:i,isDragActive:p,isDragReject:d}=useDropzone({disabled:r,...l}),m=d||e;return jsxs(uo,{...s(),isDragActive:p,hasError:!!m,disabled:!!r,sx:t,"data-testid":"upload-box",children:[jsx("input",{name:o,...i()}),"Selecionar arquivo"]})},Mt=memo(Ct);
|
|
34
|
-
|
|
35
|
-
export { y as a, Se as b, Xe as c, ke as d, Ee as e, Ji as f, Uo as g, To as h, Oo as i, Lo as j, q as k, Ve as l, Be as m, X as n, et as o, lt as p, ft as q, wt as r, Ut as s, Mt as t };
|
|
36
|
-
//# sourceMappingURL=out.js.map
|
|
37
|
-
//# sourceMappingURL=chunk-VYNBVZSA.js.map
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
package/dist/chunk-WQSRNCNF.js
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
package/dist/chunk-YCEQDXLR.js
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { useState } from 'react';
|
|
2
|
-
import { useFormContext } from 'react-hook-form';
|
|
3
|
-
|
|
4
|
-
function F(t,i){let{watch:r,setValue:n}=useFormContext(),[u,o]=useState(i),l=r(t)||[];return {uploadFile:async e=>{if(!e){n(t,void 0),o(void 0);return}n(t,e),o(Object.assign(e,{preview:URL.createObjectURL(e)}));},uploadFiles:async e=>{n(t,[...l,...e.map(s=>Object.assign(s,{preview:URL.createObjectURL(s)}))]);},handleDeleteFile:()=>{n(t,void 0),o(void 0);},handleRemoveAll:()=>{n(t,void 0);},handleRemove:e=>{let s=l.filter(a=>a!==e);n(t,s);},file:u,setFileValue:o}}var b=F;
|
|
5
|
-
|
|
6
|
-
export { b as a };
|
|
7
|
-
//# sourceMappingURL=out.js.map
|
|
8
|
-
//# sourceMappingURL=chunk-YCEQDXLR.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/hooks/useUpload.ts"],"names":["useState","useFormContext","useUpload","fieldName","urlImage","watch","setValue","fileValue","setFileValue","filesValues","file","files","filteredItems","f","useUpload_default"],"mappings":"AAAA,OAAS,YAAAA,MAAgB,QACzB,OAAS,kBAAAC,MAAsB,kBAI/B,SAASC,EAAUC,EAAmBC,EAAmB,CACvD,GAAM,CAAE,MAAAC,EAAO,SAAAC,CAAS,EAAIL,EAAe,EACrC,CAACM,EAAWC,CAAY,EAAIR,EAChCI,CACF,EACMK,EAAwBJ,EAAMF,CAAS,GAAK,CAAC,EA4CnD,MAAO,CACL,WA3CiB,MAAOO,GAAgB,CACxC,GAAI,CAACA,EAAM,CACTJ,EAASH,EAAW,MAAS,EAC7BK,EAAa,MAAS,EACtB,OAGFF,EAASH,EAAWO,CAAI,EAExBF,EACE,OAAO,OAAOE,EAAM,CAClB,QAAS,IAAI,gBAAgBA,CAAI,CACnC,CAAC,CACH,CACF,EA8BE,YA5BkB,MAAOC,GAAkB,CAC3CL,EAASH,EAAW,CAClB,GAAGM,EACH,GAAGE,EAAM,IAAKD,GACZ,OAAO,OAAOA,EAAM,CAClB,QAAS,IAAI,gBAAgBA,CAAI,CACnC,CAAC,CACH,CACF,CAAC,CACH,EAoBE,iBAlBuB,IAAM,CAC7BJ,EAASH,EAAW,MAAS,EAC7BK,EAAa,MAAS,CACxB,EAgBE,gBAdsB,IAAM,CAC5BF,EAASH,EAAW,MAAS,CAC/B,EAaE,aAXoBO,GAAwB,CAC5C,IAAME,EAAgBH,EAAY,OAAOI,GAAKA,IAAMH,CAAI,EAExDJ,EAASH,EAAWS,CAAa,CACnC,EAQE,KAAML,EACN,aAAAC,CACF,CACF,CAEA,IAAOM,EAAQZ","sourcesContent":["import { useState } from 'react';\nimport { useFormContext } from 'react-hook-form';\n\nimport { CustomFile } from 'types/upload';\n\nfunction useUpload(fieldName: string, urlImage?: string) {\n const { watch, setValue } = useFormContext();\n const [fileValue, setFileValue] = useState<CustomFile | string | undefined>(\n urlImage,\n );\n const filesValues: string[] = watch(fieldName) || [];\n\n const uploadFile = async (file?: File) => {\n if (!file) {\n setValue(fieldName, undefined);\n setFileValue(undefined);\n return;\n }\n\n setValue(fieldName, file);\n\n setFileValue(\n Object.assign(file, {\n preview: URL.createObjectURL(file),\n }),\n );\n };\n\n const uploadFiles = async (files: File[]) => {\n setValue(fieldName, [\n ...filesValues,\n ...files.map((file: Blob | MediaSource) =>\n Object.assign(file, {\n preview: URL.createObjectURL(file),\n }),\n ),\n ]);\n };\n\n const handleDeleteFile = () => {\n setValue(fieldName, undefined);\n setFileValue(undefined);\n };\n\n const handleRemoveAll = () => {\n setValue(fieldName, undefined);\n };\n\n const handleRemove = (file: File | string) => {\n const filteredItems = filesValues.filter(f => f !== file);\n\n setValue(fieldName, filteredItems);\n };\n\n return {\n uploadFile,\n uploadFiles,\n handleDeleteFile,\n handleRemoveAll,\n handleRemove,\n file: fileValue,\n setFileValue,\n };\n}\n\nexport default useUpload;\n"]}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { BaseField } from '../../../types/baseField.js';
|
|
3
|
-
import { UploadProps } from '../../../types/upload.js';
|
|
4
|
-
import 'react-hook-form';
|
|
5
|
-
import 'react';
|
|
6
|
-
import 'react-dropzone';
|
|
7
|
-
import '@mui/material/styles';
|
|
8
|
-
|
|
9
|
-
interface IProps {
|
|
10
|
-
aspect: number;
|
|
11
|
-
label: string;
|
|
12
|
-
image?: string;
|
|
13
|
-
onFileCropped?(file: File | undefined): void;
|
|
14
|
-
onImageUploaded(image?: string): void;
|
|
15
|
-
onCancel?: VoidFunction;
|
|
16
|
-
}
|
|
17
|
-
type UploadAvatarWithCropProps = BaseField<UploadProps> & IProps;
|
|
18
|
-
|
|
19
|
-
declare const UploadAvatarWithCrop: ({ name, rules, helperText, aspect, label, image, onFileCropped, onImageUploaded, onCancel, ...other }: UploadAvatarWithCropProps) => react_jsx_runtime.JSX.Element;
|
|
20
|
-
|
|
21
|
-
export { UploadAvatarWithCrop as default };
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { b } from '../../../chunk-JFZOAS75.js';
|
|
2
|
-
import '../../../chunk-6WGKIN5L.js';
|
|
3
|
-
import '../../../chunk-KR3DUHA6.js';
|
|
4
|
-
import '../../../chunk-ESFOFEVL.js';
|
|
5
|
-
import '../../../chunk-WQSRNCNF.js';
|
|
6
|
-
import '../../../chunk-RFRLNTFN.js';
|
|
7
|
-
import '../../../chunk-OF6623HG.js';
|
|
8
|
-
import '../../../chunk-NQNNMRLC.js';
|
|
9
|
-
import '../../../chunk-CIGSMWKF.js';
|
|
10
|
-
import { a } from '../../../chunk-YCEQDXLR.js';
|
|
11
|
-
import '../../../chunk-SBMEL2IJ.js';
|
|
12
|
-
import '../../../chunk-E3R7W7GK.js';
|
|
13
|
-
import '../../../chunk-IAOMC4C4.js';
|
|
14
|
-
import '../../../chunk-GLRLKFPS.js';
|
|
15
|
-
import { useFormContext, Controller } from 'react-hook-form';
|
|
16
|
-
import W from '@mui/material/FormHelperText';
|
|
17
|
-
import { jsx } from 'react/jsx-runtime';
|
|
18
|
-
|
|
19
|
-
var v=({name:e,rules:m,helperText:r,aspect:n,label:f,image:s,onFileCropped:a$1,onImageUploaded:u,onCancel:l,...c})=>{let{control:C}=useFormContext(),{uploadFile:U,file:g,setFileValue:x}=a(e);return jsx(Controller,{name:e,control:C,rules:m,render:({field:{value:F},fieldState:{error:o}})=>jsx(b,{accept:{"image/*":[]},file:F?g:void 0,onFileCropped:p=>{U(p),a$1&&a$1(p);},onImageUploaded:u,onCancel:()=>{x(void 0),l&&l();},error:!!o,disableMultiple:!0,helperText:(!!o||r)&&jsx(W,{error:!!o,sx:{px:2},children:o?o?.message:r}),aspect:n,label:f,image:s,"data-intercom-target":e,...c})})},I=v;
|
|
20
|
-
|
|
21
|
-
export { I as default };
|
|
22
|
-
//# sourceMappingURL=out.js.map
|
|
23
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/components/form/UploadAvatarWithCrop/index.tsx"],"names":["Controller","useFormContext","FormHelperText","jsx","UploadAvatarWithCrop","name","rules","helperText","aspect","label","image","onFileCropped","onImageUploaded","onCancel","other","control","uploadFile","file","setFileValue","useUpload_default","value","error","upload_avatar_with_crop_default","v","UploadAvatarWithCrop_default"],"mappings":"kgBAAA,OAAS,cAAAA,EAAY,kBAAAC,MAAsB,kBAC3C,OAAOC,MAAoB,+BA6Cb,cAAAC,MAAA,oBAtCd,IAAMC,EAAuB,CAAC,CAC5B,KAAAC,EACA,MAAAC,EACA,WAAAC,EACA,OAAAC,EACA,MAAAC,EACA,MAAAC,EACA,cAAAC,EACA,gBAAAC,EACA,SAAAC,EACA,GAAGC,CACL,IAAiC,CAC/B,GAAM,CAAE,QAAAC,CAAQ,EAAId,EAAe,EAC7B,CAAE,WAAAe,EAAY,KAAAC,EAAM,aAAAC,CAAa,EAAIC,EAAUd,CAAI,EAEzD,OACEF,EAACH,EAAA,CACC,KAAMK,EACN,QAASU,EACT,MAAOT,EACP,OAAQ,CAAC,CAAE,MAAO,CAAE,MAAAc,CAAM,EAAG,WAAY,CAAE,MAAAC,CAAM,CAAE,IACjDlB,EAACmB,EAAA,CACC,OAAQ,CAAE,UAAW,CAAC,CAAE,EACxB,KAAMF,EAAQH,EAAO,OACrB,cAAeM,GAAK,CAClBP,EAAWO,CAAC,EACRZ,GAAeA,EAAcY,CAAC,CACpC,EACA,gBAAiBX,EACjB,SAAU,IAAM,CACdM,EAAa,MAAS,EAElBL,GAAUA,EAAS,CACzB,EACA,MAAO,CAAC,CAACQ,EACT,gBAAe,GACf,YACG,CAAC,CAACA,GAASd,IACVJ,EAACD,EAAA,CAAe,MAAO,CAAC,CAACmB,EAAO,GAAI,CAAE,GAAI,CAAE,EACzC,SAAAA,EAAQA,GAAO,QAAUd,EAC5B,EAGJ,OAAQC,EACR,MAAOC,EACP,MAAOC,EACP,uBAAsBL,EACrB,GAAGS,EACN,EAEJ,CAEJ,EAEOU,EAAQpB","sourcesContent":["import { Controller, useFormContext } from 'react-hook-form';\nimport FormHelperText from '@mui/material/FormHelperText';\n\nimport UploadAvatarWithCropComponent from 'components/upload/upload-avatar-with-crop';\nimport useUpload from 'hooks/useUpload';\n\nimport { UploadAvatarWithCropProps } from './props';\n\nconst UploadAvatarWithCrop = ({\n name,\n rules,\n helperText,\n aspect,\n label,\n image,\n onFileCropped,\n onImageUploaded,\n onCancel,\n ...other\n}: UploadAvatarWithCropProps) => {\n const { control } = useFormContext();\n const { uploadFile, file, setFileValue } = useUpload(name);\n\n return (\n <Controller\n name={name}\n control={control}\n rules={rules}\n render={({ field: { value }, fieldState: { error } }) => (\n <UploadAvatarWithCropComponent\n accept={{ 'image/*': [] }}\n file={value ? file : undefined}\n onFileCropped={v => {\n uploadFile(v);\n if (onFileCropped) onFileCropped(v);\n }}\n onImageUploaded={onImageUploaded}\n onCancel={() => {\n setFileValue(undefined);\n\n if (onCancel) onCancel();\n }}\n error={!!error}\n disableMultiple\n helperText={\n (!!error || helperText) && (\n <FormHelperText error={!!error} sx={{ px: 2 }}>\n {error ? error?.message : helperText}\n </FormHelperText>\n )\n }\n aspect={aspect}\n label={label}\n image={image}\n data-intercom-target={name}\n {...other}\n />\n )}\n />\n );\n};\n\nexport default UploadAvatarWithCrop;\n"]}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { BaseField } from '../../../types/baseField.js';
|
|
3
|
-
import { UploadProps } from '../../../types/upload.js';
|
|
4
|
-
import 'react-hook-form';
|
|
5
|
-
import 'react';
|
|
6
|
-
import 'react-dropzone';
|
|
7
|
-
import '@mui/material/styles';
|
|
8
|
-
|
|
9
|
-
interface IProps {
|
|
10
|
-
aspect: number;
|
|
11
|
-
label: string;
|
|
12
|
-
image?: string;
|
|
13
|
-
onFileCropped?(file: File | undefined): void;
|
|
14
|
-
onImageUploaded(image?: string): void;
|
|
15
|
-
onCancel?: VoidFunction;
|
|
16
|
-
}
|
|
17
|
-
type UploadWithCropProps = BaseField<UploadProps> & IProps;
|
|
18
|
-
|
|
19
|
-
declare const UploadWithCrop: ({ name, rules, helperText, aspect, label, image, onFileCropped, onImageUploaded, onCancel, ...other }: UploadWithCropProps) => react_jsx_runtime.JSX.Element;
|
|
20
|
-
|
|
21
|
-
export { UploadWithCrop as default };
|