@swan-admin/swan-web-component 1.0.105 → 1.0.107

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/dist/BodyScan-BJqddH9l.js +2 -0
  2. package/dist/BodyScan-BJqddH9l.js.map +1 -0
  3. package/dist/BodyScan-BMSwRF8g.js +2 -0
  4. package/dist/BodyScan-BMSwRF8g.js.map +1 -0
  5. package/dist/BodyScan-C4Ycxu7X.js +2 -0
  6. package/dist/BodyScan-C4Ycxu7X.js.map +1 -0
  7. package/dist/BodyScan-CffCyP1x.js +2 -0
  8. package/dist/BodyScan-CffCyP1x.js.map +1 -0
  9. package/dist/FaceScan-Bilx5Uxm.js +2 -0
  10. package/dist/FaceScan-Bilx5Uxm.js.map +1 -0
  11. package/dist/FaceScan-CgKhy7Fv.js +2 -0
  12. package/dist/FaceScan-CgKhy7Fv.js.map +1 -0
  13. package/dist/FaceScan-DiWbxkKT.js +2 -0
  14. package/dist/FaceScan-DiWbxkKT.js.map +1 -0
  15. package/dist/FaceScan-DzoH_-xE.js +2 -0
  16. package/dist/FaceScan-DzoH_-xE.js.map +1 -0
  17. package/dist/LoadingScreen-BpZsFNfx.js +2 -0
  18. package/dist/LoadingScreen-BpZsFNfx.js.map +1 -0
  19. package/dist/LoadingScreen-G2UAxhzi.js +2 -0
  20. package/dist/LoadingScreen-G2UAxhzi.js.map +1 -0
  21. package/dist/LoadingScreen-dw8GNGG0.js +2 -0
  22. package/dist/LoadingScreen-dw8GNGG0.js.map +1 -0
  23. package/dist/LoadingScreen-rSXW_5Vv.js +2 -0
  24. package/dist/LoadingScreen-rSXW_5Vv.js.map +1 -0
  25. package/dist/bodyScan.js +1 -1
  26. package/dist/bodyScan.mjs +1 -1
  27. package/dist/faceScan.js +1 -1
  28. package/dist/faceScan.mjs +1 -1
  29. package/dist/index.css +1 -1
  30. package/dist/index.js +1 -1
  31. package/dist/index.mjs +1 -1
  32. package/dist/pose-detection.esm-Dtxn0TmC.js +18 -0
  33. package/dist/pose-detection.esm-Dtxn0TmC.js.map +1 -0
  34. package/dist/pose-detection.esm-qPaFsqLN.js +18 -0
  35. package/dist/pose-detection.esm-qPaFsqLN.js.map +1 -0
  36. package/package.json +2 -2
