{
  "version": 3,
  "sources": ["ssg:https://framer.com/m/framer/store.js@^1.0.0", "ssg:https://framerusercontent.com/modules/YPSrEY2NmURbr3ROqoQY/Vh3z9yKYQ3F6aR7FFi2i/Masking.js"],
  "sourcesContent": ["import{useState,useEffect}from\"react\";import{Data,useObserveData}from\"framer\";export function createStore(state1){// Use Data so that a Preview reload resets the state\nconst dataStore=Data({state:Object.freeze({...state1})});// Create a set function that updates the state\nconst setDataStore=newState=>{// If the state is an object, make sure we copy it\nif(typeof newState===\"function\"){newState=newState(dataStore.state);}dataStore.state=Object.freeze({...dataStore.state,...newState});};// Store the initial state, copy the object if it's an object\nlet storeState=typeof state1===\"object\"?Object.freeze({...state1}):state1;// Keep a list of all the listeners, in the form of React hook setters\nconst storeSetters=new Set();// Create a set function that updates all the listeners / setters\nconst setStoreState=newState=>{// If the state is an object, make sure we copy it\nif(typeof newState===\"function\"){newState=newState(storeState);}storeState=typeof newState===\"object\"?Object.freeze({...storeState,...newState}):newState;// Update all the listeners / setters with the new value\nstoreSetters.forEach(setter=>setter(storeState));};// Create the actual hook based on everything above\nfunction useStore(){// Create the hook we are going to use as a listener\nconst[state,setState]=useState(storeState);// If we unmount the component using this hook, we need to remove the listener\n// @ts-ignore\nuseEffect(()=>{// But right now, we need to add the listener\nstoreSetters.add(setState);return()=>storeSetters.delete(setState);},[]);// If Data context exists, use Data, otherwise use vanilla React state\nif(useObserveData()===true){useObserveData();return[dataStore.state,setDataStore];}else{// Return the state and a function to update the central store\nreturn[state,setStoreState];}}return useStore;}\nexport const __FramerMetadata__ = {\"exports\":{\"createStore\":{\"type\":\"function\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"__FramerMetadata__\":{\"type\":\"variable\"}}}\n//# sourceMappingURL=./createStore.map", "import{jsx as _jsx}from\"react/jsx-runtime\";import{createStore}from\"https://framer.com/m/framer/store.js@^1.0.0\";import useMousePosition from\"https://framerusercontent.com/modules/vBX6TGSkgKkqJU18Yxqm/jN7e1czU159ptEgkEFIG/useMousePosition.js\";import{useEffect}from\"react\";// Learn more: https://www.framer.com/docs/guides/overrides/\nconst MASKSIZE={initial:50,onHover:400};const MASK_IMAGEURL=\"https://framerusercontent.com/images/De0CMakQwO0HOVWPyQnVeTw.svg\";const useStore=createStore({mousePos:{x:0,y:0},size:MASKSIZE.initial});export function withMaskHover(Component){return props=>{const[store,setStore]=useStore();return /*#__PURE__*/_jsx(Component,{...props,onMouseEnter:()=>{setStore({...store,size:MASKSIZE.onHover});},onMouseLeave:()=>{setStore({...store,size:MASKSIZE.initial});}});};}export function withMaskFrame(Component){return props=>{const[store,setStore]=useStore();const{x,y}=useMousePosition();useEffect(()=>{setStore({...store,mousePos:{x:x,y:y}});},[]);return /*#__PURE__*/_jsx(Component,{...props,animate:{WebkitMaskPosition:`${x-store.size/2}px ${y-store.size/2}px`,WebkitMaskSize:`${store.size}px`},transition:{type:\"tween\",ease:\"backOut\",duration:.5},style:{WebkitMaskSize:`${store.size}px`,WebkitMaskImage:`url(${MASK_IMAGEURL})`,WebkitMaskRepeat:\"no-repeat\",WebkitMaskPosition:`${x-store.size/2}px ${y-store.size/2}px`}});};}\nexport const __FramerMetadata__ = {\"exports\":{\"withMaskHover\":{\"type\":\"reactHoc\",\"name\":\"withMaskHover\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"withMaskFrame\":{\"type\":\"reactHoc\",\"name\":\"withMaskFrame\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"__FramerMetadata__\":{\"type\":\"variable\"}}}"],
  "mappings": "uGAAqF,SAASA,EAAYC,EAAO,CACjH,IAAMC,EAAUC,EAAK,CAAC,MAAM,OAAO,OAAO,CAAC,GAAGF,CAAM,CAAC,CAAC,CAAC,EACjDG,EAAaC,GAAU,CAC1B,OAAOA,GAAW,aAAYA,EAASA,EAASH,EAAU,KAAK,GAAGA,EAAU,MAAM,OAAO,OAAO,CAAC,GAAGA,EAAU,MAAM,GAAGG,CAAQ,CAAC,CAAE,EACjIC,EAAW,OAAOL,GAAS,SAAS,OAAO,OAAO,CAAC,GAAGA,CAAM,CAAC,EAAEA,EAC7DM,EAAa,IAAI,IACjBC,EAAcH,GAAU,CAC3B,OAAOA,GAAW,aAAYA,EAASA,EAASC,CAAU,GAAGA,EAAW,OAAOD,GAAW,SAAS,OAAO,OAAO,CAAC,GAAGC,EAAW,GAAGD,CAAQ,CAAC,EAAEA,EACjJE,EAAa,QAAQE,GAAQA,EAAOH,CAAU,CAAC,CAAE,EACjD,SAASI,GAAU,CACnB,GAAK,CAACC,EAAMC,CAAQ,EAAEC,EAASP,CAAU,EAIzC,OAFAQ,EAAU,KACVP,EAAa,IAAIK,CAAQ,EAAQ,IAAIL,EAAa,OAAOK,CAAQ,GAAI,CAAC,CAAC,EACpEG,EAAe,IAAI,IAAMA,EAAe,EAAQ,CAACb,EAAU,MAAME,CAAY,GAC1E,CAACO,EAAMH,CAAa,CAAG,CAAC,OAAOE,CAAS,CCd9C,IAAMM,EAAS,CAAC,QAAQ,GAAG,QAAQ,GAAG,EAAyF,IAAMC,EAASC,EAAY,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAKC,EAAS,OAAO,CAAC,EAAS,SAASC,EAAcC,EAAU,CAAC,OAAOC,GAAO,CAAC,GAAK,CAACC,EAAMC,CAAQ,EAAEP,EAAS,EAAE,OAAoBQ,EAAKJ,EAAU,CAAC,GAAGC,EAAM,aAAa,IAAI,CAACE,EAAS,CAAC,GAAGD,EAAM,KAAKJ,EAAS,OAAO,CAAC,CAAE,EAAE,aAAa,IAAI,CAACK,EAAS,CAAC,GAAGD,EAAM,KAAKJ,EAAS,OAAO,CAAC,CAAE,CAAC,CAAC,CAAE,CAAE",
  "names": ["createStore", "state1", "dataStore", "Data", "setDataStore", "newState", "storeState", "storeSetters", "setStoreState", "setter", "useStore", "state", "setState", "ye", "ue", "useObserveData", "MASKSIZE", "useStore", "createStore", "MASKSIZE", "withMaskHover", "Component", "props", "store", "setStore", "p"]
}
