{"version":3,"file":"Counter.geJJTykX.mjs","names":[],"sources":["https:/framerusercontent.com/modules/gnoBSz9tfFAxm5KXzcBB/GuCVQ30Gv8CM10afK2bf/Counter.js"],"sourcesContent":["import{jsxs as _jsxs}from\"react/jsx-runtime\";import React,{useState,useEffect}from\"react\";import{motion}from\"framer-motion\";import{addPropertyControls,ControlType}from\"framer\";const NumberCounterStyles={display:\"flex\",justifyContent:\"left\",alignItems:\"left\"};export function NumberCounter(props){const{startNumber,endNumber,speed,prefix,suffix,loop,decimalSeparator,fontSize,font,fontColor}=props;const[count,setCount]=useState(startNumber);const[isVisible,setIsVisible]=useState(false);const ref=React.useRef(null);useEffect(()=>{const observer=new IntersectionObserver(entries=>{const entry=entries[0];setIsVisible(entry.isIntersecting);});if(ref.current){observer.observe(ref.current);}return()=>{if(ref.current){observer.unobserve(ref.current);}};},[]);useEffect(()=>{if(isVisible&&startNumber!==endNumber){const intervalId=setInterval(()=>{if(count<endNumber){setCount(prevCount=>prevCount+1);}else if(loop){setCount(startNumber);}},speed);return()=>{clearInterval(intervalId);};}},[count,startNumber,endNumber,loop,isVisible]);const formatCount=number=>{if(decimalSeparator===\"comma\"){return number.toLocaleString(\"en-US\");}else if(decimalSeparator===\"period\"){return number.toLocaleString(\"en-US\").replace(/,/g,\".\");}else{return number.toFixed(0);}};return /*#__PURE__*/ _jsxs(motion.div,{ref:ref,style:{...NumberCounterStyles,gap:`${fontSize/2}px`,flexDirection:\"row\",alignItems:\"left\",fontSize:`${fontSize}px`,fontFamily:font.fontFamily,fontWeight:font.fontWeight,color:fontColor},children:[prefix,formatCount(count),suffix]});}NumberCounter.defaultProps={startNumber:0,endNumber:10,speed:100,prefix:\"\",suffix:\"\",loop:false,decimalSeparator:\"comma\",fontSize:16,font:{fontFamily:\"Arial\",fontWeight:400,systemFont:true},fontColor:\"#707070\"};addPropertyControls(NumberCounter,{font:{title:\"Font\",type:ControlType.Font,defaultValue:{fontFamily:\"Arial\",fontWeight:400,systemFont:true}},fontSize:{title:\"Font Size\",type:ControlType.Number,min:8,max:200,step:1},fontColor:{type:ControlType.Color,title:\"Font Color\"},startNumber:{type:ControlType.Number,title:\"Start Number\",defaultValue:0,displayStepper:true},endNumber:{type:ControlType.Number,title:\"End Number\",defaultValue:10,displayStepper:true},decimalSeparator:{type:ControlType.Enum,title:\"Decimal Separator\",defaultValue:\"comma\",options:[\"comma\",\"period\",\"none\"],optionTitles:[\"Comma (1,000)\",\"Period (1.000)\",\"None\"]},speed:{type:ControlType.Number,title:\"Speed (ms)\",defaultValue:100,min:0,max:1e3,step:10},prefix:{type:ControlType.String,title:\"Prefix\",defaultValue:\"\"},suffix:{type:ControlType.String,title:\"Suffix\",defaultValue:\"\"},loop:{type:ControlType.Boolean,title:\"Loop Animation\",defaultValue:false,enabledTitle:\"On\",disabledTitle:\"Off\"}});\nexport const __FramerMetadata__ = {\"exports\":{\"NumberCounter\":{\"type\":\"reactComponent\",\"name\":\"NumberCounter\",\"slots\":[],\"annotations\":{\"framerContractVersion\":\"1\"}},\"__FramerMetadata__\":{\"type\":\"variable\"}}}\n//# sourceMappingURL=./Counter.map"],"mappings":"iWAAmQ,SAAgB,EAAc,EAAM,CAAC,GAAK,CAAC,cAAY,YAAU,QAAM,SAAO,SAAO,OAAK,mBAAiB,WAAS,OAAK,YAAU,CAAC,EAAW,CAAC,EAAM,EAAS,CAAC,EAAS,EAAY,CAAM,CAAC,EAAU,EAAa,CAAC,GAAS,EAAM,CAAO,EAAI,EAAM,OAAO,KAAK,CAAkP,AAAjP,EAAU,IAAI,CAAC,IAAM,EAAS,IAAI,qBAAqB,GAAS,CAAC,IAAM,EAAM,EAAQ,GAAG,EAAa,EAAM,eAAe,AAAE,GAAiD,OAA5C,EAAI,SAAS,EAAS,QAAQ,EAAI,QAAQ,CAAQ,IAAI,CAAC,AAAG,EAAI,SAAS,EAAS,UAAU,EAAI,QAAQ,AAAG,CAAE,EAAC,CAAE,EAAC,CAAC,EAAU,IAAI,CAAC,GAAG,GAAW,IAAc,EAAU,CAAC,IAAM,EAAW,YAAY,IAAI,CAAC,AAAG,EAAM,EAAW,EAAS,GAAW,EAAU,EAAE,CAAU,GAAM,EAAS,EAAY,AAAG,EAAC,EAAM,CAAC,MAAM,IAAI,CAAC,cAAc,EAAW,AAAE,CAAE,CAAC,EAAC,CAAC,EAAM,EAAY,EAAU,EAAK,CAAU,EAAC,CAAC,IAAM,EAAY,GAAY,IAAmB,QAAgB,EAAO,eAAe,QAAQ,CAAU,IAAmB,SAAiB,EAAO,eAAe,QAAQ,CAAC,QAAQ,KAAK,IAAI,CAAc,EAAO,QAAQ,EAAE,CAAI,MAAqB,GAAM,EAAO,IAAI,CAAK,MAAI,MAAM,CAAC,GAAG,EAAoB,OAAO,EAAS,EAAE,IAAI,cAAc,MAAM,WAAW,OAAO,YAAY,EAAS,IAAI,WAAW,EAAK,WAAW,WAAW,EAAK,WAAW,MAAM,CAAU,EAAC,SAAS,CAAC,EAAO,EAAY,EAAM,CAAC,CAAO,CAAC,EAAC,AAAE,gBAAmN,AAAptD,GAA6C,IAA6C,IAAkC,IAAoD,CAAM,EAAoB,CAAC,QAAQ,OAAO,eAAe,OAAO,WAAW,MAAO,EAA+vC,EAAc,aAAa,CAAC,YAAY,EAAE,UAAU,GAAG,MAAM,IAAI,OAAO,GAAG,OAAO,GAAG,MAAK,EAAM,iBAAiB,QAAQ,SAAS,GAAG,KAAK,CAAC,WAAW,QAAQ,WAAW,IAAI,YAAW,CAAK,EAAC,UAAU,SAAU,EAAC,EAAoB,EAAc,CAAC,KAAK,CAAC,MAAM,OAAO,KAAK,EAAY,KAAK,aAAa,CAAC,WAAW,QAAQ,WAAW,IAAI,YAAW,CAAK,CAAC,EAAC,SAAS,CAAC,MAAM,YAAY,KAAK,EAAY,OAAO,IAAI,EAAE,IAAI,IAAI,KAAK,CAAE,EAAC,UAAU,CAAC,KAAK,EAAY,MAAM,MAAM,YAAa,EAAC,YAAY,CAAC,KAAK,EAAY,OAAO,MAAM,eAAe,aAAa,EAAE,gBAAe,CAAK,EAAC,UAAU,CAAC,KAAK,EAAY,OAAO,MAAM,aAAa,aAAa,GAAG,gBAAe,CAAK,EAAC,iBAAiB,CAAC,KAAK,EAAY,KAAK,MAAM,oBAAoB,aAAa,QAAQ,QAAQ,CAAC,QAAQ,SAAS,MAAO,EAAC,aAAa,CAAC,gBAAgB,iBAAiB,MAAO,CAAC,EAAC,MAAM,CAAC,KAAK,EAAY,OAAO,MAAM,aAAa,aAAa,IAAI,IAAI,EAAE,IAAI,IAAI,KAAK,EAAG,EAAC,OAAO,CAAC,KAAK,EAAY,OAAO,MAAM,SAAS,aAAa,EAAG,EAAC,OAAO,CAAC,KAAK,EAAY,OAAO,MAAM,SAAS,aAAa,EAAG,EAAC,KAAK,CAAC,KAAK,EAAY,QAAQ,MAAM,iBAAiB,cAAa,EAAM,aAAa,KAAK,cAAc,KAAM,CAAC,EAAC"}