@@ -0,0 +1,2 @@
1
+ "use strict";var e=require("react/jsx-runtime"),t=require("react"),s=require("posthog-js"),a=require("./LoadingScreen-rSXW_5Vv.js"),n=require("clsx"),r=require("react-webcam"),o=require("lucide-react"),i=require("@mui/material"),c=require("video.js");const l="DESKTOP",u="TAB",d="MOBILE",m=t.createContext(void 0);function f({children:s}){const[a,n]=t.useState([window?.innerWidth,window?.innerHeight]),[r,o]=t.useState(!1),i=()=>{n([window?.innerWidth,window?.innerHeight])};t.useEffect(()=>{i()},[]),t.useLayoutEffect(()=>(window.addEventListener("resize",i),()=>window.removeEventListener("resize",i)),[i]);let c=l;a[0]>768&&a[0]<1024&&(c=u),a[0]<768&&(c=d);const f=t.useMemo(()=>({size:a,setSize:n,clearInputs:r,setClearInputs:o,media:c}),[a,r,c]);return e.jsx(m.Provider,{value:f,children:s})}var h=t.memo(function({size:t=16}){return e.jsxs("svg",{width:t,height:t,viewBox:"0 0 25 25",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[e.jsx("path",{d:"M22.6968 14.6968C22.6968 16.8185 21.8539 18.8533 20.3536 20.3536C18.8533 21.8539 16.8185 22.6968 14.6968 22.6968",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M18.6968 11.6968V10.6968C18.6968 10.1663 18.4861 9.65764 18.111 9.28256C17.7359 8.90749 17.2272 8.69678 16.6968 8.69678C16.1663 8.69678 15.6576 8.90749 15.2826 9.28256C14.9075 9.65764 14.6968 10.1663 14.6968 10.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M14.6968 10.6968V9.69678C14.6968 9.16634 14.4861 8.65764 14.111 8.28256C13.7359 7.90749 13.2272 7.69678 12.6968 7.69678C12.1663 7.69678 11.6576 7.90749 11.2826 8.28256C10.9075 8.65764 10.6968 9.16634 10.6968 9.69678V10.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M10.6968 10.1968V4.69678C10.6968 4.16634 10.4861 3.65764 10.111 3.28256C9.73592 2.90749 9.22721 2.69678 8.69678 2.69678C8.16634 2.69678 7.65764 2.90749 7.28256 3.28256C6.90749 3.65764 6.69678 4.16634 6.69678 4.69678V14.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M18.6969 11.6968C18.6969 11.1663 18.9076 10.6576 19.2827 10.2826C19.6577 9.90749 20.1664 9.69678 20.6969 9.69678C21.2273 9.69678 21.736 9.90749 22.1111 10.2826C22.4862 10.6576 22.6969 11.1663 22.6969 11.6968V14.6968C22.6969 16.8185 21.854 18.8533 20.3537 20.3536C18.8534 21.8539 16.8186 22.6968 14.6969 22.6968H12.6969C9.89688 22.6968 8.19688 21.8368 6.70688 20.3568L3.10688 16.7568C2.76282 16.3757 2.57847 15.8769 2.592 15.3637C2.60554 14.8505 2.81593 14.3621 3.1796 13.9997C3.54327 13.6373 4.03238 13.4287 4.54565 13.417C5.05892 13.4053 5.55704 13.5914 5.93688 13.9368L7.69688 15.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})]})});var g=t.memo(function({angle:s,countdown:r,isScanning:o,isInTargetRange:i,stabilityScore:c,children:l,config:u}){const{translate:d}=t.useContext(a.LanguageContext)||{},m=t.useCallback(()=>s<80?Math.max(0,Math.min(100,10*(s-60))):s>95?Math.max(0,Math.min(100,10*(105-s))):100,[s]),f=t.useMemo(()=>{if(o)return u?.style?.angleDetector?.successAngleBackground||"#4f46e5";const e=m();if(0===e)return u?.style?.angleDetector?.successAngleLowBackground||"#ffffff";if(100===e)return u?.style?.angleDetector?.successAngleBackground||"#4f46e5";return`rgb(${Math.round(255-e/100*116)}, ${Math.round(255-e/100*163)}, ${Math.round(255-e/100*9)})`},[o,m]),g=t.useCallback((e,t)=>t>70?e?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]/70`:`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]`:e?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]/40`:`text-[${u?.style?.angleDetector?.successAngleTextDarkColor}]/70`,[]),p=t.useCallback((e=!1)=>{const t=m();return o?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]`:g(e,t)},[o,m]),x=t.useCallback((e,t)=>t>70||e?u?.style?.angleDetector?.successAngleTextLightColor:u?.style?.angleDetector?.successAngleTextDarkColor,[]),y=t.useCallback((e=!1)=>{const t=m();return o?u?.style?.angleDetector?.successAngleTextLightColor:x(e,t)},[o,m]),S=r;function v(){document.documentElement.style.setProperty("--real-vh",window.innerHeight+"px")}return v(),window.addEventListener("resize",v),e.jsxs("div",{className:"flex w-screen flex-col items-center h-[var(--real-vh)] overflow-hidden touch-none justify-center transition-all duration-300 max-w-[28rem] mx-auto",style:{backgroundColor:f},children:[e.jsx("div",{className:"flex justify-start fixed top-[.5rem] max-w-[28rem] mx-auto w-full px-[1rem]",children:e.jsx("div",{className:"flex justify-start ",children:e.jsx(a.Header,{noTitle:!0,resolvedConfig:u})})}),null!==S?e.jsx("div",{className:"relative flex h-[6rem] w-[6rem] items-center justify-center rounded-[9999px] bg-[#fff]/20 transition-all duration-300",style:{border:`2px solid ${y()}`},children:e.jsx("div",{className:`text-[3rem] font-bold text-[${y()}]`,style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:y()},children:S})}):o?e.jsxs("div",{className:"relative flex flex-col items-center justify-center",children:[e.jsx("div",{className:"relative flex h-16 w-16 items-center justify-center rounded-[9999px] border-2 bg-[#fff]/30 border-[#fff]",children:e.jsx("div",{className:"h-4 w-4 rounded-[9999px] animate-pulse bg-[#fff]/80"})}),l]}):e.jsxs("div",{className:n("relative flex h-[4rem] w-[4rem] items-center justify-center rounded-[9999px] ",i?"bg-[#fff]/20 border-[#fff]":"bg-[#fff]/10 border-[#fff]"),style:{transform:`translateY(${3*(90-s)}px)`,transition:"transform 0.2s ease-out",border:`2px solid ${y()}`},children:[e.jsx("div",{className:`h-[1rem] w-[1rem] rounded-[9999px] bg-[${y()}]/80`,style:{backgroundColor:`${y()}B3`}}),e.jsxs("div",{className:n("mt-[.5rem] text-center w-[180px] flex-col flex items-center absolute top-[60px]",p()),style:{color:y()},children:[e.jsx(h,{size:30}),e.jsxs("p",{style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif"},children:[" ",d?.(a.LanguageKeys.startLevelCheck),e.jsx("br",{})]})]})]}),null!==S&&e.jsx("div",{className:"absolute bottom-[8rem] text-center",children:e.jsx("div",{className:n("text-sm font-medium px-4 py-1.5 bg-black/20 rounded-[9999px] mt-8",p()),style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:y()},children:d?.(a.LanguageKeys.leavePhone)})}),i&&null===S&&!o&&e.jsx("div",{className:"absolute bottom-[8rem] w-[12rem]",children:e.jsx("div",{className:`h-[.375rem] w-full bg-[${y()}]/20 rounded-[9999px] overflow-hidden`,style:{backgroundColor:`${y()}33`},children:e.jsx("div",{className:`h-full bg-[${y()}]/70 transition-all duration-300 rounded-[9999px]`,style:{width:`${s}%`,backgroundColor:`${y()}B3`}})})}),null===S&&!o&&e.jsx("div",{className:"absolute bottom-[5rem] text-center",children:e.jsxs("div",{className:n("text-[1.5rem] font-light",p()),style:{color:y()},children:[Math.round(s),"°"]})}),null===S&&!o&&e.jsx("div",{className:"absolute bottom-[2rem] text-center max-w-[20rem] mx-auto",children:e.jsx("div",{className:n("text-[.75rem] opacity-50",p()),style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:y()},children:d?.(a.LanguageKeys.placePhoneUpright)})})]})});function p({handleShowStreamCamera:s,loadingCam:n,handleUserMedia:i,handlePause:c,pause:l,recordingStarted:u,startSendingVideoFrames:f,showPause:h,webcamRef:g,resetDetector:p,config:x}){const{media:y}=t.useContext(m)||{},{translate:S}=t.useContext(a.LanguageContext)||{};return e.jsxs("div",{className:"App w-screen h-[100vh] relative ",children:[e.jsx("span",{onClick:()=>{s(),p()},className:"fixed right-[20px] top-[20px] z-[999]",children:e.jsx(o.X,{className:"text-[#fff]"})}),e.jsx("div",{className:"w-full h-full overflow-hidden ",children:y===d&&e.jsx(r,{audio:!1,ref:g,screenshotQuality:1,videoConstraints:a.videoConstraints,mirrored:!0,screenshotFormat:"image/jpeg",onUserMedia:i,style:{position:"fixed",top:0,bottom:0,zIndex:0,width:"100%",height:"100%",objectFit:"cover"}})}),e.jsxs("div",{className:"fixed bottom-[30px] w-full z-[999] flex flex-col gap-4 items-center justify-center",children:[h&&e.jsx(a.SpecificButton,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto ",prefix:a.pauseIcon,buttonText:S?.(a.LanguageKeys.pause),buttonFunc:c,resolvedConfig:x,btnSecondary:!0}),l?e.jsx("div",{children:e.jsx(a.SpecificButton,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto",buttonText:S?.(a.LanguageKeys.restart),buttonFunc:s,resolvedConfig:x,btnSecondary:!0})}):u?null:e.jsx(a.SpecificButton,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto !bg-[#ffffff] !text-[#000000] "+(n?"!opacity-50":""),buttonText:S?.(a.LanguageKeys.startScan),buttonFunc:f,disabled:n,resolvedConfig:x})]}),e.jsx("audio",{id:"audioElement",crossOrigin:"anonymous",preload:"auto",style:{position:"absolute",zIndex:-99999},src:`${a.voiceOverAssetsPath}scanAudioInstructions/silence.mp3`})]})}let x=null,y=null,S=null;let v,b=null,C=null;var w=t.memo(function({setIsScanLocked:n,resetDetector:r,scanID:o,setIsVideoUploaded:i,setScanFailsError:c,setScanStartTime:l,setScanUniqueKey:u,userDetails:d,config:m}){const{gender:f,heightInCm:h,email:g,shopDomain:w}=d,j=t.useRef(null),N=t.useRef(null),[F,k]=t.useState([]),[E,D]=t.useState(!0),[T,I]=t.useState(!1),[L,M]=t.useState(!1),[A,_]=t.useState(!0),[P,U]=t.useState(!1),$=t.useRef(null),[z,R]=t.useState(""),[K,O]=t.useState([]),[q,B]=t.useState(""),[V,W]=t.useState(!1),[H,G]=t.useState(!1),[J,Q]=t.useState(!1),[X,Y]=t.useState([]),[Z,ee]=t.useState(!1),te=t.useRef(!0),{poseDetector:se}=function(){const[e,s]=t.useState(0),[a,n]=t.useState(0),[r,o]=t.useState(!1),i=t.useRef(0),c=t.useRef(0),l=t.useRef(!0);async function u(){if("undefined"==typeof window||"undefined"==typeof navigator)return!1;try{console.log("Starting TensorFlow preload...");const[e,t,s]=await Promise.all([Promise.resolve().then(function(){return require("./pose-detection.esm-Dtxn0TmC.js")}),import("@tensorflow/tfjs-core"),import("@tensorflow/tfjs-backend-webgl")]);S=e,await t.setBackend("webgl"),await t.ready(),console.log("TensorFlow backend ready (WebGL)");const a={runtime:"mediapipe",modelType:"full",solutionPath:"https://cdn.jsdelivr.net/npm/@mediapipe/pose"};try{y=await S.createDetector(S.SupportedModels.BlazePose,a),console.log("MediaPipe detector created successfully")}catch(e){console.warn("MediaPipe failed, falling back to TFJS runtime:",e),y=await S.createDetector(S.SupportedModels.BlazePose,{runtime:"tfjs",modelType:"full"}),console.log("TFJS detector created successfully")}return!0}catch(e){return console.error("Failed to load TensorFlow dependencies:",e),x=null,!1}}function d(e){return!(!e||0===e.length)&&22===e.filter(e=>e[2]>.7).length}return t.useEffect(()=>{if(l.current=!0,!y)return x||(x=u()),x.then(e=>{e&&l.current&&o(!0)}),()=>{l.current=!1};o(!0)},[]),t.useEffect(()=>{c.current=e,e>6&&i.current<2&&(n(e=>e+1),s(0))},[e]),t.useEffect(()=>{i.current=a},[a]),{poseDetector:async(e,t)=>{if(!y||!l.current||!t?.current?.video)return;const a=t.current.video;if(!(a.readyState<2))try{const t=await y.estimatePoses(a,{flipHorizontal:!1});if(!t||!t.length)return;const n=t[0].keypoints.slice(11).map(e=>[e.x>0&&e.x<720?e.x:-1,e.y>0&&e.y<1280?e.y:-1,e.score??0]);0!==i.current||d(n)||s(e=>e+1),1===i.current&&d(n)&&s(e=>e+1),2===i.current&&e()}catch(e){console.error("Pose detection error:",e)}},isLoaded:r,spinPhase:a,resetDetector:()=>{i.current=0,c.current=0,s(0),n(0)},retryLoading:async()=>{y||x||(x=u(),await x&&l.current&&o(!0))}}}(),ae=t.useRef(!0),ne=t.useRef(!1),[re,oe]=t.useState([]);let ie=0;const{setStartGyro:ce,handleFileUpload:le,setUploadLoading:ue}=t.useContext(a.ParamsContext),de=()=>{ne.current=!1,clearTimeout(v),$.current&&clearTimeout($.current),u(a.generateUuid()),c(""),ue?.(!1),k([]),D(!0),I(!1),M(!1),_(!0),U(!1),$.current=null,R(""),O([]),B(""),W(!V),ce(!1),a.speechService.stopAudio(),G(!1),Q(!1),ie=0,null!==N.current&&N.current.stop(),X.forEach(e=>{N.current&&N.current.removeEventListener("dataavailable",e)}),Y([]),te.current=!0,ee(!1),i(!1)},me=t.useCallback(()=>{setTimeout(()=>{D(!1)},1e3)},[]),fe=t.useCallback(()=>{a.rescanSupportCaptureEvent({eventName:`${w}/rescan`,email:g,scanID:o,height:h,gender:f,status:!1}),te.current=!1,de(),Ce()},[de,o,g]),he=t.useCallback(()=>{te.current=!1,Q(!0),ee(!1),$.current&&clearTimeout($.current),N.current&&N.current.pause(),a.speechService.stopAudio(),a.swan.poseDetection.disconnect(),ie=0,N.current&&N.current.stop(),X.forEach(e=>{N.current&&N.current.removeEventListener("dataavailable",e)}),Y([]),clearTimeout(v)},[N,X,a.speechService,te]),ge=t.useCallback(async()=>{te.current=!0,await a.speechService.playAudio(`${a.voiceOverAssetsPath}SpotOn.mp3`),Q(!1),ee(!1),$.current&&clearTimeout($.current),I(!1)},[$,a.speechService]),pe=t.useCallback(async()=>{try{b=await a.swan.poseDetection.connect(),s.capture(`${w}/pose_detection_connected`,{scanID:o,email:g,id:b})}catch(e){console.log(e,"while connecting websocket")}},[o,w,g]),xe=t.useCallback(({data:e})=>{e&&e.size>0&&te.current&&(k(t=>t.concat(e)),!ne.current&&j.current&&(ne.current=!0,se(()=>{ge(),a.handleScanTimeCapture({eventName:`${w}/tensorFlow`,scanID:o,email:g,message:"recording stopped by tensorflow "})},j)))},[ge,a.handleScanTimeCapture,w,o,g,j]),ye=t.useCallback(async()=>{K.length>0&&te.current&&(await a.speechService.playAudio(a.voiceOverAssetsPath+K[K.length-1]),te.current&&(v=setTimeout(ye,2e3)))},[K,te]),Se=t.useCallback(()=>{N&&N.current&&N.current.stop(),I(!0);try{if(j&&j.current&&j.current.stream){const e={mimeType:re[0]};N.current=new MediaRecorder(j.current.stream,e),N.current.addEventListener("dataavailable",xe),Y([...X,xe]),N.current.start(1e3),_(!1)}}catch(e){console.log("error while using media recorder",e)}},[j,re,xe,X]),ve=t.useCallback(async()=>{$.current&&clearTimeout($.current),Se(),te.current&&($.current=setTimeout(async()=>{te.current&&(await a.speechService.playAudio(`${a.voiceOverAssetsPath}SpotOn.mp3`),I(!1))},15e3)),M(!0),te.current&&await a.speechService.playAudio(`${a.voiceOverAssetsPath}Spin.mp3`)},[Se,te,a.speechService]),be=t.useCallback(({data:e})=>{e.size>0&&a.swan.poseDetection.connected()&&(a.swan.poseDetection.poseStatus(async e=>{if(e&&e.audio&&e.audio.length>0){const t=document.querySelector("#audioElement");!0===e.status&&e.sid===b?ie<2?(0===ie&&t?.paused&&await a.speechService.playAudio(a.voiceOverAssetsPath+e.audio),ie+=1):(B(e.audio),clearTimeout(v),a.swan.poseDetection.disconnect(),setTimeout(ve,1e3)):(ie=0,!t?.paused||C&&C?.audioName===e.audio?C?.audioName===e.audio&&t?.paused&&(C&&C.no_of_times_skipped>=C.skipCount?(C.no_of_times_skipped=0,a.speechService.playAudio(a.voiceOverAssetsPath+e.audio)):C&&(C.no_of_times_skipped+=1)):(C={skipCount:2,no_of_times_skipped:0,audioName:e.audio},a.speechService.playAudio(a.voiceOverAssetsPath+e.audio)))}}),j?.current&&null!==j.current.getScreenshot()&&a.swan.poseDetection.videoEmit({image:j.current.getScreenshot()||"",scanId:o}))},[j,o,a.swan,b,ie,ve,a.speechService]),Ce=t.useCallback(async()=>{U(!0),ce(!0),ae.current&&(ae.current=!1,a.handleScanTimeCapture({eventName:"scan started",scanID:o,status:"success",email:g})),l(a.getCurrentTimeInSeconds()),D(!0),te.current&&await a.speechService.playAudio(`${a.voiceOverAssetsPath}StartScan.mp3`),te.current&&await a.speechService.playAudio(`${a.voiceOverAssetsPath}LiftArmsAndHoldAtHip.mp3`),te.current&&(U(!1),I(!0),G(!0),ee(!0),me());try{if(j&&j.current&&j.current.stream&&te.current){const e={mimeType:re[0]};te.current&&(N.current=new MediaRecorder(j.current.stream,e)),te.current&&N.current&&N.current.addEventListener("dataavailable",be),Y([...X,be]),N.current&&N.current.start(1e3),_(!1),te.current&&(v=setTimeout(ye,2e3))}}catch(e){console.log("error ----------",e)}},[j,re,be,X,ye,te]);return t.useEffect(()=>(w&&(n(!0),pe()),()=>{b&&(a.swan.poseDetection.disconnect(),s.capture(`${w}/pose_detection_disconnected`,{scanID:o,email:g,id:b})),X.forEach(e=>{N?.current?.removeEventListener("dataavailable",e)})}),[V,w]),t.useEffect(()=>{K.push(z)},[z]),t.useEffect(()=>{O([])},[q]),t.useEffect(()=>{const e=F.length&&F.length>0;A||!e||T||!te.current||J||N&&N.current&&(T||(N.current.stop(),_(!0)))},[A,T,F,J]),t.useEffect(()=>{const e=F.length&&F.length>0;if(A||!e||T)console.log("No video found to upload");else if(N&&N.current&&te.current&&!J&&!T){const e=new File(F,`${o}.webm`,{type:"video/webm"});ue?.(!0),c(""),le?.(e)}},[A,T,F,J,N,te]),t.useEffect(()=>{if("undefined"!=typeof MediaRecorder){const e=a.videoTypes.filter(e=>MediaRecorder.isTypeSupported(e));oe(e)}},[]),t.useEffect(()=>{de()},[]),e.jsx(p,{resetDetector:r,handleShowStreamCamera:de,loadingCam:E,handlePause:he,showRestart:H,pause:J,handleReScan:fe,recordingStarted:T,isScanning:P,startSendingVideoFrames:Ce,faceDone:L,stopRecording:ge,showPause:Z,webcamRef:j,handleUserMedia:me,config:m})});function j({scanID:s,userDetails:a,setIsVideoUploaded:n,setScanFailsError:r,setScanStartTime:o,setScanUniqueKey:i,config:c}){const[l,u]=t.useState(90),[d,m]=t.useState(0),[f,h]=t.useState(null),[p,x]=t.useState(!1),[y,S]=t.useState(0),v=t.useRef([]),[b,C]=t.useState(!1),j=l-d,N=j>=80&&j<=95;t.useEffect(()=>{if("undefined"!=typeof window&&window.DeviceOrientationEvent){const e=e=>{if(null!==e.beta){let t=Math.abs(e.beta);null!==e.gamma&&(t*=Math.cos(e.gamma*Math.PI/180)),t=Math.max(0,Math.min(180,t)),u(t)}},t=async()=>{const t=DeviceOrientationEvent;if(t&&"function"==typeof t.requestPermission)try{"granted"===await t.requestPermission()&&window.addEventListener("deviceorientation",e)}catch(e){console.error("Permission error",e)}else window.addEventListener("deviceorientation",e);return()=>{e&&window.removeEventListener("deviceorientation",e)}};document.addEventListener("click",t,{once:!0})}},[]),t.useEffect(()=>{if(v.current=[...v.current.slice(-4),j],v.current.length>=5){const e=Math.max(...v.current)-Math.min(...v.current);S(N&&e<2?e=>Math.min(100,e+10):e=>Math.max(0,e-20))}N||null===f&&!p||k()},[j,N,f,p]),t.useEffect(()=>{y>=100&&null===f&&!p&&F(),y<50&&null!==f&&k()},[y,f,p]);const F=()=>{h(3);const e=setInterval(()=>{h(t=>null===t||t<=1?(clearInterval(e),x(!0),null):t-1)},1e3)},k=()=>{h(null),b||x(!1)};return e.jsx(g,{angle:j,countdown:f,isScanning:p,isInTargetRange:N,stabilityScore:y,config:c,children:p&&e.jsx(w,{setIsScanLocked:C,resetDetector:()=>{u(90),m(0),h(null),x(!1),S(0),C(!1),v.current=[]},scanID:s,userDetails:a,setIsVideoUploaded:n,setScanFailsError:r,setScanStartTime:o,setScanUniqueKey:i,config:c})})}function N({message:s,config:n}){const{translate:r}=t.useContext(a.LanguageContext)||{};return e.jsx(i.Dialog,{open:!0,className:"confirm-modal",children:e.jsx("div",{className:"modal-main",children:e.jsx("div",{className:"text-center",children:s?e.jsxs(e.Fragment,{children:[e.jsx("h2",{style:{fontFamily:n?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:n?.style?.heading?.headingFontSize||"32px",color:n?.style?.heading?.headingColor||"#000",fontWeight:n?.style?.heading?.headingFontWeight||"normal"},children:r?.(a.LanguageKeys.cameraAlreadyInUse)}),e.jsx("p",{className:"mt-[0.5rem] text-sm",style:{fontFamily:n?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:n?.style?.base?.baseFontSize||"16px",color:n?.style?.base?.baseTextColor||"#000"},children:r?.(a.LanguageKeys.tryClosingBrowser)})]}):e.jsxs(e.Fragment,{children:[e.jsx("h2",{style:{fontFamily:n?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:n?.style?.heading?.headingFontSize||"32px",color:n?.style?.heading?.headingColor||"#000",fontWeight:n?.style?.heading?.headingFontWeight||"normal"},children:r?.(a.LanguageKeys.checkCameraSettings)}),e.jsx("p",{className:"mt-[0.5rem] text-sm",style:{fontFamily:n?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:n?.style?.base?.baseFontSize||"16px",color:n?.style?.base?.baseTextColor||"#000"},children:`${r?.(a.LanguageKeys.setting)} > ${a.getBrowserName()} > ${r?.(a.LanguageKeys.enableCameraPermissions)}`})]})})})})}function F({setShowDrawer:s,config:n,loader:o}){const[i,c]=t.useState({disabled:!1,message:""}),[l,u]=t.useState(!0),d=t.useRef(null),m=t.useCallback(async()=>{const e=await a.checkCameraPermission();c(e),u(!1)},[]);return t.useEffect(()=>{m()},[]),l?e.jsx(a.LoadingScreen,{url:o,loaderType:"black"}):i?.disabled?e.jsx(N,{config:n,message:i?.message}):e.jsx(r,{audio:!1,ref:d,screenshotQuality:1,videoConstraints:a.videoConstraints,mirrored:!0,onUserMedia:()=>s?.(!0),screenshotFormat:"image/jpeg",style:{position:"relative",top:0,bottom:0,zIndex:0,width:"100%",height:"100%",objectFit:"cover"}})}function k({link:s,onReady:n,wrapperClassName:r="[&_video]:rounded-t-[20px] w-full h-full"}){const o=t.useRef(null),i=t.useRef(null);let l={autoplay:!0,controls:!1,responsive:!0,fluid:!0,muted:!0,navigationUI:"hide",preload:"metadata",poster:a.videoPoster};return t.useEffect(()=>{if(!i.current&&s&&o?.current){const e=c(o.current,{...l});e.ready(()=>{i.current=e;const t={...l,sources:[{src:s,type:"application/x-mpegURL"}]};e.autoplay(t.autoplay),e.src(t.sources),n?.(e)})}},[s,o]),t.useEffect(()=>{const e=i.current;return()=>{e&&!e.isDisposed()&&(e.dispose(),i.current=null)}},[i]),e.jsx("div",{className:r,children:e.jsx("video",{ref:o,muted:!0,className:"video-js",playsInline:!0,onDrag:e=>e.preventDefault()})})}function E({scanFailsError:s,serverAtCapacity:n=!1,onNext:r,gender:c,setScanUniqueKey:l,resolvedConfig:u,setIsVideoUploaded:d}){const{translate:m}=t.useContext(a.LanguageContext)||{},[f,h]=t.useState(!1),g=()=>{h(!f)};return e.jsxs(e.Fragment,{children:[e.jsxs("div",{className:"flex flex-col h-full max-w-[28rem] mx-auto w-full rounded-t-[20px] overflow-y-auto",style:{background:u?.style?.base?.backgroundColor},children:[e.jsx("div",{className:"w-full max-w-[28rem] mx-auto pt-[1rem] px-[1rem]",children:e.jsx(a.Header,{noTitle:!0,resolvedConfig:u})}),e.jsxs("div",{className:"flex-1",children:[s&&e.jsxs("div",{className:"px-[1rem]",children:[e.jsx("h2",{className:"text-center",style:{fontFamily:u?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:u?.style?.heading?.headingFontSize||"32px",color:u?.style?.heading?.headingColor||"#000",fontWeight:u?.style?.heading?.headingFontWeight||"normal"},children:m?.(a.LanguageKeys.issueWithScan)}),e.jsx("p",{style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:u?.style?.base?.baseFontSize||"16px",color:u?.style?.base?.baseTextColor||"#1E1E1E"},children:m?.(a.LanguageKeys.reason)}),e.jsx("p",{style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:u?.style?.base?.baseFontSize||"16px",color:u?.style?.base?.baseTextColor||"#1E1E1E"},children:a.handleErrorMessage(s)}),e.jsx("img",{className:"my-[0.5rem] aspect-[2/1.4] w-full object-cover",onClick:g,src:a.VIDEO_POSTER_GENDER_BASED[c],alt:"icon"})]}),n&&e.jsxs("div",{className:"p-[1rem] text-center",children:[e.jsx("h3",{style:{fontFamily:u?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:u?.style?.heading?.headingFontSize||"32px",color:u?.style?.heading?.headingColor||"#000",fontWeight:u?.style?.heading?.headingFontWeight||"normal"},children:m?.(a.LanguageKeys.serverAtCapacity)}),e.jsx("p",{className:"text-base mt-[0.5rem]",style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:u?.style?.base?.baseFontSize||"16px",color:u?.style?.base?.baseTextColor||"#1E1E1E"},children:m?.(a.LanguageKeys.serverAtCapacityDescription)})]})]}),s&&e.jsx("div",{className:"p-[1rem] flex gap-[0.5rem]",children:e.jsx(a.SpecificButton,{disabled:!1,buttonText:m?.(a.LanguageKeys.scanAgain),className:"!shadow-none",buttonFunc:()=>{r?r?.():l(a.generateUuid()),d(!1)},resolvedConfig:u})})]}),f&&e.jsxs(i.Dialog,{className:"w-screen h-screen video-modal",onClose:g,open:f,children:[e.jsx("div",{className:"flex justifyEnd ",children:e.jsx("span",{className:"closeBtn",onClick:g,children:e.jsx(o.X,{className:"absolute right-[8px] top-[8px] text-white z-[9]"})})}),e.jsx("div",{className:"aspect-video object-cover rounded-[20px] ",children:e.jsx(k,{link:c?a.GENDER[c].PRE_LINK:a.GENDER.male.PRE_LINK,wrapperClassName:"w-screen h-screen fixed top-[0] left-[0]"})})]})]})}function D({scanId:n,userDetails:r,config:o,isFaceScan:c,isVideoUploadedCorrect:l,isMeasurementAvailable:u,onScanSuccess:d,isSuccess:m}){const{gender:f,shopDomain:h,heightInCm:g,deviceFocalLength:p,userName:x,email:y,scanType:S}=r,v=[a.CLOTHING_CUSTOM_SCAN,a.CLOTHING_BANNER_SCAN,a.CLOTHING_CUSTOM_FIT_SCAN].includes(S),[b,C]=t.useState(!0),w=t.useCallback(async()=>{try{v&&await a.swan.auth.addUser({scanId:n,email:y,name:x,gender:f,height:g}),s.posthog.capture(h,{scanID:n,email:y,height:g,focalLength:p,clothesFit:"0",gender:f})}catch(e){console.log(e)}},[v]),{translate:j}=t.useContext(a.LanguageContext)||{};t.useEffect(()=>{l&&w()},[l]);const N=m||(c?u&&l:l||u);return e.jsx(i.Box,{className:"flex h-full w-full flex-col ",children:e.jsxs("div",{className:"h-full w-full flex-col items-center justify-center flex",children:[e.jsx(F,{loader:o?.loader,setShowDrawer:C}),e.jsx(i.Drawer,{open:b,onClose:(e,t)=>{},className:"camera-drawer",anchor:"bottom",children:e.jsx("div",{className:"max-w-[28rem] mx-auto w-full h-full flex text-center flex-col justify-between items-center bg-primary rounded-t-[30px] p-[1rem]",style:{background:o?.style?.base?.backgroundColor},children:e.jsxs("div",{className:"w-full h-full flex flex-col",children:[e.jsx(a.Header,{title:j?.(a.LanguageKeys.measurementsBeingTaken),resolvedConfig:o}),e.jsx("div",{className:"flex items-center justify-center flex-1",children:e.jsx("video",{preload:"auto",className:"max-h-[calc(100vh-450px)] mx-auto w-full object-contain border-none",muted:!0,loop:!0,autoPlay:!0,playsInline:!0,children:e.jsx("source",{src:f===a.GenderType.Male?a.maleMeasurementProgress:a.measurementProgress,type:"video/mp4"})})}),N&&e.jsx(a.SpecificButton,{resolvedConfig:o,className:"!w-[180px] mx-auto",buttonText:j?.(a.LanguageKeys.next),buttonFunc:d&&d})]})})})]})})}const T=()=>{const{userDetails:s,config:n,onRetry:r,isError:o,isSuccess:c,onScanSuccess:l,gender:u,scanUniqueKey:d,scanFailsError:m,setScanUniqueKey:f,setIsVideoUploaded:h,isMeasurementAvailable:g,isVideoUploadedCorrect:p,loading:x,showDeniedModal:y,uploadLoading:S,setStartGyro:v,handleFileUpload:b,setUploadLoading:C,setScanFailsError:w,setScanStartTime:k,handleShowStreamCamera:T}=t.useContext(a.ParamsContext),{setPreferredLanguage:I}=t.useContext(a.LanguageContext)||{},L=a.useLocalConfig(n);return t.useEffect(()=>{I?.(L?.language)},[L]),o?e.jsxs(e.Fragment,{children:[e.jsx(F,{}),e.jsx(i.Drawer,{anchor:"bottom",open:!0,className:"camera-drawer",onClose:(e,t)=>{},children:e.jsx(E,{scanFailsError:m||o,onNext:()=>{},setScanUniqueKey:f,gender:u,resolvedConfig:L,setIsVideoUploaded:h})})]}):c?e.jsx(D,{isFaceScan:!1,scanId:d,isMeasurementAvailable:g,userDetails:s,isVideoUploadedCorrect:p,config:L,isSuccess:c}):x?e.jsx("div",{className:"flex top-0 !mt-0 left-0 z-[999] absolute justify-center items-center w-full h-full",style:{background:L?.style?.base?.backgroundColor},children:e.jsx(a.LoadingScreen,{url:L?.loader,loaderType:"black"})}):y.disabled?e.jsx(N,{}):S||m?!S&&!g||m?e.jsxs(e.Fragment,{children:[e.jsx(F,{}),e.jsx(i.Drawer,{anchor:"bottom",open:!0,className:"camera-drawer",onClose:(e,t)=>{},children:e.jsx(E,{scanFailsError:m,onNext:()=>{r?.(),T()},setScanUniqueKey:f,gender:u,resolvedConfig:L,setIsVideoUploaded:h})})]}):e.jsx(D,{isFaceScan:!1,scanId:d,isMeasurementAvailable:g,userDetails:s,onScanSuccess:l,isVideoUploadedCorrect:p,config:L}):e.jsx(j,{config:L,scanID:d,userDetails:s,setIsVideoUploaded:h,setScanFailsError:w,setScanStartTime:k,setScanUniqueKey:f})};exports.BodyScan=({userDetails:n,config:r,onRetry:o,onScanError:i,isError:c,isSuccess:l,onScanSuccess:u})=>{const{gender:d,scanType:m,shopDomain:h,heightInCm:g,email:p,deviceFocalLength:x,deviceModelName:y,callbackUrl:S}=n,[v,b]=t.useState(!1),[C,w]=t.useState(!1),[j,N]=t.useState(!1),[F,k]=t.useState({disabled:!1,message:""}),[E,D]=t.useState(""),[I,L]=t.useState(!1),[M,A]=t.useState(!0),[_,P]=t.useState(!1),[U,$]=t.useState(""),[z,R]=t.useState(a.getCurrentTimeInSeconds()),{gyroData:K}=function(e){const[s,a]=t.useState([]),[n,r]=t.useState(!1),o=t.useCallback(e=>{try{const{alpha:t,beta:s,gamma:n}=e;a(e=>[...e,{alpha:t?.toString()||void 0,beta:s?.toString()||void 0,gamma:n?.toString()||void 0,timestamp:(new Date).toISOString()}])}catch(e){console.log(e)}},[]),i=t.useCallback(async()=>{const e=DeviceOrientationEvent;if(void 0!==e&&"function"==typeof e.requestPermission)try{"granted"===await e.requestPermission()?r(!0):console.warn("Device orientation permission denied.")}catch(e){console.error("Error requesting device orientation permission:",e)}else r(!0)},[]);return t.useEffect(()=>(e&&n?window.addEventListener("deviceorientation",o):a([]),()=>{window.removeEventListener("deviceorientation",o)}),[e,n,o]),t.useEffect(()=>{e&&i()},[e,i]),{gyroData:s}}(_),O=t.useCallback(()=>{$(a.generateUuid()),D(""),b(!1),L(!1)},[]),q=e=>{i({...e,message:a.handleErrorMessage(e)}),B(),N(!1),D(e),w(!1),a.handleScanTimeCapture({eventName:`${h}/measurement_failed/fit-view`,scanID:U,status:"failed",email:p,message:a.handleErrorMessage(e)}),z&&a.handleScanTimeCapture({eventName:`${h}/scan_completion_time`,scanID:U,status:"failed",completionTime:a.getCurrentTimeInSeconds()-z,email:p})},B=()=>{R(null),$("")},V=t.useCallback(async e=>{if(e&&"success"===e?.scanStatus&&"intermediate"===e?.resultType&&200===e?.code)return void a.handleScanTimeCapture({eventName:`${h}/measurement_success/intermediate`,scanID:U,status:"success",email:p});B();const t=U;N(!0),a.handleScanTimeCapture({eventName:`${h}/measurement_success/fit-view`,scanID:t,status:"success",email:p}),z&&a.handleScanTimeCapture({eventName:`${h}/scan_completion_time`,scanID:t,status:"success",completionTime:a.getCurrentTimeInSeconds()-z,email:p})},[m,h,U]),W=e=>{N(!1),D(""),w(!1),a.swan.measurement.handleMeasurementSocket({scanId:e||U,onOpen:()=>{a.handleWebSocketCapture({eventName:`${h}/webSocket`,scanID:U,connection:"open",type:"measurement_recommendation",email:p})},onClose:()=>a.handleWebSocketCapture({eventName:`${h}/webSocket`,scanID:U,connection:"close",type:"measurement_recommendation",email:p}),onError:e=>{q(e),a.handleWebSocketCapture({eventName:`${h}/webSocket`,scanID:U,connection:"error",type:"measurement_recommendation",email:p})},onSuccess:e=>{a.handleWebSocketCapture({eventName:`${h}/webSocket`,scanID:U,connection:"success",type:"measurement_recommendation",email:p}),V(e)}})},H=t.useCallback(async e=>{const t=a.createObjectMetadataArray({gender:d,focal_length:`${x}`,height:`${g}`,customer_store_url:h,clothes_fit:"0",scan_type:m,callback_url:S||"https://example.com/webhook"});a.handleScanTimeCapture({eventName:`${h}/body_scan_meta_data`,scanID:U,email:p,data:JSON.stringify(t)});try{await a.swan.fileUpload.uploadFileFrontend({file:e,arrayMetaData:t,scanId:U,email:p}),await a.swan.fileUpload.setDeviceInfo({model:y,detection:"manual",gyro:K,scanId:U}),console.log("video successfully uploaded"),L(!1),a.handleScanTimeCapture({eventName:`${h}/scan_success`,scanID:U,status:"success",email:p,data:JSON.stringify(t)}),a.handleScanTimeCapture({eventName:"scan finished",scanID:U,status:"success",email:p}),R(a.getCurrentTimeInSeconds()),setTimeout(()=>{L(!0)},3e3)}catch(e){a.handleScanTimeCapture({eventName:"scan finished",scanID:U,status:"failed",email:p,message:a.handleErrorMessage(e)}),a.handleScanTimeCapture({eventName:`${h}/scan_failed`,scanID:U,status:"failed",email:p,message:a.handleErrorMessage(e),data:JSON.stringify(t)}),D(a.handleErrorMessage(e)),L(!1),console.log(e,"video upload failed")}finally{P(!1)}},[U,K]),G=t.useCallback(async e=>{try{const t=await a.swan.measurement.getMeasurementResult(e),s=t?.data?.isMeasured,n=z||a.getCurrentTimeInSeconds(),r=a.getCurrentTimeInSeconds(),o=300;if(A(!1),!1===s)return B(),void $(a.generateUuid());b(!0),!0===s?await V(null):null===s&&n>r+o?q(t?.data?.error):W(e)}catch(e){console.log(e),B(),$(a.generateUuid()),b(!1)}},[q,V,$]),J=t.useCallback(async()=>{if(+g<152.4||+g>213.36)return void i({message:"Height must be between 152.4cm (5ft) and 213.36cm (7ft)"});const e=await a.checkCameraPermission();if(e.disabled)a.handleScanTimeCapture({eventName:`${h}/camera_activation`,scanID:U,status:"failed",email:p}),A(!1);else{U?G(U):A(!1),a.handleScanTimeCapture({eventName:`${h}/camera_activation`,scanID:U,status:"success",email:p})}k(e),D(""),L(!1)},[G,p,U,$,h]);return t.useEffect(()=>{s.init(a.posthogPublicKey,{api_host:a.posthogPublicHost}),s.capture("$pageview")},[]),t.useEffect(()=>{c||l||h&&J()},[h,g,c,l]),t.useEffect(()=>{c||l||I&&h&&U&&W()},[I,h,U,c,l]),e.jsx(a.LanguageContextProvider,{children:e.jsx(f,{children:e.jsx(a.ParamsContext.Provider,{value:{userDetails:n,config:r,onRetry:o,onScanError:i,isError:c,isSuccess:l,onScanSuccess:u,gender:d,scanUniqueKey:U,scanFailsError:E,setScanUniqueKey:$,setIsVideoUploaded:L,isMeasurementAvailable:j,isVideoUploadedCorrect:C,loading:M,showDeniedModal:F,uploadLoading:v,setStartGyro:P,handleFileUpload:H,setUploadLoading:b,handleShowStreamCamera:O,setScanFailsError:D,setScanStartTime:R},children:e.jsx(T,{})})})})};
2
+ //# sourceMappingURL=BodyScan-BJqddH9l.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BodyScan-BJqddH9l.js","sources":["../src/utils/context/mediaContext.tsx","../src/Icons/SwitchIcon.tsx","../src/components/bodyScan/LevelScreen.tsx","../src/components/bodyScan/CameraScanChild.tsx","../src/customHooks/useTensorFlow.ts","../src/components/bodyScan/ScanningComponent.tsx","../src/components/bodyScan/AngleDetector.tsx","../src/components/Modal.tsx","../src/components/bodyScan/CameraPermission.tsx","../src/components/bodyScan/VideoPlayer.tsx","../src/components/bodyScan/ScanErrorMessage.tsx","../src/components/Signup.tsx","../src/components/bodyScan/BodyScanSteps.tsx","../src/components/bodyScan/BodyScan.tsx","../src/customHooks/useGyroSensor.ts"],"sourcesContent":["\"use client\"\nimport React, {\n createContext,\n Dispatch,\n ReactNode,\n SetStateAction,\n useEffect,\n useLayoutEffect,\n useMemo,\n useState,\n} from \"react\";\n\nexport const MEDIA_TYPES = {\n DESKTOP: \"DESKTOP\",\n TAB: \"TAB\",\n MOBILE: \"MOBILE\",\n};\n\ninterface MediaContextType {\n size: number[];\n setSize: Dispatch<SetStateAction<number[]>>;\n clearInputs: boolean;\n setClearInputs: Dispatch<SetStateAction<boolean>>;\n media: string;\n}\n\nexport const MediaContext = createContext<MediaContextType | undefined>(\n undefined\n);\n\nfunction MediaContextProvider({ children }: { children: ReactNode }) {\n const [size, setSize] = useState([window?.innerWidth, window?.innerHeight]);\n const [clearInputs, setClearInputs] = useState(false);\n\n const updateSize = () => {\n setSize([window?.innerWidth, window?.innerHeight]);\n };\n useEffect(() => {\n updateSize();\n }, []);\n useLayoutEffect(() => {\n window.addEventListener(\"resize\", updateSize);\n return () => window.removeEventListener(\"resize\", updateSize);\n }, [updateSize]);\n let media = MEDIA_TYPES.DESKTOP;\n if (size[0] > 768 && size[0] < 1024) {\n media = MEDIA_TYPES.TAB;\n }\n if (size[0] < 768) {\n media = MEDIA_TYPES.MOBILE;\n }\n\n const mediaDetails = useMemo(\n () => ({\n size,\n setSize,\n clearInputs,\n setClearInputs,\n media,\n }),\n [size, clearInputs, media]\n );\n\n return (\n <MediaContext.Provider value={mediaDetails}>\n {children}\n </MediaContext.Provider>\n );\n}\n\nexport default MediaContextProvider;\n","import React from \"react\";\n\nfunction SwitchIcon({ size = 16 }: { size?: number }) {\n return (\n <svg\n width={size}\n height={size}\n viewBox=\"0 0 25 25\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M22.6968 14.6968C22.6968 16.8185 21.8539 18.8533 20.3536 20.3536C18.8533 21.8539 16.8185 22.6968 14.6968 22.6968\"\n stroke=\"white\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M18.6968 11.6968V10.6968C18.6968 10.1663 18.4861 9.65764 18.111 9.28256C17.7359 8.90749 17.2272 8.69678 16.6968 8.69678C16.1663 8.69678 15.6576 8.90749 15.2826 9.28256C14.9075 9.65764 14.6968 10.1663 14.6968 10.6968\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M14.6968 10.6968V9.69678C14.6968 9.16634 14.4861 8.65764 14.111 8.28256C13.7359 7.90749 13.2272 7.69678 12.6968 7.69678C12.1663 7.69678 11.6576 7.90749 11.2826 8.28256C10.9075 8.65764 10.6968 9.16634 10.6968 9.69678V10.6968\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M10.6968 10.1968V4.69678C10.6968 4.16634 10.4861 3.65764 10.111 3.28256C9.73592 2.90749 9.22721 2.69678 8.69678 2.69678C8.16634 2.69678 7.65764 2.90749 7.28256 3.28256C6.90749 3.65764 6.69678 4.16634 6.69678 4.69678V14.6968\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n <path\n d=\"M18.6969 11.6968C18.6969 11.1663 18.9076 10.6576 19.2827 10.2826C19.6577 9.90749 20.1664 9.69678 20.6969 9.69678C21.2273 9.69678 21.736 9.90749 22.1111 10.2826C22.4862 10.6576 22.6969 11.1663 22.6969 11.6968V14.6968C22.6969 16.8185 21.854 18.8533 20.3537 20.3536C18.8534 21.8539 16.8186 22.6968 14.6969 22.6968H12.6969C9.89688 22.6968 8.19688 21.8368 6.70688 20.3568L3.10688 16.7568C2.76282 16.3757 2.57847 15.8769 2.592 15.3637C2.60554 14.8505 2.81593 14.3621 3.1796 13.9997C3.54327 13.6373 4.03238 13.4287 4.54565 13.417C5.05892 13.4053 5.55704 13.5914 5.93688 13.9368L7.69688 15.6968\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n );\n}\n\nexport default React.memo(SwitchIcon);\n","/* eslint-disable no-nested-ternary */\n\nimport React, { useCallback, useContext, useMemo } from \"react\";\nimport Header from \"../Header\";\nimport cn from \"clsx\";\nimport { LevelScreenProps } from \"../../types/interfaces\";\nimport SwitchIcon from \"../../Icons/SwitchIcon\";\nimport { LanguageContext } from \"../../utils/context/languageContext\";\nimport { LanguageKeys } from \"../../utils/languageKeys\";\n\nfunction LevelScreen({ angle, countdown, isScanning, isInTargetRange, stabilityScore, children, config }: LevelScreenProps) {\n\tconst { translate } = useContext(LanguageContext) || {};\n\n\tconst getProximityToTarget = useCallback(() => {\n\t\tif (angle < 80) return Math.max(0, Math.min(100, (angle - 60) * 10));\n\t\tif (angle > 95) return Math.max(0, Math.min(100, (105 - angle) * 10));\n\t\treturn 100;\n\t}, [angle]);\n\n\tconst backgroundColor = useMemo(() => {\n\t\tif (isScanning) return config?.style?.angleDetector?.successAngleBackground || \"#4f46e5\";\n\n\t\tconst proximity = getProximityToTarget();\n\t\tif (proximity === 0) return config?.style?.angleDetector?.successAngleLowBackground || \"#ffffff\";\n\t\tif (proximity === 100) return config?.style?.angleDetector?.successAngleBackground || \"#4f46e5\";\n\n const r = Math.round(255 - (255 - 139) * (proximity / 100));\n const g = Math.round(255 - (255 - 92) * (proximity / 100));\n const b = Math.round(255 - (255 - 246) * (proximity / 100));\n return `rgb(${r}, ${g}, ${b})`;\n }, [isScanning, getProximityToTarget]);\n\n\tconst handelTextColour = useCallback((isLight: boolean, proximity: number) => {\n\t\tif (proximity > 70) {\n\t\t\treturn isLight ? `text-[${config?.style?.angleDetector?.successAngleTextLightColor}]/70` : `text-[${config?.style?.angleDetector?.successAngleTextLightColor}]`;\n\t\t}\n\t\treturn isLight ? `text-[${config?.style?.angleDetector?.successAngleTextLightColor}]/40` : `text-[${config?.style?.angleDetector?.successAngleTextDarkColor}]/70`;\n\t}, []);\n\n\tconst getTextColor = useCallback(\n\t\t(isLight = false) => {\n\t\t\tconst proximity = getProximityToTarget();\n\t\t\tif (isScanning) return `text-[${config?.style?.angleDetector?.successAngleTextLightColor}]`;\n\t\t\treturn handelTextColour(isLight, proximity);\n\t\t},\n\t\t[isScanning, getProximityToTarget],\n\t);\n\n\tconst handelColourCode = useCallback((isLight: boolean, proximity: number) => {\n\t\tif (proximity > 70) {\n\t\t\treturn isLight ? config?.style?.angleDetector?.successAngleTextLightColor : config?.style?.angleDetector?.successAngleTextLightColor;\n\t\t}\n\t\treturn isLight ? config?.style?.angleDetector?.successAngleTextLightColor : config?.style?.angleDetector?.successAngleTextDarkColor;\n\t}, []);\n\tconst getColorCode = useCallback(\n\t\t(isLight = false) => {\n\t\t\tconst proximity = getProximityToTarget();\n\t\t\tif (isScanning) return config?.style?.angleDetector?.successAngleTextLightColor;\n\t\t\treturn handelColourCode(isLight, proximity);\n\t\t},\n\t\t[isScanning, getProximityToTarget],\n\t);\n\tconst cd = countdown;\n\tfunction fixVh() {\n\t\tdocument.documentElement.style.setProperty(\"--real-vh\", window.innerHeight + \"px\");\n\t}\n\tfixVh();\n\twindow.addEventListener(\"resize\", fixVh);\n\treturn (\n\t\t<div\n\t\t\tclassName=\"flex w-screen flex-col items-center h-[var(--real-vh)] overflow-hidden touch-none justify-center transition-all duration-300 max-w-[28rem] mx-auto\"\n\t\t\tstyle={{ backgroundColor }}\n\t\t\t// onDoubleClick={onDoubleClick}\n\t\t>\n\t\t\t<div className=\"flex justify-start fixed top-[.5rem] max-w-[28rem] mx-auto w-full px-[1rem]\">\n\t\t\t\t<div className=\"flex justify-start \">\n\t\t\t\t\t<Header noTitle resolvedConfig={config} />\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t{cd !== null ? (\n\t\t\t\t<div\n\t\t\t\t\tclassName=\"relative flex h-[6rem] w-[6rem] items-center justify-center rounded-[9999px] bg-[#fff]/20 transition-all duration-300\"\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\tborder: `2px solid ${getColorCode()}`,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={`text-[3rem] font-bold text-[${getColorCode()}]`}\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tfontFamily: config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n color: getColorCode(),\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t{cd}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t) : isScanning ? (\n\t\t\t\t<div className=\"relative flex flex-col items-center justify-center\">\n\t\t\t\t\t<div className=\"relative flex h-16 w-16 items-center justify-center rounded-[9999px] border-2 bg-[#fff]/30 border-[#fff]\">\n\t\t\t\t\t\t<div className=\"h-4 w-4 rounded-[9999px] animate-pulse bg-[#fff]/80\" />\n\t\t\t\t\t</div>\n\t\t\t\t\t{children}\n\t\t\t\t</div>\n\t\t\t) : (\n\t\t\t\t<div\n\t\t\t\t\tclassName={cn(\"relative flex h-[4rem] w-[4rem] items-center justify-center rounded-[9999px] \", isInTargetRange ? \"bg-[#fff]/20 border-[#fff]\" : \"bg-[#fff]/10 border-[#fff]\")}\n\t\t\t\t\tstyle={{\n\t\t\t\t\t\ttransform: `translateY(${(90 - angle) * 3}px)`,\n\t\t\t\t\t\ttransition: \"transform 0.2s ease-out\",\n\t\t\t\t\t\tborder: `2px solid ${getColorCode()}`,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<div className={`h-[1rem] w-[1rem] rounded-[9999px] bg-[${getColorCode()}]/80`}\n style={{\n\t\t\t\t\t\tbackgroundColor: `${getColorCode()}B3`,\n\t\t\t\t\t}}\n />\n\t\t\t\t\t<div\n\t\t\t\t\t\t// className=\" text-[#fff]\"\n\t\t\t\t\t\tclassName={cn(\"mt-[.5rem] text-center w-[180px] flex-col flex items-center absolute top-[60px]\", getTextColor())}\n style={{\n\t\t\t\t\t\tcolor: getColorCode(),\n\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t<SwitchIcon size={30} />\n\t\t\t\t\t\t<p\n\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\tfontFamily: config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{\" \"}\n\t\t\t\t\t\t\t{translate?.(LanguageKeys.startLevelCheck)}\n\t\t\t\t\t\t\t<br />\n\t\t\t\t\t\t</p>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{cd !== null && (\n\t\t\t\t<div className=\"absolute bottom-[8rem] text-center\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\"text-sm font-medium px-4 py-1.5 bg-black/20 rounded-[9999px] mt-8\", getTextColor())}\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tfontFamily: config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n color: getColorCode(),\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t{translate?.(LanguageKeys.leavePhone)}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t\t{isInTargetRange && cd === null && !isScanning && (\n\t\t\t\t<div className=\"absolute bottom-[8rem] w-[12rem]\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={`h-[.375rem] w-full bg-[${getColorCode()}]/20 rounded-[9999px] overflow-hidden`}\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tbackgroundColor: `${getColorCode()}33`, // 20% opacity\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={`h-full bg-[${getColorCode()}]/70 transition-all duration-300 rounded-[9999px]`}\n\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\twidth: `${angle}%`,\n\t\t\t\t\t\t\t\tbackgroundColor: `${getColorCode()}B3`,\n\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t)}\n\n {cd === null && !isScanning && (\n <div className=\"absolute bottom-[5rem] text-center\">\n <div className={cn(\"text-[1.5rem] font-light\", getTextColor())}\n style={{\n\t\t\t\t\t\tcolor: getColorCode(),\n\t\t\t\t\t}}\n >\n {Math.round(angle)}°\n </div>\n </div>\n )}\n\n\t\t\t{cd === null && !isScanning && (\n\t\t\t\t<div className=\"absolute bottom-[2rem] text-center max-w-[20rem] mx-auto\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={cn(\"text-[.75rem] opacity-50\", getTextColor())}\n\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\tfontFamily: config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n color: getColorCode(),\n\t\t\t\t\t\t}}\n\t\t\t\t\t>\n\t\t\t\t\t\t{translate?.(LanguageKeys.placePhoneUpright)}\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n}\nexport default React.memo(LevelScreen);\n","import { useContext } from \"react\";\nimport Webcam from \"react-webcam\";\nimport { CameraScanChildProps } from \"../../types/interfaces\";\nimport { MEDIA_TYPES, MediaContext } from \"../../utils/context/mediaContext\";\nimport { LanguageContext } from \"../../utils/context/languageContext\";\nimport { pauseIcon, videoConstraints, voiceOverAssetsPath } from \"../../utils/constants\";\nimport SpecificButton from \"../../atoms/specificButton/SpecificButton\";\nimport { LanguageKeys } from \"../../utils/languageKeys\";\nimport { X } from \"lucide-react\";\n\n\n\nfunction CameraScanChild({\n handleShowStreamCamera,\n loadingCam,\n handleUserMedia,\n handlePause,\n pause,\n recordingStarted,\n startSendingVideoFrames,\n showPause,\n webcamRef,\n resetDetector,\n config,\n}: CameraScanChildProps) {\n const { media } = useContext(MediaContext) || {};\n const { translate } = useContext(LanguageContext) || {};\n\n return (\n <div className=\"App w-screen h-[100vh] relative \">\n <span\n onClick={() => {\n handleShowStreamCamera();\n resetDetector();\n }}\n className=\"fixed right-[20px] top-[20px] z-[999]\"\n >\n <X className=\"text-[#fff]\" />\n </span>\n\n <div className=\"w-full h-full overflow-hidden \">\n {media === MEDIA_TYPES.MOBILE && (\n <Webcam\n audio={false}\n ref={webcamRef}\n screenshotQuality={1}\n videoConstraints={videoConstraints}\n mirrored\n screenshotFormat=\"image/jpeg\"\n onUserMedia={handleUserMedia}\n style={{\n position: \"fixed\",\n top: 0,\n bottom: 0,\n zIndex: 0,\n width: \"100%\",\n height: \"100%\",\n objectFit: \"cover\",\n }}\n />\n )}\n </div>\n\n <div className=\"fixed bottom-[30px] w-full z-[999] flex flex-col gap-4 items-center justify-center\">\n {showPause && (\n <SpecificButton\n className=\"!w-[180px] !h-[40px] !py-[0] mx-auto \"\n prefix={pauseIcon}\n buttonText={translate?.(LanguageKeys.pause)}\n buttonFunc={handlePause}\n resolvedConfig={config}\n btnSecondary\n />\n )}\n\n {pause ? (\n <div>\n <SpecificButton\n className=\"!w-[180px] !h-[40px] !py-[0] mx-auto\"\n buttonText={translate?.(LanguageKeys.restart)}\n buttonFunc={handleShowStreamCamera}\n resolvedConfig={config}\n btnSecondary\n />\n </div>\n ) : !recordingStarted ? (\n <SpecificButton\n className={`!w-[180px] !h-[40px] !py-[0] mx-auto !bg-[#ffffff] !text-[#000000] ${\n loadingCam ? \"!opacity-50\" : \"\"\n }`}\n buttonText={translate?.(LanguageKeys.startScan)}\n buttonFunc={startSendingVideoFrames}\n disabled={loadingCam}\n resolvedConfig={config}\n />\n ) : null}\n </div>\n\n <audio\n id=\"audioElement\"\n crossOrigin=\"anonymous\"\n preload=\"auto\"\n style={{\n position: \"absolute\",\n zIndex: -99999,\n }}\n src={`${voiceOverAssetsPath}scanAudioInstructions/silence.mp3`}\n />\n </div>\n );\n}\n\nexport default CameraScanChild;\n","import { useState, useRef, useEffect } from \"react\";\n// We keep this, but we will make it optional in the logic below\n\ntype KeypointTuple = [number, number, number];\n\n// GLOBAL SINGLETONS (Persist across component re-mounts)\n// This prevents reloading the heavy model if the user navigates away and back.\nlet globalLoadingPromise: Promise<boolean> | null = null;\nlet globalDetector: any = null;\nlet globalPoseLib: any = null;\n\nexport default function useTensorFlow() {\n const [consecutiveFronts, setConsecutiveFronts] = useState(0);\n const [spinPhase, setSpinPhase] = useState(0);\n const [isLoaded, setIsLoaded] = useState(false);\n\n const spinPhaseRef = useRef(0);\n const consecutiveFrontsRef = useRef(0);\n const mounted = useRef(true);\n\n useEffect(() => {\n mounted.current = true; // Reset on mount\n\n // 1. If already loaded globally, just use it.\n if (globalDetector) {\n setIsLoaded(true);\n return;\n }\n\n // 2. If not loading, start the process.\n if (!globalLoadingPromise) {\n globalLoadingPromise = loadDependenciesGlobal();\n }\n\n // 3. Wait for the global promise to resolve.\n globalLoadingPromise.then((success) => {\n if (success && mounted.current) {\n setIsLoaded(true);\n }\n });\n\n return () => {\n mounted.current = false;\n };\n }, []);\n\n /**\n * Loads TensorFlow/MediaPipe dynamically.\n * This logic is ISOLATED from the server.\n */\n async function loadDependenciesGlobal(): Promise<boolean> {\n // GUARDRAIL 1: Strict Environment Check\n // Ensure we are in a browser environment with media capabilities\n if (\n typeof window === 'undefined' || \n typeof navigator === 'undefined'\n ) {\n return false;\n }\n \n try {\n console.log(\"Starting TensorFlow preload...\");\n \n // GUARDRAIL 2: Dynamic Imports\n // These heavy modules are only fetched by the browser, never the server.\n const [poseLib, tfjsCore, tfjsBackend] = await Promise.all([\n import(\"@tensorflow-models/pose-detection\"),\n import(\"@tensorflow/tfjs-core\"),\n import(\"@tensorflow/tfjs-backend-webgl\") // Triggers backend registration side-effect\n ]);\n \n globalPoseLib = poseLib;\n \n // Explicitly set the backend to WebGL for performance\n await tfjsCore.setBackend('webgl');\n await tfjsCore.ready();\n console.log(\"TensorFlow backend ready (WebGL)\");\n\n // GUARDRAIL 3: Zero-Config Asset Loading\n // If TENSORFLOW_SOLUTION_PATH fails or is missing, we must fallback \n // to a CDN so the user doesn't have to copy files manually.\n const modelConfig = {\n runtime: \"mediapipe\",\n modelType: \"full\",\n solutionPath:\"https://cdn.jsdelivr.net/npm/@mediapipe/pose\", // Fallback for Zero Config\n } as const;\n\n try {\n globalDetector = await globalPoseLib.createDetector(\n globalPoseLib.SupportedModels.BlazePose,\n modelConfig\n );\n console.log(\"MediaPipe detector created successfully\");\n } catch (mediapipeError) {\n console.warn(\"MediaPipe failed, falling back to TFJS runtime:\", mediapipeError);\n \n // Fallback to TFJS runtime (slower but works without external assets)\n globalDetector = await globalPoseLib.createDetector(\n globalPoseLib.SupportedModels.BlazePose,\n {\n runtime: \"tfjs\",\n modelType: \"full\",\n }\n );\n console.log(\"TFJS detector created successfully\");\n }\n \n return true;\n } catch (error) {\n console.error(\"Failed to load TensorFlow dependencies:\", error);\n globalLoadingPromise = null; // Reset so retry is possible\n return false;\n }\n }\n\n function isFrontFrame(body: KeypointTuple[]) {\n // Guardrail: Ensure points exist before filtering\n if (!body || body.length === 0) return false;\n return body.filter((p) => p[2] > 0.7).length === 22;\n }\n\n const poseDetector = async (callback: () => void, webcamRef: any) => {\n // GUARDRAIL 4: Runtime Safety\n // Check if everything is truly ready before calculating\n if (!globalDetector || !mounted.current || !webcamRef?.current?.video) {\n return;\n }\n \n // Check if video is actually playing and has data\n const video = webcamRef.current.video;\n if (video.readyState < 2) return; \n\n try {\n const poses = await globalDetector.estimatePoses(\n video,\n { flipHorizontal: false }\n );\n\n if (!poses || !poses.length) return;\n\n const keypoints = poses[0].keypoints;\n \n // Standardize keypoints\n const body: KeypointTuple[] = keypoints\n .slice(11) // Ignore face keypoints (0-10)\n .map((kp: any) => [\n kp.x > 0 && kp.x < 720 ? kp.x : -1,\n kp.y > 0 && kp.y < 1280 ? kp.y : -1,\n kp.score ?? 0,\n ]);\n\n if (spinPhaseRef.current === 0 && !isFrontFrame(body)) {\n setConsecutiveFronts((prev) => prev + 1);\n }\n\n if (spinPhaseRef.current === 1 && isFrontFrame(body)) {\n setConsecutiveFronts((prev) => prev + 1);\n }\n\n if (spinPhaseRef.current === 2) callback();\n } catch (err) {\n console.error(\"Pose detection error:\", err);\n }\n };\n\n useEffect(() => {\n consecutiveFrontsRef.current = consecutiveFronts;\n if (consecutiveFronts > 6 && spinPhaseRef.current < 2) {\n setSpinPhase((s) => s + 1);\n setConsecutiveFronts(0);\n }\n }, [consecutiveFronts]);\n\n useEffect(() => {\n spinPhaseRef.current = spinPhase;\n }, [spinPhase]);\n\n const resetDetector = () => {\n spinPhaseRef.current = 0;\n consecutiveFrontsRef.current = 0;\n setConsecutiveFronts(0);\n setSpinPhase(0);\n };\n\n const retryLoading = async () => {\n if (!globalDetector && !globalLoadingPromise) {\n globalLoadingPromise = loadDependenciesGlobal();\n const success = await globalLoadingPromise;\n if (success && mounted.current) {\n setIsLoaded(true);\n }\n }\n };\n\n return { \n poseDetector, \n isLoaded,\n spinPhase,\n resetDetector,\n retryLoading\n };\n}","/* eslint-disable no-use-before-define */\nimport React, { useCallback, useContext, useEffect, useRef, useState } from \"react\";\nimport CameraScanChild from \"./CameraScanChild\";\nimport posthog from \"posthog-js\";\nimport Webcam from \"react-webcam\";\nimport { ScanningComponentProps } from \"../../types/interfaces\";\nimport useTensorFlow from \"../../customHooks/useTensorFlow\";\nimport ParamsContext from \"../../utils/context/paramsContext\";\nimport { generateUuid, getCurrentTimeInSeconds, handleScanTimeCapture, rescanSupportCaptureEvent } from \"../../utils/utils\";\nimport speechService from \"../../utils/service/speechService\";\nimport swan from \"../../utils/service/swanService\";\nimport { videoTypes, voiceOverAssetsPath } from \"../../utils/constants\";\n\nlet id: string | null = null;\nlet audioTimeoutId: number | undefined | NodeJS.Timeout;\nlet lastVideoPlayed: {\n\tskipCount: number;\n\tno_of_times_skipped: number;\n\taudioName: string;\n} | null = null;\n\nfunction ScanningComponent({ setIsScanLocked, resetDetector, scanID, setIsVideoUploaded, setScanFailsError, setScanStartTime, setScanUniqueKey, userDetails, config }: ScanningComponentProps) {\n\tconst { gender, heightInCm, email, shopDomain } = userDetails;\n\tconst webcamRef = useRef<Webcam | null>(null);\n\tconst mediaRecorderRef = useRef<MediaRecorder | null>(null);\n\tconst [recordedChunks, setRecordedChunks] = useState<Blob[]>([]);\n\tconst [loadingCam, setLoadingCam] = useState(true);\n\tconst [recordingStarted, setRecordingStarted] = useState(false);\n\tconst [faceDone, setFaceDone] = useState(false);\n\tconst [mediaRecorderStopped, setMediaRecorderStopped] = useState(true);\n\tconst [isScanning, setIsScanning] = useState(false);\n\tconst captureVideoTimeOutHandle = useRef<number | null | NodeJS.Timeout>(null);\n\tconst [audioSource, setAudioSource] = useState(\"\");\n\tconst [audioSourceList, setAudioSourceList] = useState<string[]>([]);\n\tconst [emptyAudioSource, setEmptyAudioSource] = useState(\"\");\n\tconst [startAgain, setStartAgain] = useState(false);\n\tconst [showRestart, setRestart] = useState(false);\n\tconst [pause, setPause] = useState(false);\n\tconst [events, setEvents] = useState<any>([]);\n\tconst [showPause, setShowPause] = useState(false);\n\tconst allowAudioToPlay = useRef(true);\n\tconst { poseDetector } = useTensorFlow();\n\tconst firstScan = useRef(true);\n\tconst poseStoppedRef = useRef(false);\n\tconst [supportedTypes, setSupportedTypes] = useState<string[]>([]);\n\n\tlet counter = 0;\n\n\tconst { setStartGyro, handleFileUpload, setUploadLoading } = useContext(ParamsContext);\n\n\tconst handleShowStreamCamera = () => {\n\t\tposeStoppedRef.current = false;\n\t\tclearTimeout(audioTimeoutId);\n\t\tif (captureVideoTimeOutHandle.current) clearTimeout(captureVideoTimeOutHandle.current);\n\t\tsetScanUniqueKey(generateUuid());\n\t\tsetScanFailsError(\"\");\n\t\tsetUploadLoading?.(false);\n\t\tsetRecordedChunks([]);\n\t\tsetLoadingCam(true);\n\t\tsetRecordingStarted(false);\n\t\tsetFaceDone(false);\n\t\tsetMediaRecorderStopped(true);\n\t\tsetIsScanning(false);\n\t\tcaptureVideoTimeOutHandle.current = null;\n\t\tsetAudioSource(\"\");\n\t\tsetAudioSourceList([]);\n\t\tsetEmptyAudioSource(\"\");\n\t\tsetStartAgain(!startAgain);\n\t\tsetStartGyro(false);\n\t\tspeechService.stopAudio();\n\t\tsetRestart(false);\n\t\tsetPause(false);\n\t\tcounter = 0;\n\t\tif (mediaRecorderRef.current !== null) {\n\t\t\tmediaRecorderRef.current.stop();\n\t\t}\n\n\t\tevents.forEach((el: any) => {\n\t\t\tif (mediaRecorderRef.current) mediaRecorderRef.current.removeEventListener(\"dataavailable\", el);\n\t\t});\n\n\t\tsetEvents([]);\n\t\tallowAudioToPlay.current = true;\n\t\tsetShowPause(false);\n\t\tsetIsVideoUploaded(false);\n\t};\n\n\tconst handleUserMedia = useCallback(() => {\n\t\tsetTimeout(() => {\n\t\t\tsetLoadingCam(false);\n\t\t}, 1000);\n\t}, []);\n\n\tconst handleReScan = useCallback(() => {\n\t\trescanSupportCaptureEvent({\n\t\t\teventName: `${shopDomain}/rescan`,\n\t\t\temail,\n\t\t\tscanID: scanID,\n\t\t\theight: heightInCm,\n\t\t\tgender,\n\t\t\tstatus: false,\n\t\t});\n\t\tallowAudioToPlay.current = false;\n\t\thandleShowStreamCamera();\n\t\tstartSendingVideoFrames();\n\t}, [handleShowStreamCamera, scanID, email]);\n\n\tconst handlePause = useCallback(() => {\n\t\tallowAudioToPlay.current = false;\n\t\tsetPause(true);\n\t\tsetShowPause(false);\n\t\tif (captureVideoTimeOutHandle.current) clearTimeout(captureVideoTimeOutHandle.current);\n\t\tif (mediaRecorderRef.current) {\n\t\t\tmediaRecorderRef.current.pause();\n\t\t}\n\t\tspeechService.stopAudio();\n\t\tswan.poseDetection.disconnect();\n\t\tcounter = 0;\n\t\tif (mediaRecorderRef.current) {\n\t\t\tmediaRecorderRef.current.stop();\n\t\t}\n\t\tevents.forEach((el: any) => {\n\t\t\tif (mediaRecorderRef.current) mediaRecorderRef.current.removeEventListener(\"dataavailable\", el);\n\t\t});\n\t\tsetEvents([]);\n\t\tclearTimeout(audioTimeoutId);\n\t}, [mediaRecorderRef, events, speechService, allowAudioToPlay]);\n\n\t// const supportedTypes = videoTypes.filter((type) => MediaRecorder.isTypeSupported(type));\n\n\tconst stopRecording = useCallback(async () => {\n\t\tallowAudioToPlay.current = true;\n\t\tawait speechService.playAudio(`${voiceOverAssetsPath}SpotOn.mp3`);\n\t\tsetPause(false);\n\t\tsetShowPause(false);\n\t\tif (captureVideoTimeOutHandle.current) clearTimeout(captureVideoTimeOutHandle.current);\n\t\tsetRecordingStarted(false);\n\t}, [captureVideoTimeOutHandle, speechService]);\n\n\tconst handleSocket = useCallback(async () => {\n\t\ttry {\n\t\t\tid = await swan.poseDetection.connect();\n\n\t\t\tposthog.capture(`${shopDomain}/pose_detection_connected`, {\n\t\t\t\tscanID: scanID,\n\t\t\t\temail,\n\t\t\t\tid,\n\t\t\t});\n\t\t} catch (error) {\n\t\t\tconsole.log(error, \"while connecting websocket\");\n\t\t}\n\t}, [scanID, shopDomain, email]);\n\n\tconst handleSpinDataAvailable = useCallback(\n\t\t({ data }: BlobEvent) => {\n\t\t\tif (data && data.size > 0 && allowAudioToPlay.current) {\n\t\t\t\tsetRecordedChunks((prev) => prev.concat(data));\n\t\t\t\tif (!poseStoppedRef.current && webcamRef.current) {\n\t\t\t\t\tposeStoppedRef.current = true;\n\t\t\t\t\tposeDetector(() => {\n\t\t\t\t\t\tstopRecording();\n\t\t\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\t\t\teventName: `${shopDomain}/tensorFlow`,\n\t\t\t\t\t\t\tscanID: scanID,\n\t\t\t\t\t\t\temail,\n\t\t\t\t\t\t\tmessage: \"recording stopped by tensorflow \",\n\t\t\t\t\t\t});\n\t\t\t\t\t}, webcamRef);\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t[stopRecording, handleScanTimeCapture, shopDomain, scanID, email, webcamRef],\n\t);\n\n\tconst playAudio = useCallback(async () => {\n\t\tif (audioSourceList.length > 0 && allowAudioToPlay.current) {\n\t\t\tawait speechService.playAudio(voiceOverAssetsPath + audioSourceList[audioSourceList.length - 1]);\n\t\t\tif (allowAudioToPlay.current) {\n\t\t\t\taudioTimeoutId = setTimeout(playAudio, 2000);\n\t\t\t}\n\t\t}\n\t}, [audioSourceList, allowAudioToPlay]);\n\n\tconst handleStartCaptureClick = useCallback(() => {\n\t\tif (mediaRecorderRef && mediaRecorderRef.current) {\n\t\t\tmediaRecorderRef.current.stop();\n\t\t}\n\t\tsetRecordingStarted(true);\n\t\ttry {\n\t\t\tif (webcamRef && webcamRef.current && webcamRef.current.stream) {\n\t\t\t\tconst mediaRecorderOptions = {\n\t\t\t\t\tmimeType: supportedTypes[0],\n\t\t\t\t};\n\t\t\t\tmediaRecorderRef.current = new MediaRecorder(webcamRef.current.stream, mediaRecorderOptions);\n\t\t\t\tmediaRecorderRef.current.addEventListener(\"dataavailable\", handleSpinDataAvailable);\n\n\t\t\t\tsetEvents([...events, handleSpinDataAvailable]);\n\t\t\t\tmediaRecorderRef.current.start(1000);\n\t\t\t\tsetMediaRecorderStopped(false);\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tconsole.log(\"error while using media recorder\", e);\n\t\t}\n\t}, [webcamRef, supportedTypes, handleSpinDataAvailable, events]);\n\n\tconst postPoseProcess = useCallback(async () => {\n\t\tif (captureVideoTimeOutHandle.current) {\n\t\t\tclearTimeout(captureVideoTimeOutHandle.current);\n\t\t}\n\t\thandleStartCaptureClick();\n\t\tif (allowAudioToPlay.current) {\n\t\t\tcaptureVideoTimeOutHandle.current = setTimeout(async () => {\n\t\t\t\tif (allowAudioToPlay.current) {\n\t\t\t\t\tawait speechService.playAudio(`${voiceOverAssetsPath}SpotOn.mp3`);\n\t\t\t\t\tsetRecordingStarted(false);\n\t\t\t\t}\n\t\t\t}, 15000);\n\t\t}\n\t\tsetFaceDone(true);\n\t\tif (allowAudioToPlay.current) {\n\t\t\tawait speechService.playAudio(`${voiceOverAssetsPath}Spin.mp3`);\n\t\t}\n\t}, [handleStartCaptureClick, allowAudioToPlay, speechService]);\n\n\tconst handleDataAvailable = useCallback(\n\t\t({ data }: BlobEvent) => {\n\t\t\tif (data.size > 0 && swan.poseDetection.connected()) {\n\t\t\t\tswan.poseDetection.poseStatus(async (data) => {\n\t\t\t\t\tif (data && data.audio && data.audio.length > 0) {\n\t\t\t\t\t\tconst audio = document.querySelector(\"#audioElement\") as HTMLAudioElement | null;\n\t\t\t\t\t\tif (data.status === true && data.sid === id) {\n\t\t\t\t\t\t\tif (counter < 2) {\n\t\t\t\t\t\t\t\tif (counter === 0 && audio?.paused) {\n\t\t\t\t\t\t\t\t\tawait speechService.playAudio(voiceOverAssetsPath + data.audio);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tcounter += 1;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tsetEmptyAudioSource(data.audio);\n\t\t\t\t\t\t\t\tclearTimeout(audioTimeoutId);\n\t\t\t\t\t\t\t\tswan.poseDetection.disconnect();\n\t\t\t\t\t\t\t\tsetTimeout(postPoseProcess, 1000);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tcounter = 0;\n\t\t\t\t\t\t\tif (audio?.paused && (!lastVideoPlayed || lastVideoPlayed?.audioName !== data.audio)) {\n\t\t\t\t\t\t\t\tlastVideoPlayed = {\n\t\t\t\t\t\t\t\t\tskipCount: 2,\n\t\t\t\t\t\t\t\t\tno_of_times_skipped: 0,\n\t\t\t\t\t\t\t\t\taudioName: data.audio,\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\tspeechService.playAudio(voiceOverAssetsPath + data.audio);\n\t\t\t\t\t\t\t} else if (lastVideoPlayed?.audioName === data.audio && audio?.paused) {\n\t\t\t\t\t\t\t\tif (lastVideoPlayed && lastVideoPlayed.no_of_times_skipped >= lastVideoPlayed.skipCount) {\n\t\t\t\t\t\t\t\t\tlastVideoPlayed.no_of_times_skipped = 0;\n\t\t\t\t\t\t\t\t\tspeechService.playAudio(voiceOverAssetsPath + data.audio);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tif (lastVideoPlayed) lastVideoPlayed.no_of_times_skipped += 1;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tif (webcamRef?.current && webcamRef.current.getScreenshot() !== null) {\n\t\t\t\t\tswan.poseDetection.videoEmit({\n\t\t\t\t\t\timage: webcamRef.current.getScreenshot() || \"\",\n\t\t\t\t\t\tscanId: scanID,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t[webcamRef, scanID, swan, id, counter, postPoseProcess, speechService],\n\t);\n\n\tconst startSendingVideoFrames = useCallback(async () => {\n\t\tsetIsScanning(true);\n\t\tsetStartGyro(true);\n\t\tif (firstScan.current) {\n\t\t\tfirstScan.current = false;\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: \"scan started\",\n\t\t\t\tscanID: scanID,\n\t\t\t\tstatus: \"success\",\n\t\t\t\temail,\n\t\t\t});\n\t\t}\n\t\tsetScanStartTime(getCurrentTimeInSeconds());\n\t\tsetLoadingCam(true);\n\t\tif (allowAudioToPlay.current) {\n\t\t\tawait speechService.playAudio(`${voiceOverAssetsPath}StartScan.mp3`);\n\t\t}\n\t\tif (allowAudioToPlay.current) {\n\t\t\tawait speechService.playAudio(`${voiceOverAssetsPath}LiftArmsAndHoldAtHip.mp3`);\n\t\t}\n\t\tif (allowAudioToPlay.current) {\n\t\t\tsetIsScanning(false);\n\t\t\tsetRecordingStarted(true);\n\t\t\tsetRestart(true);\n\t\t\tsetShowPause(true);\n\t\t\thandleUserMedia();\n\t\t}\n\t\ttry {\n\t\t\tif (webcamRef && webcamRef.current && webcamRef.current.stream && allowAudioToPlay.current) {\n\t\t\t\tconst mediaRecorderOptions = {\n\t\t\t\t\tmimeType: supportedTypes[0],\n\t\t\t\t};\n\t\t\t\tif (allowAudioToPlay.current) {\n\t\t\t\t\tmediaRecorderRef.current = new MediaRecorder(webcamRef.current.stream, mediaRecorderOptions);\n\t\t\t\t}\n\t\t\t\tif (allowAudioToPlay.current && mediaRecorderRef.current) {\n\t\t\t\t\tmediaRecorderRef.current.addEventListener(\"dataavailable\", handleDataAvailable);\n\t\t\t\t}\n\n\t\t\t\tsetEvents([...events, handleDataAvailable]);\n\t\t\t\tif (mediaRecorderRef.current) mediaRecorderRef.current.start(1000);\n\t\t\t\tsetMediaRecorderStopped(false);\n\t\t\t\tif (allowAudioToPlay.current) {\n\t\t\t\t\taudioTimeoutId = setTimeout(playAudio, 2000);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (err) {\n\t\t\tconsole.log(\"error ----------\", err);\n\t\t}\n\t}, [webcamRef, supportedTypes, handleDataAvailable, events, playAudio, allowAudioToPlay]);\n\n\tuseEffect(() => {\n\t\tif (shopDomain) {\n\t\t\tsetIsScanLocked(true);\n\t\t\thandleSocket();\n\t\t}\n\t\treturn () => {\n\t\t\tif (id) {\n\t\t\t\tswan.poseDetection.disconnect();\n\t\t\t\tposthog.capture(`${shopDomain}/pose_detection_disconnected`, {\n\t\t\t\t\tscanID: scanID,\n\t\t\t\t\temail,\n\t\t\t\t\tid,\n\t\t\t\t});\n\t\t\t}\n\t\t\tevents.forEach((el: any) => {\n\t\t\t\tmediaRecorderRef?.current?.removeEventListener(\"dataavailable\", el);\n\t\t\t});\n\t\t};\n\t}, [startAgain, shopDomain]);\n\tuseEffect(() => {\n\t\taudioSourceList.push(audioSource);\n\t}, [audioSource]);\n\n\tuseEffect(() => {\n\t\tsetAudioSourceList([]);\n\t}, [emptyAudioSource]);\n\tuseEffect(() => {\n\t\tconst bypassChecksToBackup = recordedChunks.length && recordedChunks.length > 0;\n\t\tif (!mediaRecorderStopped && bypassChecksToBackup && !recordingStarted && allowAudioToPlay.current && !pause) {\n\t\t\tif (mediaRecorderRef && mediaRecorderRef.current) {\n\t\t\t\tif (!recordingStarted) {\n\t\t\t\t\tmediaRecorderRef.current.stop();\n\t\t\t\t\tsetMediaRecorderStopped(true);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, [mediaRecorderStopped, recordingStarted, recordedChunks, pause]);\n\n\tuseEffect(() => {\n\t\tconst bypassChecksToBackup = recordedChunks.length && recordedChunks.length > 0;\n\t\tif (!mediaRecorderStopped && bypassChecksToBackup && !recordingStarted) {\n\t\t\tif (mediaRecorderRef && mediaRecorderRef.current && allowAudioToPlay.current && !pause) {\n\t\t\t\tif (!recordingStarted) {\n\t\t\t\t\tconst videoFile = new File(recordedChunks, `${scanID}.webm`, {\n\t\t\t\t\t\ttype: \"video/webm\",\n\t\t\t\t\t});\n\t\t\t\t\tsetUploadLoading?.(true);\n\t\t\t\t\tsetScanFailsError(\"\");\n\t\t\t\t\thandleFileUpload?.(videoFile);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tconsole.log(\"No video found to upload\");\n\t\t}\n\t}, [mediaRecorderStopped, recordingStarted, recordedChunks, pause, mediaRecorderRef, allowAudioToPlay]);\n\tuseEffect(() => {\n\t\tif (typeof MediaRecorder !== \"undefined\") {\n\t\t\tconst supported = videoTypes.filter((type) => MediaRecorder.isTypeSupported(type));\n\t\t\tsetSupportedTypes(supported);\n\t\t}\n\t}, []);\n\tuseEffect(() => {\n\t\thandleShowStreamCamera();\n\t}, []);\n\n\treturn (\n\t\t<CameraScanChild\n\t\t\tresetDetector={resetDetector}\n\t\t\thandleShowStreamCamera={handleShowStreamCamera}\n\t\t\tloadingCam={loadingCam}\n\t\t\thandlePause={handlePause}\n\t\t\tshowRestart={showRestart}\n\t\t\tpause={pause}\n\t\t\thandleReScan={handleReScan}\n\t\t\trecordingStarted={recordingStarted}\n\t\t\tisScanning={isScanning}\n\t\t\tstartSendingVideoFrames={startSendingVideoFrames}\n\t\t\tfaceDone={faceDone}\n\t\t\tstopRecording={stopRecording}\n\t\t\tshowPause={showPause}\n\t\t\twebcamRef={webcamRef}\n\t\t\thandleUserMedia={handleUserMedia}\n\t\t\tconfig={config}\n\t\t/>\n\t);\n}\n\nexport default React.memo(ScanningComponent);\n","/* eslint-disable no-use-before-define */\n\nimport { useEffect, useState, useRef } from \"react\";\nimport { IOSDeviceOrientationEvent } from \"../../customHooks/useGyroSensor\";\nimport LevelScreen from \"./LevelScreen\";\nimport ScanningComponent from \"./ScanningComponent\";\nimport { AngleDetectorProps } from \"../../types/interfaces\";\n\nexport default function AngleDetector({\n scanID,\n userDetails,\n setIsVideoUploaded,\n setScanFailsError,\n setScanStartTime,\n setScanUniqueKey,\n config,\n}: AngleDetectorProps) {\n const [angle, setAngle] = useState(90);\n const [calibrationOffset, setCalibrationOffset] = useState(0);\n const [countdown, setCountdown] = useState<number | null>(null);\n const [isScanning, setIsScanning] = useState(false);\n const [stabilityScore, setStabilityScore] = useState(0);\n const lastAnglesRef = useRef<number[]>([]);\n const [isScanLocked, setIsScanLocked] = useState(false);\n const calibratedAngle = angle - calibrationOffset;\n const isInTargetRange = calibratedAngle >= 80 && calibratedAngle <= 95;\n\n const resetDetector = () => {\n setAngle(90);\n setCalibrationOffset(0);\n setCountdown(null);\n setIsScanning(false);\n setStabilityScore(0);\n setIsScanLocked(false);\n lastAnglesRef.current = [];\n };\n\n useEffect(() => {\n if (typeof window !== \"undefined\" && window.DeviceOrientationEvent) {\n const handleOrientation = (event: DeviceOrientationEvent) => {\n if (event.beta !== null) {\n let newAngle = Math.abs(event.beta);\n if (event.gamma !== null) {\n newAngle *= Math.cos((event.gamma * Math.PI) / 180);\n }\n newAngle = Math.max(0, Math.min(180, newAngle));\n setAngle(newAngle);\n }\n };\n\n const requestPermission = async () => {\n const DeviceOrientation =\n DeviceOrientationEvent as unknown as IOSDeviceOrientationEvent;\n\n if (\n DeviceOrientation &&\n typeof DeviceOrientation.requestPermission === \"function\"\n ) {\n try {\n const permission = await DeviceOrientation.requestPermission();\n if (permission === \"granted\") {\n // wrappedHandler = timeout(handleOrientation, 2000);\n window.addEventListener(\"deviceorientation\", handleOrientation);\n }\n } catch (e) {\n console.error(\"Permission error\", e);\n }\n } else {\n // wrappedHandler = handleOrientation;\n window.addEventListener(\"deviceorientation\", handleOrientation);\n }\n\n return () => {\n if (handleOrientation) {\n window.removeEventListener(\"deviceorientation\", handleOrientation);\n }\n };\n };\n\n document.addEventListener(\"click\", requestPermission, { once: true });\n }\n }, []);\n\n useEffect(() => {\n lastAnglesRef.current = [\n ...lastAnglesRef.current.slice(-4),\n calibratedAngle,\n ];\n\n if (lastAnglesRef.current.length >= 5) {\n const variation =\n Math.max(...lastAnglesRef.current) - Math.min(...lastAnglesRef.current);\n if (isInTargetRange && variation < 2) {\n setStabilityScore((prev) => Math.min(100, prev + 10));\n } else {\n setStabilityScore((prev) => Math.max(0, prev - 20));\n }\n }\n\n if (!isInTargetRange && (countdown !== null || isScanning)) {\n resetCountdown();\n }\n }, [calibratedAngle, isInTargetRange, countdown, isScanning]);\n\n\tuseEffect(() => {\n\t\tif (stabilityScore >= 100 && countdown === null && !isScanning ) {\n\t\t\tstartCountdown();\n\t\t}\n\t\tif (stabilityScore < 50 && countdown !== null) {\n\t\t\tresetCountdown();\n\t\t}\n\t}, [stabilityScore, countdown, isScanning]);\n\n const startCountdown = () => {\n setCountdown(3);\n const timer = setInterval(() => {\n setCountdown((prev) => {\n if (prev === null || prev <= 1) {\n clearInterval(timer);\n setIsScanning(true);\n return null;\n }\n return prev - 1;\n });\n }, 1000);\n };\n\n const resetCountdown = () => {\n setCountdown(null);\n if (!isScanLocked) {\n setIsScanning(false);\n }\n };\n\n\n return (\n <LevelScreen\n angle={calibratedAngle}\n countdown={countdown}\n isScanning={isScanning}\n isInTargetRange={isInTargetRange}\n stabilityScore={stabilityScore}\n config={config}\n >\n {isScanning && (\n <ScanningComponent\n setIsScanLocked={setIsScanLocked}\n resetDetector={resetDetector}\n scanID={scanID}\n userDetails={userDetails}\n setIsVideoUploaded={setIsVideoUploaded}\n setScanFailsError={setScanFailsError}\n setScanStartTime={setScanStartTime}\n setScanUniqueKey={setScanUniqueKey}\n config={config}\n />\n )}\n </LevelScreen>\n );\n}\n","import { useContext } from \"react\";\nimport {Dialog} from \"@mui/material\";\nimport { getBrowserName } from \"../utils/utils\";\nimport { LanguageContext } from \"../utils/context/languageContext\";\nimport { LanguageKeys } from \"../utils/languageKeys\";\nimport { Config } from \"../types/interfaces\";\n\nfunction Modal({ message, config }: { message?: string; config?: Config }) {\n const { translate } = useContext(LanguageContext) || {};\n\n\n\n return (\n <Dialog open className=\"confirm-modal\">\n <div className=\"modal-main\">\n <div className=\"text-center\">\n {message ? (\n <>\n <h2\n style={{\n fontFamily:\n config?.style?.heading?.headingFontFamily ||\n \"SeriouslyNostalgic Fn\",\n fontSize: config?.style?.heading?.headingFontSize || \"32px\",\n color: config?.style?.heading?.headingColor || \"#000\",\n fontWeight:\n config?.style?.heading?.headingFontWeight || \"normal\",\n }}\n >\n {translate?.(LanguageKeys.cameraAlreadyInUse)}\n </h2>\n <p\n className=\"mt-[0.5rem] text-sm\"\n style={{\n fontFamily:\n config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n fontSize: config?.style?.base?.baseFontSize || \"16px\",\n color: config?.style?.base?.baseTextColor || \"#000\",\n }}\n >\n {translate?.(LanguageKeys.tryClosingBrowser)}\n </p>\n </>\n ) : (\n <>\n <h2\n style={{\n fontFamily:\n config?.style?.heading?.headingFontFamily ||\n \"SeriouslyNostalgic Fn\",\n fontSize: config?.style?.heading?.headingFontSize || \"32px\",\n color: config?.style?.heading?.headingColor || \"#000\",\n fontWeight:\n config?.style?.heading?.headingFontWeight || \"normal\",\n }}\n >\n {translate?.(LanguageKeys.checkCameraSettings)}\n </h2>\n <p\n className=\"mt-[0.5rem] text-sm\"\n style={{\n fontFamily:\n config?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n fontSize: config?.style?.base?.baseFontSize || \"16px\",\n color: config?.style?.base?.baseTextColor || \"#000\",\n }}\n >{`${translate?.(\n LanguageKeys.setting\n )} > ${getBrowserName()} > ${translate?.(\n LanguageKeys.enableCameraPermissions\n )}`}</p>\n </>\n )}\n </div>\n </div>\n </Dialog>\n );\n}\n\nexport default Modal;\n","import { useEffect, useState, useRef, useCallback, Dispatch, SetStateAction } from \"react\";\nimport Webcam from \"react-webcam\";\nimport Modal from \"../Modal\";\nimport LoadingScreen from \"../LoadingScreen\";\nimport { checkCameraPermission } from \"../../utils/utils\";\nimport { videoConstraints } from \"../../utils/constants\";\n\n\nfunction CameraPermission({ setShowDrawer, config,loader }: { setShowDrawer?: Dispatch<SetStateAction<boolean>>; config?: any,loader?:string }) {\n\tconst [showDeniedModal, setShowDeniedModal] = useState({\n\t\tdisabled: false,\n\t\tmessage: \"\",\n\t});\n\tconst [loading, setLoading] = useState(true);\n\tconst webcamRef = useRef(null);\n\n\tconst handleCameraPermission = useCallback(async () => {\n\t\tconst permission = await checkCameraPermission();\n\t\tsetShowDeniedModal(permission);\n\t\tsetLoading(false);\n\t}, []);\n\n\tuseEffect(() => {\n\t\thandleCameraPermission();\n\t}, []);\n\n\tif (loading) {\n\t\treturn <LoadingScreen url={loader} loaderType=\"black\" />\n\t}\n\n\tif (showDeniedModal?.disabled) {\n\t\treturn <Modal config={config} message={showDeniedModal?.message} />;\n\t}\n\treturn (\n\t\t<Webcam\n\t\t\taudio={false}\n\t\t\tref={webcamRef}\n\t\t\tscreenshotQuality={1}\n\t\t\tvideoConstraints={videoConstraints}\n\t\t\tmirrored\n\t\t\tonUserMedia={() => setShowDrawer?.(true)}\n\t\t\tscreenshotFormat=\"image/jpeg\"\n\t\t\tstyle={{\n\t\t\t\tposition: \"relative\",\n\t\t\t\ttop: 0,\n\t\t\t\tbottom: 0,\n\t\t\t\tzIndex: 0,\n\t\t\t\twidth: \"100%\",\n\t\t\t\theight: \"100%\",\n\t\t\t\tobjectFit: \"cover\",\n\t\t\t}}\n\t\t/>\n\t);\n}\n\nexport default CameraPermission;\n","\nimport React, { useEffect, useRef } from \"react\";\nimport videojs from \"video.js\";\nimport type Player from \"video.js/dist/types/player\";\n// import \"video.js/dist/video-js.css\";\nimport { videoPoster } from \"../../utils/constants\";\n\nfunction VideoPlayer({ link, onReady, wrapperClassName = \"[&_video]:rounded-t-[20px] w-full h-full\" }: { link?: string; wrapperClassName?: string; onReady?: (args: Player) => void }) {\n\tconst videoReference = useRef<HTMLVideoElement | null>(null);\n\tconst playerReference = useRef<Player | null>(null);\n\n\tlet videoJsOptions: any = {\n\t\tautoplay: true,\n\t\tcontrols: false,\n\t\tresponsive: true,\n\t\tfluid: true,\n\t\tmuted: true,\n\t\tnavigationUI: \"hide\",\n\t\tpreload: \"metadata\",\n\t\tposter: videoPoster,\n\t};\n\n\tuseEffect(() => {\n\t\tif (!playerReference.current && link && videoReference?.current) {\n\t\t\tconst player = videojs(videoReference.current, {\n\t\t\t\t...videoJsOptions,\n\t\t\t});\n\t\t\tplayer.ready(() => {\n\t\t\t\tplayerReference.current = player;\n\n\t\t\t\tconst updatedOptions = {\n\t\t\t\t\t...videoJsOptions,\n\t\t\t\t\tsources: [{ src: link, type: \"application/x-mpegURL\" }],\n\t\t\t\t};\n\n\t\t\t\tplayer.autoplay(updatedOptions.autoplay);\n\t\t\t\tplayer.src(updatedOptions.sources);\n\n\t\t\t\tonReady?.(player);\n\t\t\t});\n\t\t}\n\t}, [link, videoReference]);\n\n\tuseEffect(() => {\n\t\tconst player = playerReference.current;\n\t\treturn () => {\n\t\t\tif (player && !player.isDisposed()) {\n\t\t\t\tplayer.dispose();\n\t\t\t\tplayerReference.current = null;\n\t\t\t}\n\t\t};\n\t}, [playerReference]);\n\n\treturn (\n\t\t<div className={wrapperClassName}>\n\t\t\t<video ref={videoReference} muted className=\"video-js\" playsInline onDrag={(e) => e.preventDefault()} />\n\t\t</div>\n\t);\n}\nexport default VideoPlayer;\n","import { useContext, useState } from \"react\";\nimport {Dialog} from \"@mui/material\";\nimport { LanguageContext } from \"../../utils/context/languageContext\";\nimport Header from \"../Header\";\nimport VideoPlayer from \"./VideoPlayer\";\nimport { ScanErrorMessageProps } from \"../../types/interfaces\";\nimport { generateUuid, handleErrorMessage } from \"../../utils/utils\";\nimport { GENDER, VIDEO_POSTER_GENDER_BASED } from \"../../utils/constants\";\nimport SpecificButton from \"../../atoms/specificButton/SpecificButton\";\nimport { LanguageKeys } from \"../../utils/languageKeys\";\nimport { X } from \"lucide-react\";\n\nfunction ScanErrorMessage({ scanFailsError, serverAtCapacity = false, onNext, gender, setScanUniqueKey, resolvedConfig, setIsVideoUploaded }: ScanErrorMessageProps) {\n\tconst { translate } = useContext(LanguageContext) || {};\n\tconst [showModal, setShowModal] = useState(false);\n\n\tconst handleBtnClick = () => {\n\t\tif (onNext) {\n\t\t\tonNext?.();\n\t\t} else {\n\t\t\tsetScanUniqueKey(generateUuid());\n\t\t}\n\t\tsetIsVideoUploaded(false);\n\t};\n\n\tconst handleShowModal = () => {\n\t\tsetShowModal(!showModal);\n\t};\n\n\n\treturn (\n\t\t<>\n\t\t\t<div className=\"flex flex-col h-full max-w-[28rem] mx-auto w-full rounded-t-[20px] overflow-y-auto\" style={{ background: resolvedConfig?.style?.base?.backgroundColor }}>\n\t\t\t\t<div className=\"w-full max-w-[28rem] mx-auto pt-[1rem] px-[1rem]\">\n\t\t\t\t\t<Header noTitle resolvedConfig={resolvedConfig} />\n\t\t\t\t</div>\n\t\t\t\t<div className=\"flex-1\">\n\t\t\t\t\t{/* <VideoPlayer link={gender ? GENDER[gender].PRE_LINK : GENDER.male.PRE_LINK} /> */}\n\t\t\t\t\t{scanFailsError && (\n\t\t\t\t\t\t<div className=\"px-[1rem]\">\n\t\t\t\t\t\t\t<h2\n\t\t\t\t\t\t\t\tclassName=\"text-center\"\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\tfontFamily: resolvedConfig?.style?.heading?.headingFontFamily || \"SeriouslyNostalgic Fn\",\n\t\t\t\t\t\t\t\t\tfontSize: resolvedConfig?.style?.heading?.headingFontSize || \"32px\",\n\t\t\t\t\t\t\t\t\tcolor: resolvedConfig?.style?.heading?.headingColor || \"#000\",\n\t\t\t\t\t\t\t\t\tfontWeight: resolvedConfig?.style?.heading?.headingFontWeight || \"normal\",\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{translate?.(LanguageKeys.issueWithScan)}\n\t\t\t\t\t\t\t</h2>\n\t\t\t\t\t\t\t<p\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\tfontFamily: resolvedConfig?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n\t\t\t\t\t\t\t\t\tfontSize: resolvedConfig?.style?.base?.baseFontSize || \"16px\",\n\t\t\t\t\t\t\t\t\tcolor: resolvedConfig?.style?.base?.baseTextColor || \"#1E1E1E\",\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{translate?.(LanguageKeys.reason)}\n\t\t\t\t\t\t\t</p>\n\t\t\t\t\t\t\t<p\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\tfontFamily: resolvedConfig?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n\t\t\t\t\t\t\t\t\tfontSize: resolvedConfig?.style?.base?.baseFontSize || \"16px\",\n\t\t\t\t\t\t\t\t\tcolor: resolvedConfig?.style?.base?.baseTextColor || \"#1E1E1E\",\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{handleErrorMessage(scanFailsError)}\n\t\t\t\t\t\t\t</p>\n\n\t\t\t\t\t\t\t<img className=\"my-[0.5rem] aspect-[2/1.4] w-full object-cover\" onClick={handleShowModal} src={VIDEO_POSTER_GENDER_BASED[gender]} alt=\"icon\" />\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t\t{serverAtCapacity && (\n\t\t\t\t\t\t<div className=\"p-[1rem] text-center\">\n\t\t\t\t\t\t\t<h3\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\tfontFamily: resolvedConfig?.style?.heading?.headingFontFamily || \"SeriouslyNostalgic Fn\",\n\t\t\t\t\t\t\t\t\tfontSize: resolvedConfig?.style?.heading?.headingFontSize || \"32px\",\n\t\t\t\t\t\t\t\t\tcolor: resolvedConfig?.style?.heading?.headingColor || \"#000\",\n\t\t\t\t\t\t\t\t\tfontWeight: resolvedConfig?.style?.heading?.headingFontWeight || \"normal\",\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{translate?.(LanguageKeys.serverAtCapacity)}\n\t\t\t\t\t\t\t</h3>\n\t\t\t\t\t\t\t<p\n\t\t\t\t\t\t\t\tclassName=\"text-base mt-[0.5rem]\"\n\t\t\t\t\t\t\t\tstyle={{\n\t\t\t\t\t\t\t\t\tfontFamily: resolvedConfig?.style?.base?.baseFontFamily || \"Inter, sans-serif\",\n\t\t\t\t\t\t\t\t\tfontSize: resolvedConfig?.style?.base?.baseFontSize || \"16px\",\n\t\t\t\t\t\t\t\t\tcolor: resolvedConfig?.style?.base?.baseTextColor || \"#1E1E1E\",\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t{translate?.(LanguageKeys.serverAtCapacityDescription)}\n\t\t\t\t\t\t\t</p>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{scanFailsError && (\n\t\t\t\t\t<div className=\"p-[1rem] flex gap-[0.5rem]\">\n\t\t\t\t\t\t<SpecificButton disabled={false} buttonText={translate?.(LanguageKeys.scanAgain)} className=\"!shadow-none\" buttonFunc={handleBtnClick} resolvedConfig={resolvedConfig} />\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</div>\n\t\t\t{showModal && (\n\t\t\t\t<Dialog className=\"w-screen h-screen video-modal\" onClose={handleShowModal} open={showModal}>\n\t\t\t\t\t<div className=\"flex justifyEnd \">\n\t\t\t\t\t\t<span className=\"closeBtn\" onClick={handleShowModal}>\n\t\t\t\t\t\t\t<X className=\"absolute right-[8px] top-[8px] text-white z-[9]\" />\n\t\t\t\t\t\t</span>\n\t\t\t\t\t</div>\n\t\t\t\t\t<div className=\"aspect-video object-cover rounded-[20px] \">\n\t\t\t\t\t\t<VideoPlayer link={gender ? GENDER[gender].PRE_LINK : GENDER.male.PRE_LINK} wrapperClassName=\"w-screen h-screen fixed top-[0] left-[0]\" />\n\t\t\t\t\t</div>\n\t\t\t\t</Dialog>\n\t\t\t)}\n\t\t</>\n\t);\n}\n\nexport default ScanErrorMessage;\n","import { useCallback, useContext, useEffect, useState } from \"react\";\nimport {Box,Drawer} from \"@mui/material\";\nimport { posthog } from \"posthog-js\";\nimport Header from \"./Header\";\nimport CameraPermission from \"./bodyScan/CameraPermission\";\nimport { UserDetails } from \"../types/interfaces\";\nimport { CLOTHING_BANNER_SCAN, CLOTHING_CUSTOM_FIT_SCAN, CLOTHING_CUSTOM_SCAN, maleMeasurementProgress, measurementProgress } from \"../utils/constants\";\nimport { GenderType } from \"../utils/enums\";\nimport SpecificButton from \"../atoms/specificButton/SpecificButton\";\nimport { LanguageContext } from \"../utils/context/languageContext\";\nimport { LanguageKeys } from \"../utils/languageKeys\";\nimport swan from \"../utils/service/swanService\";\n\nfunction SignUp({\n\tscanId,\n\tuserDetails,\n\tconfig,\n\tisFaceScan,\n\tisVideoUploadedCorrect,\n\tisMeasurementAvailable,\n\tonScanSuccess,\n\tisSuccess,\n}: {\n\tconfig?: any;\n\tisFaceScan: boolean;\n\tscanId: string;\n\tisVideoUploadedCorrect?: boolean;\n\tisMeasurementAvailable?: boolean;\n\tuserDetails: UserDetails;\n\tonScanSuccess?: () => void;\n\tisSuccess?: boolean;\n}) {\n\tconst { gender, shopDomain, heightInCm, deviceFocalLength, userName, email, scanType } = userDetails;\n\tconst isCustom = [CLOTHING_CUSTOM_SCAN, CLOTHING_BANNER_SCAN, CLOTHING_CUSTOM_FIT_SCAN].includes(scanType);\n\tconst [showDrawer, setShowDrawer] = useState(true);\n\tconst handlePostHogEvent = () => {\n\t\tposthog.capture(shopDomain, {\n\t\t\tscanID: scanId,\n\t\t\temail: email,\n\t\t\theight: heightInCm,\n\t\t\tfocalLength: deviceFocalLength,\n\t\t\tclothesFit: \"0\",\n\t\t\tgender: gender,\n\t\t});\n\t};\n\n\tconst handleSignUp = useCallback(async () => {\n\t\ttry {\n\t\t\tif (isCustom) {\n\t\t\t\tawait swan.auth.addUser({\n\t\t\t\t\tscanId,\n\t\t\t\t\temail,\n\t\t\t\t\tname: userName,\n\t\t\t\t\tgender,\n\t\t\t\t\theight: heightInCm,\n\t\t\t\t});\n\t\t\t}\n\t\t\thandlePostHogEvent();\n\t\t} catch (error) {\n\t\t\tconsole.log(error);\n\t\t}\n\t}, [isCustom]);\n\n\tconst { translate } = useContext(LanguageContext) || {};\n\n\tuseEffect(() => {\n\t\tif (isVideoUploadedCorrect) {\n\t\t\thandleSignUp();\n\t\t}\n\t}, [isVideoUploadedCorrect]);\n\n\tconst showNextButton = isSuccess || (isFaceScan ? isMeasurementAvailable && isVideoUploadedCorrect : isVideoUploadedCorrect || isMeasurementAvailable);\n\n\treturn (\n\t\t<Box className=\"flex h-full w-full flex-col \">\n\t\t\t<div className=\"h-full w-full flex-col items-center justify-center flex\">\n\t\t\t\t<CameraPermission loader={config?.loader} setShowDrawer={setShowDrawer} />\n\t\t\t\t<Drawer\n\t\t\t\t\topen={showDrawer}\n\t\t\t\t\tonClose={(_, reason) => {\n\t\t\t\t\t\tif (reason === \"backdropClick\") {\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t\tclassName=\"camera-drawer\"\n\t\t\t\t\tanchor=\"bottom\"\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName=\"max-w-[28rem] mx-auto w-full h-full flex text-center flex-col justify-between items-center bg-primary rounded-t-[30px] p-[1rem]\"\n\t\t\t\t\t\tstyle={{ background: config?.style?.base?.backgroundColor }}\n\t\t\t\t\t>\n\t\t\t\t\t\t<div className=\"w-full h-full flex flex-col\">\n\t\t\t\t\t\t\t<Header title={translate?.(LanguageKeys.measurementsBeingTaken)} resolvedConfig={config} />\n\t\t\t\t\t\t\t<div className=\"flex items-center justify-center flex-1\">\n\t\t\t\t\t\t\t\t<video preload=\"auto\" className=\"max-h-[calc(100vh-450px)] mx-auto w-full object-contain border-none\" muted loop autoPlay playsInline>\n\t\t\t\t\t\t\t\t\t<source src={gender === GenderType.Male ? maleMeasurementProgress : measurementProgress} type=\"video/mp4\" />\n\t\t\t\t\t\t\t\t</video>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{showNextButton && <SpecificButton resolvedConfig={config} className=\"!w-[180px] mx-auto\" buttonText={translate?.(LanguageKeys.next)} buttonFunc={onScanSuccess && onScanSuccess} />}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</Drawer>\n\t\t\t</div>\n\t\t</Box>\n\t);\n}\nexport default SignUp;\n","\"use client\";\nimport { useContext, useEffect } from \"react\";\nimport AngleDetector from \"./AngleDetector\";\nimport CameraPermission from \"./CameraPermission\";\nimport Modal from \"../Modal\";\nimport { Drawer } from \"@mui/material\";\nimport ScanErrorMessage from \"./ScanErrorMessage\";\nimport LoadingScreen from \"../LoadingScreen\";\nimport SignUp from \"../Signup\";\nimport { LanguageContext } from \"../../utils/context/languageContext\";\nimport { useLocalConfig } from \"../../config/useLocalConfig\";\nimport ParamsContext from \"../../utils/context/paramsContext\";\n\nexport const BodyScanSteps = () => {\n\tconst {\n\t\tuserDetails,\n\t\tconfig,\n\t\tonRetry,\n\t\tisError,\n\t\tisSuccess,\n\t\tonScanSuccess,\n\t\tgender,\n\t\tscanUniqueKey,\n\t\tscanFailsError,\n\t\tsetScanUniqueKey,\n\t\tsetIsVideoUploaded,\n\t\tisMeasurementAvailable,\n\t\tisVideoUploadedCorrect,\n\t\tloading,\n\t\tshowDeniedModal,\n\t\tuploadLoading,\n\t\tsetStartGyro,\n\t\thandleFileUpload,\n\t\tsetUploadLoading,\n\t\tsetScanFailsError,\n\t\tsetScanStartTime,\n\t\thandleShowStreamCamera,\n\t} = useContext(ParamsContext);\n\tconst { setPreferredLanguage } = useContext(LanguageContext) || {};\n\tconst resolvedConfig = useLocalConfig(config);\n\n\tuseEffect(() => {\n\t\tsetPreferredLanguage?.(resolvedConfig?.language);\n\t}, [resolvedConfig]);\n\n\tif (isError) {\n\t\treturn (\n\t\t\t<>\n\t\t\t\t<CameraPermission />\n\t\t\t\t<Drawer\n\t\t\t\t\tanchor=\"bottom\"\n\t\t\t\t\topen={true}\n\t\t\t\t\tclassName=\"camera-drawer\"\n\t\t\t\t\tonClose={(event, reason) => {\n\t\t\t\t\t\tif (reason === \"backdropClick\") {\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<ScanErrorMessage\n\t\t\t\t\t\tscanFailsError={scanFailsError || isError}\n\t\t\t\t\t\tonNext={() => {\n\t\t\t\t\t\t\t// onRetry?.();\n\t\t\t\t\t\t\t// handleShowStreamCamera();\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tsetScanUniqueKey={setScanUniqueKey}\n\t\t\t\t\t\tgender={gender}\n\t\t\t\t\t\tresolvedConfig={resolvedConfig}\n\t\t\t\t\t\tsetIsVideoUploaded={setIsVideoUploaded}\n\t\t\t\t\t/>\n\t\t\t\t</Drawer>\n\t\t\t</>\n\t\t);\n\t}\n\n\tif (isSuccess) {\n\t\treturn (\n\t\t\t<SignUp\n\t\t\t\tisFaceScan={false}\n\t\t\t\tscanId={scanUniqueKey}\n\t\t\t\tisMeasurementAvailable={isMeasurementAvailable}\n\t\t\t\tuserDetails={userDetails}\n\t\t\t\t// onComplete={onComplete}\n\t\t\t\tisVideoUploadedCorrect={isVideoUploadedCorrect}\n\t\t\t\tconfig={resolvedConfig}\n\t\t\t\tisSuccess={isSuccess}\n\t\t\t/>\n\t\t);\n\t}\n\n\tif (loading) {\n\t\treturn (\n\t\t\t<div className=\"flex top-0 !mt-0 left-0 z-[999] absolute justify-center items-center w-full h-full\"\n style={{ background: resolvedConfig?.style?.base?.backgroundColor }}\n >\n\t\t\t\t<LoadingScreen url={resolvedConfig?.loader} loaderType=\"black\" />\n\t\t\t</div>\n\t\t);\n\t}\n\tif (showDeniedModal.disabled) {\n\t\treturn <Modal />;\n\t}\n\n\tif (!uploadLoading && !scanFailsError) {\n\t\treturn (\n\t\t\t<AngleDetector\n\t\t\t\tconfig={resolvedConfig}\n\t\t\t\tscanID={scanUniqueKey}\n\t\t\t\tuserDetails={userDetails}\n\t\t\t\tsetIsVideoUploaded={setIsVideoUploaded}\n\t\t\t\tsetScanFailsError={setScanFailsError}\n\t\t\t\tsetScanStartTime={setScanStartTime}\n\t\t\t\tsetScanUniqueKey={setScanUniqueKey}\n\t\t\t/>\n\t\t);\n\t}\n\tif ((uploadLoading || isMeasurementAvailable) && !scanFailsError) {\n\t\treturn (\n\t\t\t<SignUp\n\t\t\t\tisFaceScan={false}\n\t\t\t\tscanId={scanUniqueKey}\n\t\t\t\tisMeasurementAvailable={isMeasurementAvailable}\n\t\t\t\tuserDetails={userDetails}\n\t\t\t\tonScanSuccess={onScanSuccess}\n\t\t\t\tisVideoUploadedCorrect={isVideoUploadedCorrect}\n\t\t\t\tconfig={resolvedConfig}\n\t\t\t/>\n\t\t);\n\t}\n\treturn (\n\t\t<>\n\t\t\t<CameraPermission />\n\t\t\t<Drawer\n\t\t\t\tanchor=\"bottom\"\n\t\t\t\topen\n\t\t\t\tclassName=\"camera-drawer\"\n\t\t\t\tonClose={(event, reason) => {\n\t\t\t\t\tif (reason === \"backdropClick\") {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}}\n\t\t\t>\n\t\t\t\t<ScanErrorMessage\n\t\t\t\t\tscanFailsError={scanFailsError}\n\t\t\t\t\tonNext={() => {\n\t\t\t\t\t\tonRetry?.();\n\t\t\t\t\t\thandleShowStreamCamera();\n\t\t\t\t\t}}\n\t\t\t\t\tsetScanUniqueKey={setScanUniqueKey}\n\t\t\t\t\tgender={gender}\n\t\t\t\t\tresolvedConfig={resolvedConfig}\n\t\t\t\t\tsetIsVideoUploaded={setIsVideoUploaded}\n\t\t\t\t/>\n\t\t\t</Drawer>\n\t\t</>\n\t);\n};\n","\"use client\";\n\"use client\";\nimport { useCallback, useEffect, useState } from \"react\";\nimport posthog from \"posthog-js\";\nimport useGyroSensor from \"../../customHooks/useGyroSensor\";\nimport { checkCameraPermission, createObjectMetadataArray, generateUuid, getCurrentTimeInSeconds, handleErrorMessage, handleScanTimeCapture, handleWebSocketCapture } from \"../../utils/utils\";\nimport LanguageContextProvider from \"../../utils/context/languageContext\";\nimport swan from \"../../utils/service/swanService\";\nimport { posthogPublicHost, posthogPublicKey } from \"../../utils/constants\";\nimport ParamsContext from \"../../utils/context/paramsContext\";\nimport MediaContextProvider from \"../../utils/context/mediaContext\";\nimport { BodyScanProps } from \"../../bodyScan\";\nimport { BodyScanSteps } from \"./BodyScanSteps\";\n\nconst clothesFit = \"0\";\n\nexport const BodyScan: React.FC<BodyScanProps> = ({ userDetails, config, onRetry, onScanError, isError, isSuccess, onScanSuccess }) => {\n\tconst { gender, scanType, shopDomain, heightInCm, email, deviceFocalLength, deviceModelName, callbackUrl } = userDetails;\n\tconst [uploadLoading, setUploadLoading] = useState(false);\n\tconst [isVideoUploadedCorrect, setIsVideoUploadedCorrect] = useState(false);\n\tconst [isMeasurementAvailable, setIsMeasurementAvailable] = useState(false);\n\tconst [showDeniedModal, setShowDeniedModal] = useState({\n\t\tdisabled: false,\n\t\tmessage: \"\",\n\t});\n\tconst [scanFailsError, setScanFailsError] = useState(\"\");\n\tconst [isVideoUploaded, setIsVideoUploaded] = useState(false);\n\tconst [loading, setLoading] = useState(true);\n\tconst [startGyro, setStartGyro] = useState(false);\n\tconst [scanUniqueKey, setScanUniqueKey] = useState(\"\");\n\tconst [scanStartTime, setScanStartTime] = useState<number | null>(getCurrentTimeInSeconds());\n\tconst { gyroData } = useGyroSensor(startGyro);\n\n\tconst handleShowStreamCamera = useCallback(() => {\n\t\tsetScanUniqueKey(generateUuid());\n\t\tsetScanFailsError(\"\");\n\t\tsetUploadLoading(false);\n\t\tsetIsVideoUploaded(false);\n\t}, []);\n\n\tconst onError = (data: any) => {\n\t\tonScanError({ ...data, message: handleErrorMessage(data) });\n\t\tclearScanStartTimeAndScanId();\n\t\tsetIsMeasurementAvailable(false);\n\t\tsetScanFailsError(data);\n\t\tsetIsVideoUploadedCorrect(false);\n\t\thandleScanTimeCapture({\n\t\t\teventName: `${shopDomain}/measurement_failed/fit-view`,\n\t\t\tscanID: scanUniqueKey,\n\t\t\tstatus: \"failed\",\n\t\t\temail,\n\t\t\tmessage: handleErrorMessage(data),\n\t\t});\n\t\tif (scanStartTime)\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: `${shopDomain}/scan_completion_time`,\n\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\tstatus: \"failed\",\n\t\t\t\tcompletionTime: getCurrentTimeInSeconds() - scanStartTime,\n\t\t\t\temail,\n\t\t\t});\n\t};\n\n\tconst clearScanStartTimeAndScanId = () => {\n\t\tsetScanStartTime(null);\n\t\tsetScanUniqueKey(\"\");\n\t};\n\n\tconst onSuccess = useCallback(\n\t\tasync (data: any) => {\n\t\t\tif (data && data?.scanStatus === \"success\" && data?.resultType === \"intermediate\" && data?.code === 200) {\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: `${shopDomain}/measurement_success/intermediate`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t\t// onScanSuccess?.(data);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tclearScanStartTimeAndScanId();\n\t\t\tconst scanIdToSet = scanUniqueKey;\n\t\t\tsetIsMeasurementAvailable(true);\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: `${shopDomain}/measurement_success/fit-view`,\n\t\t\t\tscanID: scanIdToSet,\n\t\t\t\tstatus: \"success\",\n\t\t\t\temail,\n\t\t\t});\n\t\t\tif (scanStartTime)\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: `${shopDomain}/scan_completion_time`,\n\t\t\t\t\tscanID: scanIdToSet,\n\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\tcompletionTime: getCurrentTimeInSeconds() - scanStartTime,\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t},\n\t\t[scanType, shopDomain, scanUniqueKey],\n\t);\n\n\tconst handleMeasurementRecommendation = (scanId?: string) => {\n\t\tsetIsMeasurementAvailable(false);\n\t\tsetScanFailsError(\"\");\n\t\tsetIsVideoUploadedCorrect(false);\n\t\tswan.measurement.handleMeasurementSocket({\n\t\t\tscanId: scanId || scanUniqueKey,\n\t\t\tonOpen: () => {\n\t\t\t\thandleWebSocketCapture({\n\t\t\t\t\teventName: `${shopDomain}/webSocket`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tconnection: \"open\",\n\t\t\t\t\ttype: \"measurement_recommendation\",\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t},\n\t\t\tonClose: () =>\n\t\t\t\thandleWebSocketCapture({\n\t\t\t\t\teventName: `${shopDomain}/webSocket`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tconnection: \"close\",\n\t\t\t\t\ttype: \"measurement_recommendation\",\n\t\t\t\t\temail,\n\t\t\t\t}),\n\t\t\tonError: (err) => {\n\t\t\t\tonError(err);\n\t\t\t\thandleWebSocketCapture({\n\t\t\t\t\teventName: `${shopDomain}/webSocket`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tconnection: \"error\",\n\t\t\t\t\ttype: \"measurement_recommendation\",\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t},\n\t\t\tonSuccess: (data) => {\n\t\t\t\thandleWebSocketCapture({\n\t\t\t\t\teventName: `${shopDomain}/webSocket`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tconnection: \"success\",\n\t\t\t\t\ttype: \"measurement_recommendation\",\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t\tonSuccess(data);\n\t\t\t},\n\t\t});\n\t};\n\n\tconst handleFileUpload = useCallback(\n\t\tasync (file: File) => {\n\t\t\tconst arrayMetaData = createObjectMetadataArray({\n\t\t\t\tgender,\n\t\t\t\tfocal_length: `${deviceFocalLength}`,\n\t\t\t\theight: `${heightInCm}`,\n\t\t\t\tcustomer_store_url: shopDomain,\n\t\t\t\tclothes_fit: clothesFit,\n\t\t\t\tscan_type: scanType,\n\t\t\t\tcallback_url: callbackUrl || \"https://example.com/webhook\",\n\t\t\t});\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: `${shopDomain}/body_scan_meta_data`,\n\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\temail,\n\t\t\t\tdata: JSON.stringify(arrayMetaData),\n\t\t\t});\n\t\t\ttry {\n\t\t\t\tawait swan.fileUpload.uploadFileFrontend({\n\t\t\t\t\tfile,\n\t\t\t\t\tarrayMetaData,\n\t\t\t\t\tscanId: scanUniqueKey,\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t\tawait swan.fileUpload.setDeviceInfo({\n\t\t\t\t\tmodel: deviceModelName,\n\t\t\t\t\tdetection: \"manual\",\n\t\t\t\t\tgyro: gyroData,\n\t\t\t\t\tscanId: scanUniqueKey,\n\t\t\t\t});\n\t\t\t\tconsole.log(\"video successfully uploaded\");\n\t\t\t\tsetIsVideoUploaded(false);\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: `${shopDomain}/scan_success`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\temail,\n\t\t\t\t\tdata: JSON.stringify(arrayMetaData),\n\t\t\t\t});\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: \"scan finished\",\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\temail,\n\t\t\t\t});\n\t\t\t\tsetScanStartTime(getCurrentTimeInSeconds());\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tsetIsVideoUploaded(true);\n\t\t\t\t}, 3000);\n\t\t\t} catch (error) {\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: \"scan finished\",\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tstatus: \"failed\",\n\t\t\t\t\temail,\n\t\t\t\t\tmessage: handleErrorMessage(error),\n\t\t\t\t});\n\t\t\t\thandleScanTimeCapture({\n\t\t\t\t\teventName: `${shopDomain}/scan_failed`,\n\t\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\t\tstatus: \"failed\",\n\t\t\t\t\temail,\n\t\t\t\t\tmessage: handleErrorMessage(error),\n\t\t\t\t\tdata: JSON.stringify(arrayMetaData),\n\t\t\t\t});\n\t\t\t\tsetScanFailsError(handleErrorMessage(error));\n\t\t\t\tsetIsVideoUploaded(false);\n\t\t\t\tconsole.log(error, \"video upload failed\");\n\t\t\t} finally {\n\t\t\t\tsetStartGyro(false);\n\t\t\t}\n\t\t},\n\t\t[scanUniqueKey, gyroData],\n\t);\n\tconst checkMeasurementStatus = useCallback(\n\t\tasync (scanId: string) => {\n\t\t\ttry {\n\t\t\t\tconst res = await swan.measurement.getMeasurementResult(scanId);\n\t\t\t\tconst isMeasured = res?.data?.isMeasured;\n\t\t\t\tconst tempScanStartTime = scanStartTime || getCurrentTimeInSeconds();\n\t\t\t\tconst currentTimeInSeconds = getCurrentTimeInSeconds();\n\t\t\t\tconst fiveMinutesInSeconds = 5 * 60;\n\t\t\t\tsetLoading(false);\n\t\t\t\tif (isMeasured === false) {\n\t\t\t\t\tclearScanStartTimeAndScanId();\n\t\t\t\t\tsetScanUniqueKey(generateUuid());\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tsetUploadLoading(true);\n\t\t\t\tif (isMeasured === true) {\n\t\t\t\t\tawait onSuccess(null);\n\t\t\t\t} else if (isMeasured === null && tempScanStartTime > currentTimeInSeconds + fiveMinutesInSeconds) {\n\t\t\t\t\tonError(res?.data?.error);\n\t\t\t\t} else {\n\t\t\t\t\thandleMeasurementRecommendation(scanId);\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tconsole.log(error);\n\t\t\t\tclearScanStartTimeAndScanId();\n\t\t\t\tsetScanUniqueKey(generateUuid());\n\t\t\t\tsetUploadLoading(false);\n\t\t\t}\n\t\t},\n\t\t[onError, onSuccess, setScanUniqueKey],\n\t);\n\n\tconst handleCameraPermission = useCallback(async () => {\n\t\tif (+heightInCm < 152.4 || +heightInCm > 213.36) {\n\t\t\tonScanError({\n\t\t\t\tmessage: \"Height must be between 152.4cm (5ft) and 213.36cm (7ft)\",\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\n\t\tconst permission = await checkCameraPermission();\n\t\tif (permission.disabled) {\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: `${shopDomain}/camera_activation`,\n\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\tstatus: \"failed\",\n\t\t\t\temail,\n\t\t\t});\n\t\t\tsetLoading(false);\n\t\t} else {\n\t\t\tconst scanId = scanUniqueKey;\n\t\t\tif (scanId) {\n\t\t\t\tcheckMeasurementStatus(scanId);\n\t\t\t} else {\n\t\t\t\tsetLoading(false);\n\t\t\t}\n\t\t\thandleScanTimeCapture({\n\t\t\t\teventName: `${shopDomain}/camera_activation`,\n\t\t\t\tscanID: scanUniqueKey,\n\t\t\t\tstatus: \"success\",\n\t\t\t\temail,\n\t\t\t});\n\t\t}\n\t\tsetShowDeniedModal(permission);\n\t\tsetScanFailsError(\"\");\n\t\tsetIsVideoUploaded(false);\n\t}, [checkMeasurementStatus, email, scanUniqueKey, setScanUniqueKey, shopDomain]);\n\n\tuseEffect(() => {\n\t\tposthog.init(posthogPublicKey, { api_host: posthogPublicHost });\n\t\tposthog.capture(\"$pageview\");\n\t}, []);\n\n\tuseEffect(() => {\n\t\tif (isError || isSuccess) return;\n\t\tif (shopDomain) {\n\t\t\thandleCameraPermission();\n\t\t}\n\t}, [shopDomain, heightInCm, isError, isSuccess]);\n\n\tuseEffect(() => {\n\t\tif (isError || isSuccess) return;\n\t\tif (isVideoUploaded && shopDomain && scanUniqueKey) {\n\t\t\thandleMeasurementRecommendation();\n\t\t}\n\t}, [isVideoUploaded, shopDomain, scanUniqueKey, isError, isSuccess]);\n\treturn (\n\t\t<LanguageContextProvider>\n\t\t\t<MediaContextProvider>\n\t\t\t\t<ParamsContext.Provider\n\t\t\t\t\tvalue={{\n\t\t\t\t\t\tuserDetails,\n\t\t\t\t\t\tconfig,\n\t\t\t\t\t\tonRetry,\n\t\t\t\t\t\tonScanError,\n\t\t\t\t\t\tisError,\n\t\t\t\t\t\tisSuccess,\n\t\t\t\t\t\tonScanSuccess,\n\t\t\t\t\t\tgender,\n\t\t\t\t\t\tscanUniqueKey,\n\t\t\t\t\t\tscanFailsError,\n\t\t\t\t\t\tsetScanUniqueKey,\n\t\t\t\t\t\tsetIsVideoUploaded,\n\t\t\t\t\t\tisMeasurementAvailable,\n\t\t\t\t\t\tisVideoUploadedCorrect,\n\t\t\t\t\t\tloading,\n\t\t\t\t\t\tshowDeniedModal,\n\t\t\t\t\t\tuploadLoading,\n\t\t\t\t\t\tsetStartGyro,\n\t\t\t\t\t\thandleFileUpload,\n\t\t\t\t\t\tsetUploadLoading,\n\t\t\t\t\t\thandleShowStreamCamera,\n\t\t\t\t\t\tsetScanFailsError,\n\t\t\t\t\t\tsetScanStartTime,\n\t\t\t\t\t}}\n\t\t\t\t>\n\t\t\t\t\t<BodyScanSteps />\n\t\t\t\t</ParamsContext.Provider>\n\t\t\t</MediaContextProvider>\n\t\t</LanguageContextProvider>\n\t);\n};\n","import { useCallback, useEffect, useState } from \"react\";\n\ninterface GyroDataItem {\n alpha?: string;\n beta?: string;\n gamma?: string;\n timestamp?: string;\n}\n\nexport interface IOSDeviceOrientationEvent extends DeviceOrientationEvent {\n requestPermission?: () => Promise<PermissionState>;\n}\n\nfunction useGyroSensor(startGyro: boolean) {\n const [gyroData, setGyroData] = useState<GyroDataItem[]>([]);\n const [permissionGranted, setPermissionGranted] = useState(false);\n\n const handleOrientation = useCallback((event: DeviceOrientationEvent) => {\n try {\n const { alpha, beta, gamma } = event;\n setGyroData((prev: GyroDataItem[]) => [\n ...prev,\n {\n alpha: alpha?.toString() || undefined,\n beta: beta?.toString() || undefined,\n gamma: gamma?.toString() || undefined,\n timestamp: new Date().toISOString(),\n },\n ]);\n } catch (error) {\n console.log(error);\n }\n }, []);\n\n const requestPermission = useCallback(async () => {\n const DeviceOrientation =\n DeviceOrientationEvent as unknown as IOSDeviceOrientationEvent;\n\n if (\n typeof DeviceOrientation !== \"undefined\" &&\n typeof DeviceOrientation.requestPermission === \"function\"\n ) {\n try {\n const response = await DeviceOrientation.requestPermission();\n if (response === \"granted\") {\n setPermissionGranted(true);\n } else {\n console.warn(\"Device orientation permission denied.\");\n }\n } catch (error) {\n console.error(\"Error requesting device orientation permission:\", error);\n }\n } else {\n // Permission not required on non-iOS devices\n setPermissionGranted(true);\n }\n }, []);\n\n useEffect(() => {\n if (startGyro && permissionGranted) {\n window.addEventListener(\"deviceorientation\", handleOrientation);\n } else {\n setGyroData([]);\n }\n return () => {\n window.removeEventListener(\"deviceorientation\", handleOrientation);\n };\n }, [startGyro, permissionGranted, handleOrientation]);\n\n useEffect(() => {\n if (startGyro) {\n requestPermission();\n }\n }, [startGyro, requestPermission]);\n\n return { gyroData };\n}\n\nexport default useGyroSensor;\n"],"names":["MEDIA_TYPES","MediaContext","createContext","undefined","MediaContextProvider","children","size","setSize","useState","window","innerWidth","innerHeight","clearInputs","setClearInputs","updateSize","useEffect","useLayoutEffect","addEventListener","removeEventListener","media","mediaDetails","useMemo","_jsx","Provider","value","SwitchIcon$1","React","memo","_jsxs","width","height","viewBox","fill","xmlns","d","stroke","strokeWidth","strokeLinecap","strokeLinejoin","LevelScreen$1","angle","countdown","isScanning","isInTargetRange","stabilityScore","config","translate","useContext","LanguageContext","getProximityToTarget","useCallback","Math","max","min","backgroundColor","style","angleDetector","successAngleBackground","proximity","successAngleLowBackground","round","handelTextColour","isLight","successAngleTextLightColor","successAngleTextDarkColor","getTextColor","handelColourCode","getColorCode","cd","fixVh","document","documentElement","setProperty","className","Header","noTitle","resolvedConfig","border","fontFamily","base","baseFontFamily","color","cn","transform","transition","SwitchIcon","LanguageKeys","startLevelCheck","leavePhone","placePhoneUpright","CameraScanChild","handleShowStreamCamera","loadingCam","handleUserMedia","handlePause","pause","recordingStarted","startSendingVideoFrames","showPause","webcamRef","resetDetector","onClick","X","Webcam","audio","ref","screenshotQuality","videoConstraints","mirrored","screenshotFormat","onUserMedia","position","top","bottom","zIndex","objectFit","SpecificButton","prefix","pauseIcon","buttonText","buttonFunc","btnSecondary","restart","startScan","disabled","id","crossOrigin","preload","src","voiceOverAssetsPath","globalLoadingPromise","globalDetector","globalPoseLib","audioTimeoutId","lastVideoPlayed","ScanningComponent$1","setIsScanLocked","scanID","setIsVideoUploaded","setScanFailsError","setScanStartTime","setScanUniqueKey","userDetails","gender","heightInCm","email","shopDomain","useRef","mediaRecorderRef","recordedChunks","setRecordedChunks","setLoadingCam","setRecordingStarted","faceDone","setFaceDone","mediaRecorderStopped","setMediaRecorderStopped","setIsScanning","captureVideoTimeOutHandle","audioSource","setAudioSource","audioSourceList","setAudioSourceList","emptyAudioSource","setEmptyAudioSource","startAgain","setStartAgain","showRestart","setRestart","setPause","events","setEvents","setShowPause","allowAudioToPlay","poseDetector","consecutiveFronts","setConsecutiveFronts","spinPhase","setSpinPhase","isLoaded","setIsLoaded","spinPhaseRef","consecutiveFrontsRef","mounted","async","loadDependenciesGlobal","navigator","console","log","poseLib","tfjsCore","tfjsBackend","Promise","all","resolve","then","require","import","setBackend","ready","modelConfig","runtime","modelType","solutionPath","createDetector","SupportedModels","BlazePose","mediapipeError","warn","error","isFrontFrame","body","length","filter","p","current","success","s","callback","video","readyState","poses","estimatePoses","flipHorizontal","keypoints","slice","map","kp","x","y","score","prev","err","retryLoading","useTensorFlow","firstScan","poseStoppedRef","supportedTypes","setSupportedTypes","counter","setStartGyro","handleFileUpload","setUploadLoading","ParamsContext","clearTimeout","generateUuid","speechService","stopAudio","stop","forEach","el","setTimeout","handleReScan","rescanSupportCaptureEvent","eventName","status","swan","poseDetection","disconnect","stopRecording","playAudio","handleSocket","connect","posthog","capture","handleSpinDataAvailable","data","concat","handleScanTimeCapture","message","handleStartCaptureClick","stream","mediaRecorderOptions","mimeType","MediaRecorder","start","e","postPoseProcess","handleDataAvailable","connected","poseStatus","querySelector","sid","paused","audioName","no_of_times_skipped","skipCount","getScreenshot","videoEmit","image","scanId","getCurrentTimeInSeconds","push","bypassChecksToBackup","videoFile","File","type","supported","videoTypes","isTypeSupported","AngleDetector","setAngle","calibrationOffset","setCalibrationOffset","setCountdown","setStabilityScore","lastAnglesRef","isScanLocked","calibratedAngle","DeviceOrientationEvent","handleOrientation","event","beta","newAngle","abs","gamma","cos","PI","requestPermission","DeviceOrientation","once","variation","resetCountdown","startCountdown","timer","setInterval","clearInterval","LevelScreen","ScanningComponent","Modal","Dialog","open","_Fragment","heading","headingFontFamily","fontSize","headingFontSize","headingColor","fontWeight","headingFontWeight","cameraAlreadyInUse","baseFontSize","baseTextColor","tryClosingBrowser","checkCameraSettings","setting","getBrowserName","enableCameraPermissions","CameraPermission","setShowDrawer","loader","showDeniedModal","setShowDeniedModal","loading","setLoading","handleCameraPermission","permission","checkCameraPermission","LoadingScreen","url","loaderType","VideoPlayer","link","onReady","wrapperClassName","videoReference","playerReference","videoJsOptions","autoplay","controls","responsive","fluid","muted","navigationUI","poster","videoPoster","player","videojs","updatedOptions","sources","isDisposed","dispose","playsInline","onDrag","preventDefault","ScanErrorMessage","scanFailsError","serverAtCapacity","onNext","showModal","setShowModal","handleShowModal","background","issueWithScan","reason","handleErrorMessage","VIDEO_POSTER_GENDER_BASED","alt","serverAtCapacityDescription","scanAgain","onClose","GENDER","PRE_LINK","male","SignUp","isFaceScan","isVideoUploadedCorrect","isMeasurementAvailable","onScanSuccess","isSuccess","deviceFocalLength","userName","scanType","isCustom","CLOTHING_CUSTOM_SCAN","CLOTHING_BANNER_SCAN","CLOTHING_CUSTOM_FIT_SCAN","includes","showDrawer","handleSignUp","auth","addUser","name","focalLength","clothesFit","showNextButton","Box","Drawer","_","anchor","title","measurementsBeingTaken","loop","autoPlay","GenderType","Male","maleMeasurementProgress","measurementProgress","next","BodyScanSteps","onRetry","isError","scanUniqueKey","uploadLoading","setPreferredLanguage","useLocalConfig","language","onScanError","deviceModelName","callbackUrl","setIsVideoUploadedCorrect","setIsMeasurementAvailable","isVideoUploaded","startGyro","scanStartTime","gyroData","setGyroData","permissionGranted","setPermissionGranted","alpha","toString","timestamp","Date","toISOString","useGyroSensor","onError","clearScanStartTimeAndScanId","completionTime","onSuccess","scanStatus","resultType","code","scanIdToSet","handleMeasurementRecommendation","measurement","handleMeasurementSocket","onOpen","handleWebSocketCapture","connection","file","arrayMetaData","createObjectMetadataArray","focal_length","customer_store_url","clothes_fit","scan_type","callback_url","JSON","stringify","fileUpload","uploadFileFrontend","setDeviceInfo","model","detection","gyro","checkMeasurementStatus","res","getMeasurementResult","isMeasured","tempScanStartTime","currentTimeInSeconds","fiveMinutesInSeconds","init","posthogPublicKey","api_host","posthogPublicHost","LanguageContextProvider"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import{jsx as e,jsxs as t,Fragment as n}from"react/jsx-runtime";import a,{useState as s,useCallback as r,useEffect as o,createContext as i,useLayoutEffect as l,useMemo as c,useContext as d,useRef as u}from"react";import m,{posthog as f}from"posthog-js";import{L as h,H as p,b as g,a as y,S as v,n as w,v as x,P as b,r as S,s as C,k as N,j as F,o as D,f as I,e as k,q as T,t as E,c as L,w as $,x as M,V as _,y as U,C as A,z,A as j,B as P,D as V,G as R,u as q,E as W,p as B,h as K,i as O,l as H}from"./LoadingScreen-dw8GNGG0.js";import G from"clsx";import J from"react-webcam";import{X as Q}from"lucide-react";import{Dialog as Y,Box as X,Drawer as Z}from"@mui/material";import ee from"video.js";const te="DESKTOP",ne="TAB",ae="MOBILE",se=i(void 0);function re({children:t}){const[n,a]=s([window?.innerWidth,window?.innerHeight]),[r,i]=s(!1),d=()=>{a([window?.innerWidth,window?.innerHeight])};o(()=>{d()},[]),l(()=>(window.addEventListener("resize",d),()=>window.removeEventListener("resize",d)),[d]);let u=te;n[0]>768&&n[0]<1024&&(u=ne),n[0]<768&&(u=ae);const m=c(()=>({size:n,setSize:a,clearInputs:r,setClearInputs:i,media:u}),[n,r,u]);return e(se.Provider,{value:m,children:t})}var oe=a.memo(function({size:n=16}){return t("svg",{width:n,height:n,viewBox:"0 0 25 25",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[e("path",{d:"M22.6968 14.6968C22.6968 16.8185 21.8539 18.8533 20.3536 20.3536C18.8533 21.8539 16.8185 22.6968 14.6968 22.6968",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e("path",{d:"M18.6968 11.6968V10.6968C18.6968 10.1663 18.4861 9.65764 18.111 9.28256C17.7359 8.90749 17.2272 8.69678 16.6968 8.69678C16.1663 8.69678 15.6576 8.90749 15.2826 9.28256C14.9075 9.65764 14.6968 10.1663 14.6968 10.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e("path",{d:"M14.6968 10.6968V9.69678C14.6968 9.16634 14.4861 8.65764 14.111 8.28256C13.7359 7.90749 13.2272 7.69678 12.6968 7.69678C12.1663 7.69678 11.6576 7.90749 11.2826 8.28256C10.9075 8.65764 10.6968 9.16634 10.6968 9.69678V10.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e("path",{d:"M10.6968 10.1968V4.69678C10.6968 4.16634 10.4861 3.65764 10.111 3.28256C9.73592 2.90749 9.22721 2.69678 8.69678 2.69678C8.16634 2.69678 7.65764 2.90749 7.28256 3.28256C6.90749 3.65764 6.69678 4.16634 6.69678 4.69678V14.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"}),e("path",{d:"M18.6969 11.6968C18.6969 11.1663 18.9076 10.6576 19.2827 10.2826C19.6577 9.90749 20.1664 9.69678 20.6969 9.69678C21.2273 9.69678 21.736 9.90749 22.1111 10.2826C22.4862 10.6576 22.6969 11.1663 22.6969 11.6968V14.6968C22.6969 16.8185 21.854 18.8533 20.3537 20.3536C18.8534 21.8539 16.8186 22.6968 14.6969 22.6968H12.6969C9.89688 22.6968 8.19688 21.8368 6.70688 20.3568L3.10688 16.7568C2.76282 16.3757 2.57847 15.8769 2.592 15.3637C2.60554 14.8505 2.81593 14.3621 3.1796 13.9997C3.54327 13.6373 4.03238 13.4287 4.54565 13.417C5.05892 13.4053 5.55704 13.5914 5.93688 13.9368L7.69688 15.6968",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})]})});var ie=a.memo(function({angle:n,countdown:a,isScanning:s,isInTargetRange:o,stabilityScore:i,children:l,config:u}){const{translate:m}=d(h)||{},f=r(()=>n<80?Math.max(0,Math.min(100,10*(n-60))):n>95?Math.max(0,Math.min(100,10*(105-n))):100,[n]),y=c(()=>{if(s)return u?.style?.angleDetector?.successAngleBackground||"#4f46e5";const e=f();if(0===e)return u?.style?.angleDetector?.successAngleLowBackground||"#ffffff";if(100===e)return u?.style?.angleDetector?.successAngleBackground||"#4f46e5";return`rgb(${Math.round(255-e/100*116)}, ${Math.round(255-e/100*163)}, ${Math.round(255-e/100*9)})`},[s,f]),v=r((e,t)=>t>70?e?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]/70`:`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]`:e?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]/40`:`text-[${u?.style?.angleDetector?.successAngleTextDarkColor}]/70`,[]),w=r((e=!1)=>{const t=f();return s?`text-[${u?.style?.angleDetector?.successAngleTextLightColor}]`:v(e,t)},[s,f]),x=r((e,t)=>t>70||e?u?.style?.angleDetector?.successAngleTextLightColor:u?.style?.angleDetector?.successAngleTextDarkColor,[]),b=r((e=!1)=>{const t=f();return s?u?.style?.angleDetector?.successAngleTextLightColor:x(e,t)},[s,f]),S=a;function C(){document.documentElement.style.setProperty("--real-vh",window.innerHeight+"px")}return C(),window.addEventListener("resize",C),t("div",{className:"flex w-screen flex-col items-center h-[var(--real-vh)] overflow-hidden touch-none justify-center transition-all duration-300 max-w-[28rem] mx-auto",style:{backgroundColor:y},children:[e("div",{className:"flex justify-start fixed top-[.5rem] max-w-[28rem] mx-auto w-full px-[1rem]",children:e("div",{className:"flex justify-start ",children:e(p,{noTitle:!0,resolvedConfig:u})})}),null!==S?e("div",{className:"relative flex h-[6rem] w-[6rem] items-center justify-center rounded-[9999px] bg-[#fff]/20 transition-all duration-300",style:{border:`2px solid ${b()}`},children:e("div",{className:`text-[3rem] font-bold text-[${b()}]`,style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:b()},children:S})}):t("div",s?{className:"relative flex flex-col items-center justify-center",children:[e("div",{className:"relative flex h-16 w-16 items-center justify-center rounded-[9999px] border-2 bg-[#fff]/30 border-[#fff]",children:e("div",{className:"h-4 w-4 rounded-[9999px] animate-pulse bg-[#fff]/80"})}),l]}:{className:G("relative flex h-[4rem] w-[4rem] items-center justify-center rounded-[9999px] ",o?"bg-[#fff]/20 border-[#fff]":"bg-[#fff]/10 border-[#fff]"),style:{transform:`translateY(${3*(90-n)}px)`,transition:"transform 0.2s ease-out",border:`2px solid ${b()}`},children:[e("div",{className:`h-[1rem] w-[1rem] rounded-[9999px] bg-[${b()}]/80`,style:{backgroundColor:`${b()}B3`}}),t("div",{className:G("mt-[.5rem] text-center w-[180px] flex-col flex items-center absolute top-[60px]",w()),style:{color:b()},children:[e(oe,{size:30}),t("p",{style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif"},children:[" ",m?.(g.startLevelCheck),e("br",{})]})]})]}),null!==S&&e("div",{className:"absolute bottom-[8rem] text-center",children:e("div",{className:G("text-sm font-medium px-4 py-1.5 bg-black/20 rounded-[9999px] mt-8",w()),style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:b()},children:m?.(g.leavePhone)})}),o&&null===S&&!s&&e("div",{className:"absolute bottom-[8rem] w-[12rem]",children:e("div",{className:`h-[.375rem] w-full bg-[${b()}]/20 rounded-[9999px] overflow-hidden`,style:{backgroundColor:`${b()}33`},children:e("div",{className:`h-full bg-[${b()}]/70 transition-all duration-300 rounded-[9999px]`,style:{width:`${n}%`,backgroundColor:`${b()}B3`}})})}),null===S&&!s&&e("div",{className:"absolute bottom-[5rem] text-center",children:t("div",{className:G("text-[1.5rem] font-light",w()),style:{color:b()},children:[Math.round(n),"°"]})}),null===S&&!s&&e("div",{className:"absolute bottom-[2rem] text-center max-w-[20rem] mx-auto",children:e("div",{className:G("text-[.75rem] opacity-50",w()),style:{fontFamily:u?.style?.base?.baseFontFamily||"Inter, sans-serif",color:b()},children:m?.(g.placePhoneUpright)})})]})});function le({handleShowStreamCamera:n,loadingCam:a,handleUserMedia:s,handlePause:r,pause:o,recordingStarted:i,startSendingVideoFrames:l,showPause:c,webcamRef:u,resetDetector:m,config:f}){const{media:p}=d(se)||{},{translate:b}=d(h)||{};return t("div",{className:"App w-screen h-[100vh] relative ",children:[e("span",{onClick:()=>{n(),m()},className:"fixed right-[20px] top-[20px] z-[999]",children:e(Q,{className:"text-[#fff]"})}),e("div",{className:"w-full h-full overflow-hidden ",children:p===ae&&e(J,{audio:!1,ref:u,screenshotQuality:1,videoConstraints:y,mirrored:!0,screenshotFormat:"image/jpeg",onUserMedia:s,style:{position:"fixed",top:0,bottom:0,zIndex:0,width:"100%",height:"100%",objectFit:"cover"}})}),t("div",{className:"fixed bottom-[30px] w-full z-[999] flex flex-col gap-4 items-center justify-center",children:[c&&e(v,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto ",prefix:w,buttonText:b?.(g.pause),buttonFunc:r,resolvedConfig:f,btnSecondary:!0}),o?e("div",{children:e(v,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto",buttonText:b?.(g.restart),buttonFunc:n,resolvedConfig:f,btnSecondary:!0})}):i?null:e(v,{className:"!w-[180px] !h-[40px] !py-[0] mx-auto !bg-[#ffffff] !text-[#000000] "+(a?"!opacity-50":""),buttonText:b?.(g.startScan),buttonFunc:l,disabled:a,resolvedConfig:f})]}),e("audio",{id:"audioElement",crossOrigin:"anonymous",preload:"auto",style:{position:"absolute",zIndex:-99999},src:`${x}scanAudioInstructions/silence.mp3`})]})}let ce=null,de=null,ue=null;let me,fe=null,he=null;var pe=a.memo(function({setIsScanLocked:t,resetDetector:n,scanID:a,setIsVideoUploaded:i,setScanFailsError:l,setScanStartTime:c,setScanUniqueKey:f,userDetails:h,config:p}){const{gender:g,heightInCm:y,email:v,shopDomain:w}=h,T=u(null),E=u(null),[L,$]=s([]),[M,_]=s(!0),[U,A]=s(!1),[z,j]=s(!1),[P,V]=s(!0),[R,q]=s(!1),W=u(null),[B,K]=s(""),[O,H]=s([]),[G,J]=s(""),[Q,Y]=s(!1),[X,Z]=s(!1),[ee,te]=s(!1),[ne,ae]=s([]),[se,re]=s(!1),oe=u(!0),{poseDetector:ie}=function(){const[e,t]=s(0),[n,a]=s(0),[r,i]=s(!1),l=u(0),c=u(0),d=u(!0);async function m(){if("undefined"==typeof window||"undefined"==typeof navigator)return!1;try{console.log("Starting TensorFlow preload...");const[e,t,n]=await Promise.all([import("./pose-detection.esm-qPaFsqLN.js"),import("@tensorflow/tfjs-core"),import("@tensorflow/tfjs-backend-webgl")]);ue=e,await t.setBackend("webgl"),await t.ready(),console.log("TensorFlow backend ready (WebGL)");const a={runtime:"mediapipe",modelType:"full",solutionPath:"https://cdn.jsdelivr.net/npm/@mediapipe/pose"};try{de=await ue.createDetector(ue.SupportedModels.BlazePose,a),console.log("MediaPipe detector created successfully")}catch(e){console.warn("MediaPipe failed, falling back to TFJS runtime:",e),de=await ue.createDetector(ue.SupportedModels.BlazePose,{runtime:"tfjs",modelType:"full"}),console.log("TFJS detector created successfully")}return!0}catch(e){return console.error("Failed to load TensorFlow dependencies:",e),ce=null,!1}}function f(e){return!(!e||0===e.length)&&22===e.filter(e=>e[2]>.7).length}return o(()=>{if(d.current=!0,!de)return ce||(ce=m()),ce.then(e=>{e&&d.current&&i(!0)}),()=>{d.current=!1};i(!0)},[]),o(()=>{c.current=e,e>6&&l.current<2&&(a(e=>e+1),t(0))},[e]),o(()=>{l.current=n},[n]),{poseDetector:async(e,n)=>{if(!de||!d.current||!n?.current?.video)return;const a=n.current.video;if(!(a.readyState<2))try{const n=await de.estimatePoses(a,{flipHorizontal:!1});if(!n||!n.length)return;const s=n[0].keypoints.slice(11).map(e=>[e.x>0&&e.x<720?e.x:-1,e.y>0&&e.y<1280?e.y:-1,e.score??0]);0!==l.current||f(s)||t(e=>e+1),1===l.current&&f(s)&&t(e=>e+1),2===l.current&&e()}catch(e){console.error("Pose detection error:",e)}},isLoaded:r,spinPhase:n,resetDetector:()=>{l.current=0,c.current=0,t(0),a(0)},retryLoading:async()=>{de||ce||(ce=m(),await ce&&d.current&&i(!0))}}}(),pe=u(!0),ge=u(!1),[ye,ve]=s([]);let we=0;const{setStartGyro:xe,handleFileUpload:be,setUploadLoading:Se}=d(b),Ce=()=>{ge.current=!1,clearTimeout(me),W.current&&clearTimeout(W.current),f(k()),l(""),Se?.(!1),$([]),_(!0),A(!1),j(!1),V(!0),q(!1),W.current=null,K(""),H([]),J(""),Y(!Q),xe(!1),C.stopAudio(),Z(!1),te(!1),we=0,null!==E.current&&E.current.stop(),ne.forEach(e=>{E.current&&E.current.removeEventListener("dataavailable",e)}),ae([]),oe.current=!0,re(!1),i(!1)},Ne=r(()=>{setTimeout(()=>{_(!1)},1e3)},[]),Fe=r(()=>{S({eventName:`${w}/rescan`,email:v,scanID:a,height:y,gender:g,status:!1}),oe.current=!1,Ce(),_e()},[Ce,a,v]),De=r(()=>{oe.current=!1,te(!0),re(!1),W.current&&clearTimeout(W.current),E.current&&E.current.pause(),C.stopAudio(),N.poseDetection.disconnect(),we=0,E.current&&E.current.stop(),ne.forEach(e=>{E.current&&E.current.removeEventListener("dataavailable",e)}),ae([]),clearTimeout(me)},[E,ne,C,oe]),Ie=r(async()=>{oe.current=!0,await C.playAudio(`${x}SpotOn.mp3`),te(!1),re(!1),W.current&&clearTimeout(W.current),A(!1)},[W,C]),ke=r(async()=>{try{fe=await N.poseDetection.connect(),m.capture(`${w}/pose_detection_connected`,{scanID:a,email:v,id:fe})}catch(e){console.log(e,"while connecting websocket")}},[a,w,v]),Te=r(({data:e})=>{e&&e.size>0&&oe.current&&($(t=>t.concat(e)),!ge.current&&T.current&&(ge.current=!0,ie(()=>{Ie(),F({eventName:`${w}/tensorFlow`,scanID:a,email:v,message:"recording stopped by tensorflow "})},T)))},[Ie,F,w,a,v,T]),Ee=r(async()=>{O.length>0&&oe.current&&(await C.playAudio(x+O[O.length-1]),oe.current&&(me=setTimeout(Ee,2e3)))},[O,oe]),Le=r(()=>{E&&E.current&&E.current.stop(),A(!0);try{if(T&&T.current&&T.current.stream){const e={mimeType:ye[0]};E.current=new MediaRecorder(T.current.stream,e),E.current.addEventListener("dataavailable",Te),ae([...ne,Te]),E.current.start(1e3),V(!1)}}catch(e){console.log("error while using media recorder",e)}},[T,ye,Te,ne]),$e=r(async()=>{W.current&&clearTimeout(W.current),Le(),oe.current&&(W.current=setTimeout(async()=>{oe.current&&(await C.playAudio(`${x}SpotOn.mp3`),A(!1))},15e3)),j(!0),oe.current&&await C.playAudio(`${x}Spin.mp3`)},[Le,oe,C]),Me=r(({data:e})=>{e.size>0&&N.poseDetection.connected()&&(N.poseDetection.poseStatus(async e=>{if(e&&e.audio&&e.audio.length>0){const t=document.querySelector("#audioElement");!0===e.status&&e.sid===fe?we<2?(0===we&&t?.paused&&await C.playAudio(x+e.audio),we+=1):(J(e.audio),clearTimeout(me),N.poseDetection.disconnect(),setTimeout($e,1e3)):(we=0,!t?.paused||he&&he?.audioName===e.audio?he?.audioName===e.audio&&t?.paused&&(he&&he.no_of_times_skipped>=he.skipCount?(he.no_of_times_skipped=0,C.playAudio(x+e.audio)):he&&(he.no_of_times_skipped+=1)):(he={skipCount:2,no_of_times_skipped:0,audioName:e.audio},C.playAudio(x+e.audio)))}}),T?.current&&null!==T.current.getScreenshot()&&N.poseDetection.videoEmit({image:T.current.getScreenshot()||"",scanId:a}))},[T,a,N,fe,we,$e,C]),_e=r(async()=>{q(!0),xe(!0),pe.current&&(pe.current=!1,F({eventName:"scan started",scanID:a,status:"success",email:v})),c(D()),_(!0),oe.current&&await C.playAudio(`${x}StartScan.mp3`),oe.current&&await C.playAudio(`${x}LiftArmsAndHoldAtHip.mp3`),oe.current&&(q(!1),A(!0),Z(!0),re(!0),Ne());try{if(T&&T.current&&T.current.stream&&oe.current){const e={mimeType:ye[0]};oe.current&&(E.current=new MediaRecorder(T.current.stream,e)),oe.current&&E.current&&E.current.addEventListener("dataavailable",Me),ae([...ne,Me]),E.current&&E.current.start(1e3),V(!1),oe.current&&(me=setTimeout(Ee,2e3))}}catch(e){console.log("error ----------",e)}},[T,ye,Me,ne,Ee,oe]);return o(()=>(w&&(t(!0),ke()),()=>{fe&&(N.poseDetection.disconnect(),m.capture(`${w}/pose_detection_disconnected`,{scanID:a,email:v,id:fe})),ne.forEach(e=>{E?.current?.removeEventListener("dataavailable",e)})}),[Q,w]),o(()=>{O.push(B)},[B]),o(()=>{H([])},[G]),o(()=>{const e=L.length&&L.length>0;P||!e||U||!oe.current||ee||E&&E.current&&(U||(E.current.stop(),V(!0)))},[P,U,L,ee]),o(()=>{const e=L.length&&L.length>0;if(P||!e||U)console.log("No video found to upload");else if(E&&E.current&&oe.current&&!ee&&!U){const e=new File(L,`${a}.webm`,{type:"video/webm"});Se?.(!0),l(""),be?.(e)}},[P,U,L,ee,E,oe]),o(()=>{if("undefined"!=typeof MediaRecorder){const e=I.filter(e=>MediaRecorder.isTypeSupported(e));ve(e)}},[]),o(()=>{Ce()},[]),e(le,{resetDetector:n,handleShowStreamCamera:Ce,loadingCam:M,handlePause:De,showRestart:X,pause:ee,handleReScan:Fe,recordingStarted:U,isScanning:R,startSendingVideoFrames:_e,faceDone:z,stopRecording:Ie,showPause:se,webcamRef:T,handleUserMedia:Ne,config:p})});function ge({scanID:t,userDetails:n,setIsVideoUploaded:a,setScanFailsError:r,setScanStartTime:i,setScanUniqueKey:l,config:c}){const[d,m]=s(90),[f,h]=s(0),[p,g]=s(null),[y,v]=s(!1),[w,x]=s(0),b=u([]),[S,C]=s(!1),N=d-f,F=N>=80&&N<=95;o(()=>{if("undefined"!=typeof window&&window.DeviceOrientationEvent){const e=e=>{if(null!==e.beta){let t=Math.abs(e.beta);null!==e.gamma&&(t*=Math.cos(e.gamma*Math.PI/180)),t=Math.max(0,Math.min(180,t)),m(t)}},t=async()=>{const t=DeviceOrientationEvent;if(t&&"function"==typeof t.requestPermission)try{"granted"===await t.requestPermission()&&window.addEventListener("deviceorientation",e)}catch(e){console.error("Permission error",e)}else window.addEventListener("deviceorientation",e);return()=>{e&&window.removeEventListener("deviceorientation",e)}};document.addEventListener("click",t,{once:!0})}},[]),o(()=>{if(b.current=[...b.current.slice(-4),N],b.current.length>=5){const e=Math.max(...b.current)-Math.min(...b.current);x(F&&e<2?e=>Math.min(100,e+10):e=>Math.max(0,e-20))}F||null===p&&!y||I()},[N,F,p,y]),o(()=>{w>=100&&null===p&&!y&&D(),w<50&&null!==p&&I()},[w,p,y]);const D=()=>{g(3);const e=setInterval(()=>{g(t=>null===t||t<=1?(clearInterval(e),v(!0),null):t-1)},1e3)},I=()=>{g(null),S||v(!1)};return e(ie,{angle:N,countdown:p,isScanning:y,isInTargetRange:F,stabilityScore:w,config:c,children:y&&e(pe,{setIsScanLocked:C,resetDetector:()=>{m(90),h(0),g(null),v(!1),x(0),C(!1),b.current=[]},scanID:t,userDetails:n,setIsVideoUploaded:a,setScanFailsError:r,setScanStartTime:i,setScanUniqueKey:l,config:c})})}function ye({message:a,config:s}){const{translate:r}=d(h)||{};return e(Y,{open:!0,className:"confirm-modal",children:e("div",{className:"modal-main",children:e("div",{className:"text-center",children:t(n,a?{children:[e("h2",{style:{fontFamily:s?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:s?.style?.heading?.headingFontSize||"32px",color:s?.style?.heading?.headingColor||"#000",fontWeight:s?.style?.heading?.headingFontWeight||"normal"},children:r?.(g.cameraAlreadyInUse)}),e("p",{className:"mt-[0.5rem] text-sm",style:{fontFamily:s?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:s?.style?.base?.baseFontSize||"16px",color:s?.style?.base?.baseTextColor||"#000"},children:r?.(g.tryClosingBrowser)})]}:{children:[e("h2",{style:{fontFamily:s?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:s?.style?.heading?.headingFontSize||"32px",color:s?.style?.heading?.headingColor||"#000",fontWeight:s?.style?.heading?.headingFontWeight||"normal"},children:r?.(g.checkCameraSettings)}),e("p",{className:"mt-[0.5rem] text-sm",style:{fontFamily:s?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:s?.style?.base?.baseFontSize||"16px",color:s?.style?.base?.baseTextColor||"#000"},children:`${r?.(g.setting)} > ${T()} > ${r?.(g.enableCameraPermissions)}`})]})})})})}function ve({setShowDrawer:t,config:n,loader:a}){const[i,l]=s({disabled:!1,message:""}),[c,d]=s(!0),m=u(null),f=r(async()=>{const e=await E();l(e),d(!1)},[]);return o(()=>{f()},[]),c?e(L,{url:a,loaderType:"black"}):i?.disabled?e(ye,{config:n,message:i?.message}):e(J,{audio:!1,ref:m,screenshotQuality:1,videoConstraints:y,mirrored:!0,onUserMedia:()=>t?.(!0),screenshotFormat:"image/jpeg",style:{position:"relative",top:0,bottom:0,zIndex:0,width:"100%",height:"100%",objectFit:"cover"}})}function we({link:t,onReady:n,wrapperClassName:a="[&_video]:rounded-t-[20px] w-full h-full"}){const s=u(null),r=u(null);let i={autoplay:!0,controls:!1,responsive:!0,fluid:!0,muted:!0,navigationUI:"hide",preload:"metadata",poster:$};return o(()=>{if(!r.current&&t&&s?.current){const e=ee(s.current,{...i});e.ready(()=>{r.current=e;const a={...i,sources:[{src:t,type:"application/x-mpegURL"}]};e.autoplay(a.autoplay),e.src(a.sources),n?.(e)})}},[t,s]),o(()=>{const e=r.current;return()=>{e&&!e.isDisposed()&&(e.dispose(),r.current=null)}},[r]),e("div",{className:a,children:e("video",{ref:s,muted:!0,className:"video-js",playsInline:!0,onDrag:e=>e.preventDefault()})})}function xe({scanFailsError:a,serverAtCapacity:r=!1,onNext:o,gender:i,setScanUniqueKey:l,resolvedConfig:c,setIsVideoUploaded:u}){const{translate:m}=d(h)||{},[f,y]=s(!1),w=()=>{y(!f)};return t(n,{children:[t("div",{className:"flex flex-col h-full max-w-[28rem] mx-auto w-full rounded-t-[20px] overflow-y-auto",style:{background:c?.style?.base?.backgroundColor},children:[e("div",{className:"w-full max-w-[28rem] mx-auto pt-[1rem] px-[1rem]",children:e(p,{noTitle:!0,resolvedConfig:c})}),t("div",{className:"flex-1",children:[a&&t("div",{className:"px-[1rem]",children:[e("h2",{className:"text-center",style:{fontFamily:c?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:c?.style?.heading?.headingFontSize||"32px",color:c?.style?.heading?.headingColor||"#000",fontWeight:c?.style?.heading?.headingFontWeight||"normal"},children:m?.(g.issueWithScan)}),e("p",{style:{fontFamily:c?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:c?.style?.base?.baseFontSize||"16px",color:c?.style?.base?.baseTextColor||"#1E1E1E"},children:m?.(g.reason)}),e("p",{style:{fontFamily:c?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:c?.style?.base?.baseFontSize||"16px",color:c?.style?.base?.baseTextColor||"#1E1E1E"},children:M(a)}),e("img",{className:"my-[0.5rem] aspect-[2/1.4] w-full object-cover",onClick:w,src:_[i],alt:"icon"})]}),r&&t("div",{className:"p-[1rem] text-center",children:[e("h3",{style:{fontFamily:c?.style?.heading?.headingFontFamily||"SeriouslyNostalgic Fn",fontSize:c?.style?.heading?.headingFontSize||"32px",color:c?.style?.heading?.headingColor||"#000",fontWeight:c?.style?.heading?.headingFontWeight||"normal"},children:m?.(g.serverAtCapacity)}),e("p",{className:"text-base mt-[0.5rem]",style:{fontFamily:c?.style?.base?.baseFontFamily||"Inter, sans-serif",fontSize:c?.style?.base?.baseFontSize||"16px",color:c?.style?.base?.baseTextColor||"#1E1E1E"},children:m?.(g.serverAtCapacityDescription)})]})]}),a&&e("div",{className:"p-[1rem] flex gap-[0.5rem]",children:e(v,{disabled:!1,buttonText:m?.(g.scanAgain),className:"!shadow-none",buttonFunc:()=>{o?o?.():l(k()),u(!1)},resolvedConfig:c})})]}),f&&t(Y,{className:"w-screen h-screen video-modal",onClose:w,open:f,children:[e("div",{className:"flex justifyEnd ",children:e("span",{className:"closeBtn",onClick:w,children:e(Q,{className:"absolute right-[8px] top-[8px] text-white z-[9]"})})}),e("div",{className:"aspect-video object-cover rounded-[20px] ",children:e(we,{link:i?U[i].PRE_LINK:U.male.PRE_LINK,wrapperClassName:"w-screen h-screen fixed top-[0] left-[0]"})})]})]})}function be({scanId:n,userDetails:a,config:i,isFaceScan:l,isVideoUploadedCorrect:c,isMeasurementAvailable:u,onScanSuccess:m,isSuccess:y}){const{gender:w,shopDomain:x,heightInCm:b,deviceFocalLength:S,userName:C,email:F,scanType:D}=a,I=[A,z,j].includes(D),[k,T]=s(!0),E=r(async()=>{try{I&&await N.auth.addUser({scanId:n,email:F,name:C,gender:w,height:b}),f.capture(x,{scanID:n,email:F,height:b,focalLength:S,clothesFit:"0",gender:w})}catch(e){console.log(e)}},[I]),{translate:L}=d(h)||{};o(()=>{c&&E()},[c]);const $=y||(l?u&&c:c||u);return e(X,{className:"flex h-full w-full flex-col ",children:t("div",{className:"h-full w-full flex-col items-center justify-center flex",children:[e(ve,{loader:i?.loader,setShowDrawer:T}),e(Z,{open:k,onClose:(e,t)=>{},className:"camera-drawer",anchor:"bottom",children:e("div",{className:"max-w-[28rem] mx-auto w-full h-full flex text-center flex-col justify-between items-center bg-primary rounded-t-[30px] p-[1rem]",style:{background:i?.style?.base?.backgroundColor},children:t("div",{className:"w-full h-full flex flex-col",children:[e(p,{title:L?.(g.measurementsBeingTaken),resolvedConfig:i}),e("div",{className:"flex items-center justify-center flex-1",children:e("video",{preload:"auto",className:"max-h-[calc(100vh-450px)] mx-auto w-full object-contain border-none",muted:!0,loop:!0,autoPlay:!0,playsInline:!0,children:e("source",{src:w===R.Male?P:V,type:"video/mp4"})})}),$&&e(v,{resolvedConfig:i,className:"!w-[180px] mx-auto",buttonText:L?.(g.next),buttonFunc:m&&m})]})})})]})})}const Se=()=>{const{userDetails:a,config:s,onRetry:r,isError:i,isSuccess:l,onScanSuccess:c,gender:u,scanUniqueKey:m,scanFailsError:f,setScanUniqueKey:p,setIsVideoUploaded:g,isMeasurementAvailable:y,isVideoUploadedCorrect:v,loading:w,showDeniedModal:x,uploadLoading:S,setStartGyro:C,handleFileUpload:N,setUploadLoading:F,setScanFailsError:D,setScanStartTime:I,handleShowStreamCamera:k}=d(b),{setPreferredLanguage:T}=d(h)||{},E=q(s);return o(()=>{T?.(E?.language)},[E]),i?t(n,{children:[e(ve,{}),e(Z,{anchor:"bottom",open:!0,className:"camera-drawer",onClose:(e,t)=>{},children:e(xe,{scanFailsError:f||i,onNext:()=>{},setScanUniqueKey:p,gender:u,resolvedConfig:E,setIsVideoUploaded:g})})]}):l?e(be,{isFaceScan:!1,scanId:m,isMeasurementAvailable:y,userDetails:a,isVideoUploadedCorrect:v,config:E,isSuccess:l}):w?e("div",{className:"flex top-0 !mt-0 left-0 z-[999] absolute justify-center items-center w-full h-full",style:{background:E?.style?.base?.backgroundColor},children:e(L,{url:E?.loader,loaderType:"black"})}):x.disabled?e(ye,{}):S||f?!S&&!y||f?t(n,{children:[e(ve,{}),e(Z,{anchor:"bottom",open:!0,className:"camera-drawer",onClose:(e,t)=>{},children:e(xe,{scanFailsError:f,onNext:()=>{r?.(),k()},setScanUniqueKey:p,gender:u,resolvedConfig:E,setIsVideoUploaded:g})})]}):e(be,{isFaceScan:!1,scanId:m,isMeasurementAvailable:y,userDetails:a,onScanSuccess:c,isVideoUploadedCorrect:v,config:E}):e(ge,{config:E,scanID:m,userDetails:a,setIsVideoUploaded:g,setScanFailsError:D,setScanStartTime:I,setScanUniqueKey:p})},Ce=({userDetails:t,config:n,onRetry:a,onScanError:i,isError:l,isSuccess:c,onScanSuccess:d})=>{const{gender:u,scanType:f,shopDomain:h,heightInCm:p,email:g,deviceFocalLength:y,deviceModelName:v,callbackUrl:w}=t,[x,S]=s(!1),[C,I]=s(!1),[T,L]=s(!1),[$,_]=s({disabled:!1,message:""}),[U,A]=s(""),[z,j]=s(!1),[P,V]=s(!0),[R,q]=s(!1),[G,J]=s(""),[Q,Y]=s(D()),{gyroData:X}=function(e){const[t,n]=s([]),[a,i]=s(!1),l=r(e=>{try{const{alpha:t,beta:a,gamma:s}=e;n(e=>[...e,{alpha:t?.toString()||void 0,beta:a?.toString()||void 0,gamma:s?.toString()||void 0,timestamp:(new Date).toISOString()}])}catch(e){console.log(e)}},[]),c=r(async()=>{const e=DeviceOrientationEvent;if(void 0!==e&&"function"==typeof e.requestPermission)try{"granted"===await e.requestPermission()?i(!0):console.warn("Device orientation permission denied.")}catch(e){console.error("Error requesting device orientation permission:",e)}else i(!0)},[]);return o(()=>(e&&a?window.addEventListener("deviceorientation",l):n([]),()=>{window.removeEventListener("deviceorientation",l)}),[e,a,l]),o(()=>{e&&c()},[e,c]),{gyroData:t}}(R),Z=r(()=>{J(k()),A(""),S(!1),j(!1)},[]),ee=e=>{i({...e,message:M(e)}),te(),L(!1),A(e),I(!1),F({eventName:`${h}/measurement_failed/fit-view`,scanID:G,status:"failed",email:g,message:M(e)}),Q&&F({eventName:`${h}/scan_completion_time`,scanID:G,status:"failed",completionTime:D()-Q,email:g})},te=()=>{Y(null),J("")},ne=r(async e=>{if(e&&"success"===e?.scanStatus&&"intermediate"===e?.resultType&&200===e?.code)return void F({eventName:`${h}/measurement_success/intermediate`,scanID:G,status:"success",email:g});te();const t=G;L(!0),F({eventName:`${h}/measurement_success/fit-view`,scanID:t,status:"success",email:g}),Q&&F({eventName:`${h}/scan_completion_time`,scanID:t,status:"success",completionTime:D()-Q,email:g})},[f,h,G]),ae=e=>{L(!1),A(""),I(!1),N.measurement.handleMeasurementSocket({scanId:e||G,onOpen:()=>{H({eventName:`${h}/webSocket`,scanID:G,connection:"open",type:"measurement_recommendation",email:g})},onClose:()=>H({eventName:`${h}/webSocket`,scanID:G,connection:"close",type:"measurement_recommendation",email:g}),onError:e=>{ee(e),H({eventName:`${h}/webSocket`,scanID:G,connection:"error",type:"measurement_recommendation",email:g})},onSuccess:e=>{H({eventName:`${h}/webSocket`,scanID:G,connection:"success",type:"measurement_recommendation",email:g}),ne(e)}})},se=r(async e=>{const t=W({gender:u,focal_length:`${y}`,height:`${p}`,customer_store_url:h,clothes_fit:"0",scan_type:f,callback_url:w||"https://example.com/webhook"});F({eventName:`${h}/body_scan_meta_data`,scanID:G,email:g,data:JSON.stringify(t)});try{await N.fileUpload.uploadFileFrontend({file:e,arrayMetaData:t,scanId:G,email:g}),await N.fileUpload.setDeviceInfo({model:v,detection:"manual",gyro:X,scanId:G}),console.log("video successfully uploaded"),j(!1),F({eventName:`${h}/scan_success`,scanID:G,status:"success",email:g,data:JSON.stringify(t)}),F({eventName:"scan finished",scanID:G,status:"success",email:g}),Y(D()),setTimeout(()=>{j(!0)},3e3)}catch(e){F({eventName:"scan finished",scanID:G,status:"failed",email:g,message:M(e)}),F({eventName:`${h}/scan_failed`,scanID:G,status:"failed",email:g,message:M(e),data:JSON.stringify(t)}),A(M(e)),j(!1),console.log(e,"video upload failed")}finally{q(!1)}},[G,X]),oe=r(async e=>{try{const t=await N.measurement.getMeasurementResult(e),n=t?.data?.isMeasured,a=Q||D(),s=D(),r=300;if(V(!1),!1===n)return te(),void J(k());S(!0),!0===n?await ne(null):null===n&&a>s+r?ee(t?.data?.error):ae(e)}catch(e){console.log(e),te(),J(k()),S(!1)}},[ee,ne,J]),ie=r(async()=>{if(+p<152.4||+p>213.36)return void i({message:"Height must be between 152.4cm (5ft) and 213.36cm (7ft)"});const e=await E();if(e.disabled)F({eventName:`${h}/camera_activation`,scanID:G,status:"failed",email:g}),V(!1);else{G?oe(G):V(!1),F({eventName:`${h}/camera_activation`,scanID:G,status:"success",email:g})}_(e),A(""),j(!1)},[oe,g,G,J,h]);return o(()=>{m.init(B,{api_host:K}),m.capture("$pageview")},[]),o(()=>{l||c||h&&ie()},[h,p,l,c]),o(()=>{l||c||z&&h&&G&&ae()},[z,h,G,l,c]),e(O,{children:e(re,{children:e(b.Provider,{value:{userDetails:t,config:n,onRetry:a,onScanError:i,isError:l,isSuccess:c,onScanSuccess:d,gender:u,scanUniqueKey:G,scanFailsError:U,setScanUniqueKey:J,setIsVideoUploaded:j,isMeasurementAvailable:T,isVideoUploadedCorrect:C,loading:P,showDeniedModal:$,uploadLoading:x,setStartGyro:q,handleFileUpload:se,setUploadLoading:S,handleShowStreamCamera:Z,setScanFailsError:A,setScanStartTime:Y},children:e(Se,{})})})})};export{Ce as B};
2
+ //# sourceMappingURL=BodyScan-BMSwRF8g.js.map