{
  "version": 3,
  "sources": ["ssg:https://asset.29cm.co.kr/contents/framer/hooks/useInViewport.js", "ssg:https://asset.29cm.co.kr/contents/framer/components/@shared/EventTrigger/Root.js", "ssg:https://asset.29cm.co.kr/contents/framer/components/@shared/EventTrigger/Root.hooks.js", "ssg:https://asset.29cm.co.kr/contents/framer/components/@shared/EventTrigger/Target.js", "ssg:https://asset.29cm.co.kr/contents/framer/components/@shared/EventTrigger/index.js"],
  "sourcesContent": ["import { useRef, useCallback } from \"react\";\nimport { useUpdatedRef } from \"./useUpdatedRef.js\";\nimport { useWindowEventListener } from \"./useWindowEventListener.js\";\nconst useInViewport = (callback) => {\n  const ref = useRef(null);\n  const prevIsInViewport = useRef(false);\n  const updatedCallback = useUpdatedRef(callback);\n  const handleScroll = useCallback(() => {\n    if (ref.current === null) {\n      return;\n    }\n    const isInViewport = getIsInViewport(ref.current);\n    if (isInViewport !== prevIsInViewport.current) {\n      updatedCallback.current(isInViewport);\n    }\n    prevIsInViewport.current = isInViewport;\n  }, []);\n  useWindowEventListener(\"scroll\", handleScroll);\n  return ref;\n};\nconst getIsInViewport = (element) => {\n  const {\n    offsetHeight\n  } = element;\n  const top = getAbsoluteOffsetTop(element);\n  const bottom = top + offsetHeight;\n  const isElementInViewport = window.scrollY <= top && bottom <= window.scrollY + window.innerHeight;\n  const isViewportInElement = top <= window.scrollY && window.scrollY + window.innerHeight <= bottom;\n  return isViewportInElement || isElementInViewport;\n};\nconst getAbsoluteOffsetTop = (element) => {\n  return Math.round(element.getBoundingClientRect().top + window.scrollY);\n};\nexport {\n  useInViewport\n};\n", "import { jsx } from \"react/jsx-runtime\";\nimport { createContext, forwardRef, useRef } from \"react\";\nimport { useInViewport } from \"../../../hooks/useInViewport.js\";\nimport \"../../../hooks/stores/content/content.store.js\";\nimport \"../../../utils/event-properties/source.js\";\nimport \"framer\";\nimport { mergeRefs } from \"../../../utils/react/mergeRefs.js\";\nconst EventTriggerContext = createContext({\n  isViewportEntered: () => false,\n  canTriggerFallbackImpression: () => false,\n  setCanTriggerFallbackImpression: () => {\n  },\n  types: [],\n  onImpression: void 0\n});\nconst Root = forwardRef(({\n  children,\n  className,\n  style,\n  types,\n  onImpression\n}, ref) => {\n  const isViewportEntered = useRef(false);\n  const canTriggerFallbackImpression = useRef(true);\n  const observeViewport = types.includes(\"impression\");\n  const handleViewportEnter = () => {\n    if (canTriggerFallbackImpression.current) {\n      onImpression == null ? void 0 : onImpression();\n    }\n    isViewportEntered.current = true;\n    canTriggerFallbackImpression.current = false;\n  };\n  const handleViewportLeave = () => {\n    isViewportEntered.current = false;\n    canTriggerFallbackImpression.current = true;\n  };\n  const containerRef = useInViewport((isInViewport) => {\n    if (!observeViewport) {\n      return;\n    }\n    if (isInViewport) {\n      handleViewportEnter();\n    } else {\n      handleViewportLeave();\n    }\n  });\n  return /* @__PURE__ */ jsx(EventTriggerContext.Provider, { value: {\n    isViewportEntered: () => isViewportEntered.current,\n    canTriggerFallbackImpression: () => canTriggerFallbackImpression.current,\n    setCanTriggerFallbackImpression: (next) => canTriggerFallbackImpression.current = next,\n    types,\n    onImpression\n  }, children: /* @__PURE__ */ jsx(\"div\", { ref: mergeRefs([containerRef, ref]), className, style: {\n    width: \"100%\",\n    ...style\n  }, children }) });\n});\nexport {\n  EventTriggerContext,\n  Root\n};\n", "import { useContext } from \"react\";\nimport { EventTriggerContext } from \"./Root.js\";\nconst useEventTriggerContext = () => useContext(EventTriggerContext);\nexport {\n  useEventTriggerContext\n};\n", "import { jsx } from \"react/jsx-runtime\";\nimport { forwardRef } from \"react\";\nimport { useEventTriggerContext } from \"./Root.hooks.js\";\nconst Target = forwardRef(({\n  children,\n  onClick,\n  ...rest\n}, ref) => {\n  const {\n    isViewportEntered,\n    canTriggerFallbackImpression,\n    setCanTriggerFallbackImpression,\n    types,\n    onImpression\n  } = useEventTriggerContext();\n  const handleClick = (e) => {\n    onClick == null ? void 0 : onClick(e);\n    const shouldTriggerFallbackImpression = types.includes(\"impression\") && !isViewportEntered() && canTriggerFallbackImpression();\n    if (shouldTriggerFallbackImpression) {\n      onImpression == null ? void 0 : onImpression();\n      setCanTriggerFallbackImpression(false);\n    }\n  };\n  return /* @__PURE__ */ jsx(\"div\", { ref, ...rest, onClick: handleClick, children });\n});\nexport {\n  Target\n};\n", "import { Root } from \"./Root.js\";\nimport { Target } from \"./Target.js\";\nconst EventTrigger = {\n  Root,\n  Target\n};\nexport {\n  EventTrigger\n};\n"],
  "mappings": "gNAGA,IAAMA,EAAiBC,GAAa,CAClC,IAAMC,EAAMC,EAAO,IAAI,EACjBC,EAAmBD,EAAO,EAAK,EAC/BE,EAAkBC,EAAcL,CAAQ,EACxCM,EAAeC,EAAY,IAAM,CACrC,GAAIN,EAAI,UAAY,KAClB,OAEF,IAAMO,EAAeC,EAAgBR,EAAI,OAAO,EAC5CO,IAAiBL,EAAiB,SACpCC,EAAgB,QAAQI,CAAY,EAEtCL,EAAiB,QAAUK,CAC7B,EAAG,CAAC,CAAC,EACL,OAAAE,EAAuB,SAAUJ,CAAY,EACtCL,CACT,EACMQ,EAAmBE,GAAY,CACnC,GAAM,CACJ,aAAAC,CACF,EAAID,EACEE,EAAMC,EAAqBH,CAAO,EAClCI,EAASF,EAAMD,EACfI,EAAsBC,EAAO,SAAWJ,GAAOE,GAAUE,EAAO,QAAUA,EAAO,YAEvF,OAD4BJ,GAAOI,EAAO,SAAWA,EAAO,QAAUA,EAAO,aAAeF,GAC9DC,CAChC,EACMF,EAAwBH,GACrB,KAAK,MAAMA,EAAQ,sBAAsB,EAAE,IAAMM,EAAO,OAAO,ECxBxE,IAAMC,EAAsBC,EAAc,CACxC,kBAAmB,IAAM,GACzB,6BAA8B,IAAM,GACpC,gCAAiC,IAAM,CACvC,EACA,MAAO,CAAC,EACR,aAAc,MAChB,CAAC,EACKC,EAAOC,EAAW,CAAC,CACvB,SAAAC,EACA,UAAAC,EACA,MAAAC,EACA,MAAAC,EACA,aAAAC,CACF,EAAGC,IAAQ,CACT,IAAMC,EAAoBC,EAAO,EAAK,EAChCC,EAA+BD,EAAO,EAAI,EAC1CE,EAAkBN,EAAM,SAAS,YAAY,EAC7CO,EAAsB,IAAM,CAC5BF,EAA6B,SACCJ,IAAa,EAE/CE,EAAkB,QAAU,GAC5BE,EAA6B,QAAU,EACzC,EACMG,EAAsB,IAAM,CAChCL,EAAkB,QAAU,GAC5BE,EAA6B,QAAU,EACzC,EACMI,EAAeC,EAAeC,GAAiB,CAC9CL,IAGDK,EACFJ,EAAoB,EAEpBC,EAAoB,EAExB,CAAC,EACD,OAAuBI,EAAInB,EAAoB,SAAU,CAAE,MAAO,CAChE,kBAAmB,IAAMU,EAAkB,QAC3C,6BAA8B,IAAME,EAA6B,QACjE,gCAAkCQ,GAASR,EAA6B,QAAUQ,EAClF,MAAAb,EACA,aAAAC,CACF,EAAG,SAA0BW,EAAI,MAAO,CAAE,IAAKE,EAAU,CAACL,EAAcP,CAAG,CAAC,EAAG,UAAAJ,EAAW,MAAO,CAC/F,MAAO,OACP,GAAGC,CACL,EAAG,SAAAF,CAAS,CAAC,CAAE,CAAC,CAClB,CAAC,ECtDD,IAAMkB,EAAyB,IAAMC,EAAWC,CAAmB,ECCnE,IAAMC,EAASC,EAAW,CAAC,CACzB,SAAAC,EACA,QAAAC,EACA,GAAGC,CACL,EAAGC,IAAQ,CACT,GAAM,CACJ,kBAAAC,EACA,6BAAAC,EACA,gCAAAC,EACA,MAAAC,EACA,aAAAC,CACF,EAAIC,EAAuB,EAS3B,OAAuBC,EAAI,MAAO,CAAE,IAAAP,EAAK,GAAGD,EAAM,QAR7BS,GAAM,CACEV,IAAQU,CAAC,EACIJ,EAAM,SAAS,YAAY,GAAK,CAACH,EAAkB,GAAKC,EAA6B,IAE3FG,IAAa,EAC7CF,EAAgC,EAAK,EAEzC,EACwE,SAAAN,CAAS,CAAC,CACpF,CAAC,ECtBD,IAAMY,GAAe,CACnB,KAAAC,EACA,OAAAC,CACF",
  "names": ["useInViewport", "callback", "ref", "pe", "prevIsInViewport", "updatedCallback", "useUpdatedRef", "handleScroll", "te", "isInViewport", "getIsInViewport", "useWindowEventListener", "element", "offsetHeight", "top", "getAbsoluteOffsetTop", "bottom", "isElementInViewport", "window", "EventTriggerContext", "z", "Root", "Y", "children", "className", "style", "types", "onImpression", "ref", "isViewportEntered", "pe", "canTriggerFallbackImpression", "observeViewport", "handleViewportEnter", "handleViewportLeave", "containerRef", "useInViewport", "isInViewport", "p", "next", "mergeRefs", "useEventTriggerContext", "re", "EventTriggerContext", "Target", "Y", "children", "onClick", "rest", "ref", "isViewportEntered", "canTriggerFallbackImpression", "setCanTriggerFallbackImpression", "types", "onImpression", "useEventTriggerContext", "p", "e", "EventTrigger", "Root", "Target"]
}
