{
  "version": 3,
  "sources": ["ssg:https://framerusercontent.com/modules/A3TmicKe8NoPvJbIUIV3/HDDIQhAyeVZ19HkStRHT/Buttons.js", "ssg:https://framer.com/m/framer/store.js@^1.0.0", "ssg:https://framer.com/m/framer/utils.js@^0.9.0"],
  "sourcesContent": ["/**\n * Buttons.tsx - Interactive Button Components\n * =========================================\n *\n * A collection of higher-order components (HOCs) that enhance button elements\n * with interactive animations and behaviours. These components utilise Framer Motion\n * to provide smooth, engaging user interactions.\n *\n * Key Features:\n * - Rotation animations with configurable duration\n * - Vertical hover displacement effects\n * - Tactile feedback on tap interactions\n * - Dynamic background colour management\n * - State management using Framer Store\n *\n * Components:\n *\n * 1. withRotate:\n *    - Applies a 90-degree rotation animation\n *    - Default duration of 2 seconds\n *    - Smooth transition effects\n *\n * 2. withHover:\n *    - Implements vertical hover movement\n *    - Displaces element by -10 units on hover\n *    - Instant response to user interaction\n *\n * 3. withTap:\n *    - Provides tactile feedback on tap\n *    - Displaces element by 1 unit on tap\n *    - Simulates physical button press\n *\n * 4. withHoverAndTap:\n *    - Combines hover and tap effects\n *    - Subtle hover displacement (-1 unit)\n *    - Minimal tap displacement (1 unit)\n *\n * 5. withRandomColor:\n *    - Manages dynamic background colour changes\n *    - Utilises Framer Store for state management\n *    - Generates random colours on click\n *    - Initial background colour: #0099FF\n *\n * Dependencies:\n * - React\n * - Framer Motion\n * - Framer Store\n * - Framer Utils\n */import{jsx as _jsx}from\"react/jsx-runtime\";import{createStore}from\"https://framer.com/m/framer/store.js@^1.0.0\";import{randomColor}from\"https://framer.com/m/framer/utils.js@^0.9.0\";const useStore=createStore({background:\"#0099FF\"});/**\n * Adds a rotation animation to the wrapped component\n * @param Component - The component to be enhanced with rotation\n * @returns A new component with rotation animation capabilities\n */export function withRotate(Component){return props=>{return /*#__PURE__*/_jsx(Component,{...props,animate:{rotate:90},transition:{duration:2}});};}/**\n * Implements a hover effect with vertical displacement\n * @param Component - The component to be enhanced with hover effects\n * @returns A new component with hover interaction\n */export function withHover(Component){return props=>{return /*#__PURE__*/_jsx(Component,{...props,whileHover:{y:-10}});};}/**\n * Adds a tap interaction effect to the component\n * @param Component - The component to be enhanced with tap feedback\n * @returns A new component with tap animation\n */export function withTap(Component){return props=>{return /*#__PURE__*/_jsx(Component,{...props,whileTap:{y:1}});};}/**\n * Combines both hover and tap effects for enhanced interaction\n * @param Component - The component to be enhanced with hover and tap effects\n * @returns A new component with combined hover and tap animations\n */export function withHoverAndTap(Component){return props=>{return /*#__PURE__*/_jsx(Component,{...props,whileHover:{y:-1},whileTap:{y:1}});};}/**\n * Implements dynamic background colour changes on click\n * @param Component - The component to be enhanced with colour changing capability\n * @returns A new component with random colour generation on click\n */export function withRandomColor(Component){return props=>{const[store,setStore]=useStore();return /*#__PURE__*/_jsx(Component,{...props,animate:{background:store.background},onClick:()=>{setStore({background:randomColor()});}});};}\nexport const __FramerMetadata__ = {\"exports\":{\"withTap\":{\"type\":\"reactHoc\",\"name\":\"withTap\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"withHoverAndTap\":{\"type\":\"reactHoc\",\"name\":\"withHoverAndTap\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"withHover\":{\"type\":\"reactHoc\",\"name\":\"withHover\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"withRandomColor\":{\"type\":\"reactHoc\",\"name\":\"withRandomColor\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"withRotate\":{\"type\":\"reactHoc\",\"name\":\"withRotate\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"__FramerMetadata__\":{\"type\":\"variable\"}}}\n//# sourceMappingURL=./Buttons.map", "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", "export const centerContent = {\n    display: \"flex\",\n    justifyContent: \"center\",\n    alignItems: \"center\"\n};\nexport const autoSizingText = {\n    width: \"max-content\",\n    wordBreak: \"break-word\",\n    overflowWrap: \"break-word\",\n    overflow: \"hidden\",\n    whiteSpace: \"pre-wrap\",\n    flexShrink: 0\n};\nexport const defaultContainerStyles = {\n    ...centerContent,\n    overflow: \"hidden\"\n};\nexport const containerStyles = defaultContainerStyles;\nexport const randomColor = ()=>\"#\" + Math.floor(Math.random() * 16777215).toString(16)\n;\n\nexport const __FramerMetadata__ = {\"exports\":{\"centerContent\":{\"type\":\"variable\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"containerStyles\":{\"type\":\"variable\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"autoSizingText\":{\"type\":\"variable\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"defaultContainerStyles\":{\"type\":\"variable\",\"annotations\":{\"framerContractVersion\":\"1\"}},\"randomColor\":{\"type\":\"variable\",\"annotations\":{\"framerContractVersion\":\"1\"}}}}\n//# sourceMappingURL=./Utils.map"],
  "mappings": "iJAAAA,ICAAC,IAAqF,SAASC,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,CCf9CM,IAAO,IAAMC,EAAgB,CACzB,QAAS,OACT,eAAgB,SAChB,WAAY,QAChB,EASO,IAAMC,EAAyB,CAClC,GAAGC,EACH,SAAU,QACd,EFgCwL,IAAMC,EAASC,EAAY,CAAC,WAAW,SAAS,CAAC,EAgB/N,SAASC,EAAgBC,EAAU,CAAC,OAAOC,GAA4BC,EAAKF,EAAU,CAAC,GAAGC,EAAM,WAAW,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAI",
  "names": ["init_ssg_sandbox_shims", "init_ssg_sandbox_shims", "createStore", "state1", "dataStore", "Data", "setDataStore", "newState", "storeState", "storeSetters", "setStoreState", "setter", "useStore", "state", "setState", "ye", "ue", "useObserveData", "init_ssg_sandbox_shims", "centerContent", "defaultContainerStyles", "centerContent", "useStore", "createStore", "withHoverAndTap", "Component", "props", "p"]
}
