@hua-labs/motion-core 2.0.0 → 2.0.1

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 (130) hide show
  1. package/README.md +16 -19
  2. package/dist/.tsbuildinfo +1 -1
  3. package/dist/core/MotionEngine.d.ts +111 -0
  4. package/dist/core/MotionEngine.d.ts.map +1 -0
  5. package/dist/core/MotionEngine.js +206 -0
  6. package/dist/core/MotionEngine.js.map +1 -0
  7. package/dist/core/PerformanceOptimizer.d.ts +124 -0
  8. package/dist/core/PerformanceOptimizer.d.ts.map +1 -0
  9. package/dist/core/PerformanceOptimizer.js +334 -0
  10. package/dist/core/PerformanceOptimizer.js.map +1 -0
  11. package/dist/core/TransitionEffects.d.ts +76 -0
  12. package/dist/core/TransitionEffects.d.ts.map +1 -0
  13. package/dist/core/TransitionEffects.js +321 -0
  14. package/dist/core/TransitionEffects.js.map +1 -0
  15. package/dist/hooks/useBounceIn.d.ts +11 -2
  16. package/dist/hooks/useBounceIn.d.ts.map +1 -1
  17. package/dist/hooks/useBounceIn.js +48 -114
  18. package/dist/hooks/useBounceIn.js.map +1 -1
  19. package/dist/hooks/useClickToggle.d.ts +28 -13
  20. package/dist/hooks/useClickToggle.d.ts.map +1 -1
  21. package/dist/hooks/useClickToggle.js +125 -90
  22. package/dist/hooks/useClickToggle.js.map +1 -1
  23. package/dist/hooks/useFadeIn.d.ts +0 -14
  24. package/dist/hooks/useFadeIn.d.ts.map +1 -1
  25. package/dist/hooks/useFadeIn.js +17 -43
  26. package/dist/hooks/useFadeIn.js.map +1 -1
  27. package/dist/hooks/useFocusToggle.d.ts +28 -13
  28. package/dist/hooks/useFocusToggle.d.ts.map +1 -1
  29. package/dist/hooks/useFocusToggle.js +125 -87
  30. package/dist/hooks/useFocusToggle.js.map +1 -1
  31. package/dist/hooks/useGesture.d.ts +45 -0
  32. package/dist/hooks/useGesture.d.ts.map +1 -0
  33. package/dist/hooks/useGesture.js +274 -0
  34. package/dist/hooks/useGesture.js.map +1 -0
  35. package/dist/hooks/useGestureMotion.d.ts +26 -0
  36. package/dist/hooks/useGestureMotion.d.ts.map +1 -0
  37. package/dist/hooks/useGestureMotion.js +167 -0
  38. package/dist/hooks/useGestureMotion.js.map +1 -0
  39. package/dist/hooks/useGradient.d.ts +10 -21
  40. package/dist/hooks/useGradient.d.ts.map +1 -1
  41. package/dist/hooks/useGradient.js +70 -127
  42. package/dist/hooks/useGradient.js.map +1 -1
  43. package/dist/hooks/useHoverMotion.d.ts +4 -14
  44. package/dist/hooks/useHoverMotion.d.ts.map +1 -1
  45. package/dist/hooks/useHoverMotion.js +31 -82
  46. package/dist/hooks/useHoverMotion.js.map +1 -1
  47. package/dist/hooks/useMotionState.d.ts +27 -24
  48. package/dist/hooks/useMotionState.d.ts.map +1 -1
  49. package/dist/hooks/useMotionState.js +186 -103
  50. package/dist/hooks/useMotionState.js.map +1 -1
  51. package/dist/hooks/usePageMotions.d.ts +17 -0
  52. package/dist/hooks/usePageMotions.d.ts.map +1 -0
  53. package/dist/hooks/usePageMotions.js +352 -0
  54. package/dist/hooks/usePageMotions.js.map +1 -0
  55. package/dist/hooks/usePulse.d.ts +8 -1
  56. package/dist/hooks/usePulse.d.ts.map +1 -1
  57. package/dist/hooks/usePulse.js +75 -101
  58. package/dist/hooks/usePulse.js.map +1 -1
  59. package/dist/hooks/useRepeat.d.ts +17 -22
  60. package/dist/hooks/useRepeat.d.ts.map +1 -1
  61. package/dist/hooks/useRepeat.js +48 -162
  62. package/dist/hooks/useRepeat.js.map +1 -1
  63. package/dist/hooks/useScaleIn.d.ts +12 -2
  64. package/dist/hooks/useScaleIn.d.ts.map +1 -1
  65. package/dist/hooks/useScaleIn.js +46 -85
  66. package/dist/hooks/useScaleIn.js.map +1 -1
  67. package/dist/hooks/useScrollProgress.d.ts +8 -18
  68. package/dist/hooks/useScrollProgress.d.ts.map +1 -1
  69. package/dist/hooks/useScrollProgress.js +28 -130
  70. package/dist/hooks/useScrollProgress.js.map +1 -1
  71. package/dist/hooks/useScrollReveal.d.ts +12 -15
  72. package/dist/hooks/useScrollReveal.d.ts.map +1 -1
  73. package/dist/hooks/useScrollReveal.js +93 -72
  74. package/dist/hooks/useScrollReveal.js.map +1 -1
  75. package/dist/hooks/useSimplePageMotion.d.ts +29 -0
  76. package/dist/hooks/useSimplePageMotion.d.ts.map +1 -0
  77. package/dist/hooks/useSimplePageMotion.js +145 -0
  78. package/dist/hooks/useSimplePageMotion.js.map +1 -0
  79. package/dist/hooks/useSlideLeft.d.ts +12 -2
  80. package/dist/hooks/useSlideLeft.d.ts.map +1 -1
  81. package/dist/hooks/useSlideLeft.js +46 -85
  82. package/dist/hooks/useSlideLeft.js.map +1 -1
  83. package/dist/hooks/useSlideRight.d.ts +12 -2
  84. package/dist/hooks/useSlideRight.d.ts.map +1 -1
  85. package/dist/hooks/useSlideRight.js +46 -85
  86. package/dist/hooks/useSlideRight.js.map +1 -1
  87. package/dist/hooks/useSlideUp.d.ts.map +1 -1
  88. package/dist/hooks/useSlideUp.js +40 -29
  89. package/dist/hooks/useSlideUp.js.map +1 -1
  90. package/dist/hooks/useSmartMotion.d.ts +31 -0
  91. package/dist/hooks/useSmartMotion.d.ts.map +1 -0
  92. package/dist/hooks/useSmartMotion.js +257 -0
  93. package/dist/hooks/useSmartMotion.js.map +1 -0
  94. package/dist/hooks/useSpringMotion.d.ts +14 -24
  95. package/dist/hooks/useSpringMotion.d.ts.map +1 -1
  96. package/dist/hooks/useSpringMotion.js +109 -161
  97. package/dist/hooks/useSpringMotion.js.map +1 -1
  98. package/dist/hooks/useToggleMotion.d.ts +16 -0
  99. package/dist/hooks/useToggleMotion.d.ts.map +1 -0
  100. package/dist/hooks/useToggleMotion.js +53 -0
  101. package/dist/hooks/useToggleMotion.js.map +1 -0
  102. package/dist/hooks/useUnifiedMotion.d.ts +51 -0
  103. package/dist/hooks/useUnifiedMotion.d.ts.map +1 -0
  104. package/dist/hooks/useUnifiedMotion.js +106 -0
  105. package/dist/hooks/useUnifiedMotion.js.map +1 -0
  106. package/dist/index.d.ts +14 -10
  107. package/dist/index.d.ts.map +1 -1
  108. package/dist/index.js +37 -17
  109. package/dist/index.js.map +1 -1
  110. package/dist/managers/MotionStateManager.d.ts +63 -0
  111. package/dist/managers/MotionStateManager.d.ts.map +1 -0
  112. package/dist/managers/MotionStateManager.js +159 -0
  113. package/dist/managers/MotionStateManager.js.map +1 -0
  114. package/dist/presets/index.d.ts +16 -0
  115. package/dist/presets/index.d.ts.map +1 -0
  116. package/dist/presets/index.js +120 -0
  117. package/dist/presets/index.js.map +1 -0
  118. package/dist/types/common.d.ts +155 -0
  119. package/dist/types/common.d.ts.map +1 -0
  120. package/dist/types/common.js +5 -0
  121. package/dist/types/common.js.map +1 -0
  122. package/dist/types/index.d.ts +63 -95
  123. package/dist/types/index.d.ts.map +1 -1
  124. package/dist/types/index.js +2 -2
  125. package/dist/types/index.js.map +1 -1
  126. package/dist/utils/easing.d.ts +80 -26
  127. package/dist/utils/easing.d.ts.map +1 -1
  128. package/dist/utils/easing.js +202 -67
  129. package/dist/utils/easing.js.map +1 -1
  130. package/package.json +15 -15
@@ -1,139 +1,37 @@
1
- import { useRef, useState, useEffect, useCallback } from 'react';
1
+ import { useState, useEffect } from 'react';
2
2
  export function useScrollProgress(options = {}) {
3
- const { duration = 300, easing = 'ease-out', progressScale = 1, progressOpacity, progressRotate, progressTranslateY, progressTranslateX, initialScale = 0.8, initialOpacity = 0.5, initialRotate = 0, initialTranslateY = 0, initialTranslateX = 0, scrollThreshold = 0.1, progressDirection = 'both', onComplete, onStart, onStop, onReset } = options;
4
- const ref = useRef(null);
5
- const [isVisible, setIsVisible] = useState(false);
6
- const [isAnimating, setIsAnimating] = useState(false);
7
- const [progress, setProgress] = useState(0);
8
- const [scrollProgress, setScrollProgress] = useState(0);
9
- const [scrollDirection, setScrollDirection] = useState(null);
10
- const [scrollVelocity, setScrollVelocity] = useState(0);
11
- const [lastScrollY, setLastScrollY] = useState(0);
12
- const [lastScrollTime, setLastScrollTime] = useState(Date.now());
13
- // 스크롤 이벤트 핸들러
14
- const handleScroll = useCallback(() => {
15
- if (!ref.current)
16
- return;
17
- const currentScrollY = window.scrollY;
18
- const currentTime = Date.now();
19
- const rect = ref.current.getBoundingClientRect();
20
- const threshold = window.innerHeight * scrollThreshold;
21
- // 스크롤 진행률 계산 (0-1)
22
- const elementTop = rect.top + currentScrollY;
23
- const elementHeight = rect.height;
24
- const viewportHeight = window.innerHeight;
25
- const documentHeight = document.documentElement.scrollHeight;
26
- let newScrollProgress = 0;
27
- if (progressDirection === 'vertical' || progressDirection === 'both') {
28
- // 세로 스크롤 진행률
29
- const scrollRange = documentHeight - viewportHeight;
30
- newScrollProgress = Math.max(0, Math.min(1, currentScrollY / scrollRange));
31
- }
32
- else if (progressDirection === 'horizontal') {
33
- // 가로 스크롤 진행률 (요소가 뷰포트에 들어올 때)
34
- const elementProgress = Math.max(0, Math.min(1, (viewportHeight - rect.top) / (viewportHeight + elementHeight)));
35
- newScrollProgress = elementProgress;
36
- }
37
- setScrollProgress(newScrollProgress);
38
- // 스크롤 방향과 속도 계산
39
- const isScrollingDown = currentScrollY > lastScrollY;
40
- const isScrollingUp = currentScrollY < lastScrollY;
41
- const timeDiff = currentTime - lastScrollTime;
42
- const scrollDiff = Math.abs(currentScrollY - lastScrollY);
43
- const velocity = timeDiff > 0 ? scrollDiff / timeDiff : 0;
44
- if (isScrollingDown) {
45
- setScrollDirection('down');
46
- }
47
- else if (isScrollingUp) {
48
- setScrollDirection('up');
49
- }
50
- setScrollVelocity(velocity);
51
- // 요소가 뷰포트에 보이는지 확인
52
- const shouldBeVisible = rect.top <= threshold;
53
- if (shouldBeVisible && !isVisible) {
54
- setIsVisible(true);
55
- setIsAnimating(true);
56
- setProgress(0);
57
- onStart?.();
58
- setTimeout(() => {
59
- setIsAnimating(false);
60
- setProgress(1);
61
- onComplete?.();
62
- }, duration);
63
- }
64
- setLastScrollY(currentScrollY);
65
- setLastScrollTime(currentTime);
66
- }, [isVisible, lastScrollY, lastScrollTime, progressDirection, scrollThreshold, duration, onStart, onComplete]);
67
- // 스크롤 이벤트 리스너 설정
3
+ const { target, offset = 0, showOnMount = false } = options;
4
+ const [progress, setProgress] = useState(showOnMount ? 0 : 0);
5
+ const [mounted, setMounted] = useState(false);
6
+ // 하이드레이션 이슈 해결을 위한 mounted 상태 관리
7
+ useEffect(() => {
8
+ setMounted(true);
9
+ }, []);
68
10
  useEffect(() => {
69
- window.addEventListener('scroll', handleScroll, { passive: true });
70
- handleScroll(); // 초기 상태 확인
11
+ if (!mounted)
12
+ return;
13
+ const calculateProgress = () => {
14
+ if (typeof window !== 'undefined') {
15
+ const scrollTop = window.pageYOffset;
16
+ const scrollHeight = target || document.documentElement.scrollHeight - window.innerHeight;
17
+ const adjustedScrollTop = Math.max(0, scrollTop - offset);
18
+ const progressPercent = Math.min(100, Math.max(0, (adjustedScrollTop / scrollHeight) * 100));
19
+ setProgress(progressPercent);
20
+ }
21
+ };
22
+ // 초기 상태 확인
23
+ calculateProgress();
24
+ // 이벤트 리스너 등록
25
+ window.addEventListener("scroll", calculateProgress, { passive: true });
26
+ window.addEventListener("resize", calculateProgress, { passive: true });
71
27
  return () => {
72
- window.removeEventListener('scroll', handleScroll);
28
+ window.removeEventListener("scroll", calculateProgress);
29
+ window.removeEventListener("resize", calculateProgress);
73
30
  };
74
- }, [handleScroll]);
75
- // 모션 시작 함수
76
- const start = useCallback(() => {
77
- if (!isVisible) {
78
- setIsVisible(true);
79
- setIsAnimating(true);
80
- setProgress(0);
81
- onStart?.();
82
- setTimeout(() => {
83
- setIsAnimating(false);
84
- setProgress(1);
85
- onComplete?.();
86
- }, duration);
87
- }
88
- }, [isVisible, duration, onStart, onComplete]);
89
- // 모션 중단 함수
90
- const stop = useCallback(() => {
91
- setIsAnimating(false);
92
- onStop?.();
93
- }, [onStop]);
94
- // 모션 리셋 함수
95
- const reset = useCallback(() => {
96
- setIsVisible(false);
97
- setIsAnimating(false);
98
- setProgress(0);
99
- setScrollProgress(0);
100
- onReset?.();
101
- }, [onReset]);
102
- // 모션 일시정지 함수
103
- const pause = useCallback(() => {
104
- setIsAnimating(false);
105
- }, []);
106
- // 모션 재개 함수
107
- const resume = useCallback(() => {
108
- if (isVisible) {
109
- setIsAnimating(true);
110
- }
111
- }, [isVisible]);
112
- // 스타일 계산 (스크롤 진행률에 따라)
113
- const style = {
114
- transform: `
115
- scale(${initialScale + (progressScale - initialScale) * scrollProgress})
116
- rotate(${initialRotate + (progressRotate || 0 - initialRotate) * scrollProgress}deg)
117
- translate(${initialTranslateX + (progressTranslateX || 0 - initialTranslateX) * scrollProgress}px, ${initialTranslateY + (progressTranslateY || 0 - initialTranslateY) * scrollProgress}px)
118
- `,
119
- opacity: initialOpacity + (progressOpacity || 1 - initialOpacity) * scrollProgress,
120
- transition: `all ${duration}ms ${easing}`,
121
- willChange: 'transform, opacity'
122
- };
31
+ }, [target, offset, mounted]);
123
32
  return {
124
- ref,
125
- isVisible,
126
- isAnimating,
127
- style,
128
33
  progress,
129
- start,
130
- stop,
131
- reset,
132
- pause,
133
- resume,
134
- scrollProgress,
135
- scrollDirection,
136
- scrollVelocity
34
+ mounted
137
35
  };
138
36
  }
139
37
  //# sourceMappingURL=useScrollProgress.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useScrollProgress.js","sourceRoot":"","sources":["../../src/hooks/useScrollProgress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAkBhE,MAAM,UAAU,iBAAiB,CAC/B,UAAiC,EAAE;IAMnC,MAAM,EACJ,QAAQ,GAAG,GAAG,EACd,MAAM,GAAG,UAAU,EACnB,aAAa,GAAG,CAAC,EACjB,eAAe,EACf,cAAc,EACd,kBAAkB,EAClB,kBAAkB,EAClB,YAAY,GAAG,GAAG,EAClB,cAAc,GAAG,GAAG,EACpB,aAAa,GAAG,CAAC,EACjB,iBAAiB,GAAG,CAAC,EACrB,iBAAiB,GAAG,CAAC,EACrB,eAAe,GAAG,GAAG,EACrB,iBAAiB,GAAG,MAAM,EAC1B,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EACrC,GAAG,OAAO,CAAA;IAEX,MAAM,GAAG,GAAG,MAAM,CAAI,IAAI,CAAC,CAAA;IAC3B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACjD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACrD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAC3C,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACvD,MAAM,CAAC,eAAe,EAAE,kBAAkB,CAAC,GAAG,QAAQ,CAAuB,IAAI,CAAC,CAAA;IAClF,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACvD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACjD,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAA;IAEhE,cAAc;IACd,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE;QACpC,IAAI,CAAC,GAAG,CAAC,OAAO;YAAE,OAAM;QAExB,MAAM,cAAc,GAAG,MAAM,CAAC,OAAO,CAAA;QACrC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAA;QAC9B,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAA;QAChD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,GAAG,eAAe,CAAA;QAEtD,mBAAmB;QACnB,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,GAAG,cAAc,CAAA;QAC5C,MAAM,aAAa,GAAG,IAAI,CAAC,MAAM,CAAA;QACjC,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,CAAA;QACzC,MAAM,cAAc,GAAG,QAAQ,CAAC,eAAe,CAAC,YAAY,CAAA;QAE5D,IAAI,iBAAiB,GAAG,CAAC,CAAA;QAEzB,IAAI,iBAAiB,KAAK,UAAU,IAAI,iBAAiB,KAAK,MAAM,EAAE,CAAC;YACrE,aAAa;YACb,MAAM,WAAW,GAAG,cAAc,GAAG,cAAc,CAAA;YACnD,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,GAAG,WAAW,CAAC,CAAC,CAAA;QAC5E,CAAC;aAAM,IAAI,iBAAiB,KAAK,YAAY,EAAE,CAAC;YAC9C,8BAA8B;YAC9B,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,GAAG,aAAa,CAAC,CAAC,CAAC,CAAA;YAChH,iBAAiB,GAAG,eAAe,CAAA;QACrC,CAAC;QAED,iBAAiB,CAAC,iBAAiB,CAAC,CAAA;QAEpC,gBAAgB;QAChB,MAAM,eAAe,GAAG,cAAc,GAAG,WAAW,CAAA;QACpD,MAAM,aAAa,GAAG,cAAc,GAAG,WAAW,CAAA;QAClD,MAAM,QAAQ,GAAG,WAAW,GAAG,cAAc,CAAA;QAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,GAAG,WAAW,CAAC,CAAA;QACzD,MAAM,QAAQ,GAAG,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;QAEzD,IAAI,eAAe,EAAE,CAAC;YACpB,kBAAkB,CAAC,MAAM,CAAC,CAAA;QAC5B,CAAC;aAAM,IAAI,aAAa,EAAE,CAAC;YACzB,kBAAkB,CAAC,IAAI,CAAC,CAAA;QAC1B,CAAC;QAED,iBAAiB,CAAC,QAAQ,CAAC,CAAA;QAE3B,mBAAmB;QACnB,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,IAAI,SAAS,CAAA;QAE7C,IAAI,eAAe,IAAI,CAAC,SAAS,EAAE,CAAC;YAClC,YAAY,CAAC,IAAI,CAAC,CAAA;YAClB,cAAc,CAAC,IAAI,CAAC,CAAA;YACpB,WAAW,CAAC,CAAC,CAAC,CAAA;YACd,OAAO,EAAE,EAAE,CAAA;YAEX,UAAU,CAAC,GAAG,EAAE;gBACd,cAAc,CAAC,KAAK,CAAC,CAAA;gBACrB,WAAW,CAAC,CAAC,CAAC,CAAA;gBACd,UAAU,EAAE,EAAE,CAAA;YAChB,CAAC,EAAE,QAAQ,CAAC,CAAA;QACd,CAAC;QAED,cAAc,CAAC,cAAc,CAAC,CAAA;QAC9B,iBAAiB,CAAC,WAAW,CAAC,CAAA;IAChC,CAAC,EAAE,CAAC,SAAS,EAAE,WAAW,EAAE,cAAc,EAAE,iBAAiB,EAAE,eAAe,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAA;IAE/G,iBAAiB;IACjB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAClE,YAAY,EAAE,CAAA,CAAC,WAAW;QAE1B,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACpD,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;IAElB,WAAW;IACX,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,YAAY,CAAC,IAAI,CAAC,CAAA;YAClB,cAAc,CAAC,IAAI,CAAC,CAAA;YACpB,WAAW,CAAC,CAAC,CAAC,CAAA;YACd,OAAO,EAAE,EAAE,CAAA;YAEX,UAAU,CAAC,GAAG,EAAE;gBACd,cAAc,CAAC,KAAK,CAAC,CAAA;gBACrB,WAAW,CAAC,CAAC,CAAC,CAAA;gBACd,UAAU,EAAE,EAAE,CAAA;YAChB,CAAC,EAAE,QAAQ,CAAC,CAAA;QACd,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAA;IAE9C,WAAW;IACX,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,EAAE;QAC5B,cAAc,CAAC,KAAK,CAAC,CAAA;QACrB,MAAM,EAAE,EAAE,CAAA;IACZ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,WAAW;IACX,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,YAAY,CAAC,KAAK,CAAC,CAAA;QACnB,cAAc,CAAC,KAAK,CAAC,CAAA;QACrB,WAAW,CAAC,CAAC,CAAC,CAAA;QACd,iBAAiB,CAAC,CAAC,CAAC,CAAA;QACpB,OAAO,EAAE,EAAE,CAAA;IACb,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,aAAa;IACb,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,cAAc,CAAC,KAAK,CAAC,CAAA;IACvB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,WAAW;IACX,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE;QAC9B,IAAI,SAAS,EAAE,CAAC;YACd,cAAc,CAAC,IAAI,CAAC,CAAA;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAA;IAEf,uBAAuB;IACvB,MAAM,KAAK,GAAwB;QACjC,SAAS,EAAE;cACD,YAAY,GAAG,CAAC,aAAa,GAAG,YAAY,CAAC,GAAG,cAAc;eAC7D,aAAa,GAAG,CAAC,cAAc,IAAI,CAAC,GAAG,aAAa,CAAC,GAAG,cAAc;kBACnE,iBAAiB,GAAG,CAAC,kBAAkB,IAAI,CAAC,GAAG,iBAAiB,CAAC,GAAG,cAAc,OAAO,iBAAiB,GAAG,CAAC,kBAAkB,IAAI,CAAC,GAAG,iBAAiB,CAAC,GAAG,cAAc;KACxL;QACD,OAAO,EAAE,cAAc,GAAG,CAAC,eAAe,IAAI,CAAC,GAAG,cAAc,CAAC,GAAG,cAAc;QAClF,UAAU,EAAE,OAAO,QAAQ,MAAM,MAAM,EAAE;QACzC,UAAU,EAAE,oBAAoB;KACjC,CAAA;IAED,OAAO;QACL,GAAG;QACH,SAAS;QACT,WAAW;QACX,KAAK;QACL,QAAQ;QACR,KAAK;QACL,IAAI;QACJ,KAAK;QACL,KAAK;QACL,MAAM;QACN,cAAc;QACd,eAAe;QACf,cAAc;KACf,CAAA;AACH,CAAC"}
1
+ {"version":3,"file":"useScrollProgress.js","sourceRoot":"","sources":["../../src/hooks/useScrollProgress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,OAAO,CAAA;AAQ3C,MAAM,UAAU,iBAAiB,CAAC,UAAiC,EAAE;IACnE,MAAM,EACJ,MAAM,EACN,MAAM,GAAG,CAAC,EACV,WAAW,GAAG,KAAK,EACpB,GAAG,OAAO,CAAA;IAEX,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC7D,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAE7C,iCAAiC;IACjC,SAAS,CAAC,GAAG,EAAE;QACb,UAAU,CAAC,IAAI,CAAC,CAAA;IAClB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,OAAO;YAAE,OAAM;QAEpB,MAAM,iBAAiB,GAAG,GAAG,EAAE;YAC7B,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;gBAClC,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAA;gBACpC,MAAM,YAAY,GAAG,MAAM,IAAI,QAAQ,CAAC,eAAe,CAAC,YAAY,GAAG,MAAM,CAAC,WAAW,CAAA;gBACzF,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC,CAAA;gBAEzD,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,iBAAiB,GAAG,YAAY,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;gBAC5F,WAAW,CAAC,eAAe,CAAC,CAAA;YAC9B,CAAC;QACH,CAAC,CAAA;QAED,WAAW;QACX,iBAAiB,EAAE,CAAA;QAEnB,aAAa;QACb,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QACvE,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,iBAAiB,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAEvE,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAA;YACvD,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAA;QACzD,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC,CAAA;IAE7B,OAAO;QACL,QAAQ;QACR,OAAO;KACR,CAAA;AACH,CAAC"}
@@ -1,17 +1,14 @@
1
- import { BaseMotionOptions, BaseMotionReturn, MotionElement } from '../types';
2
- export interface ScrollRevealOptions extends BaseMotionOptions {
3
- revealScale?: number;
4
- revealOpacity?: number;
5
- revealRotate?: number;
6
- revealTranslateY?: number;
7
- revealTranslateX?: number;
8
- initialScale?: number;
9
- initialOpacity?: number;
10
- initialRotate?: number;
11
- initialTranslateY?: number;
12
- initialTranslateX?: number;
13
- scrollThreshold?: number;
14
- scrollDirection?: 'up' | 'down' | 'both';
1
+ import { BaseMotionReturn, MotionElement } from '../types';
2
+ type MotionType = 'fadeIn' | 'slideUp' | 'slideLeft' | 'slideRight' | 'scaleIn' | 'bounceIn';
3
+ interface ScrollRevealOptions {
4
+ threshold?: number;
5
+ rootMargin?: string;
6
+ triggerOnce?: boolean;
7
+ delay?: number;
8
+ motionType?: MotionType;
15
9
  }
16
- export declare function useScrollReveal<T extends MotionElement = HTMLDivElement>(options?: ScrollRevealOptions): BaseMotionReturn<T>;
10
+ export declare function useScrollReveal<T extends MotionElement = HTMLDivElement>(options?: ScrollRevealOptions): BaseMotionReturn<T> & {
11
+ progress: number;
12
+ };
13
+ export {};
17
14
  //# sourceMappingURL=useScrollReveal.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useScrollReveal.d.ts","sourceRoot":"","sources":["../../src/hooks/useScrollReveal.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7E,MAAM,WAAW,mBAAoB,SAAQ,iBAAiB;IAC5D,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,IAAI,GAAG,MAAM,GAAG,MAAM,CAAA;CACzC;AAED,wBAAgB,eAAe,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EACtE,OAAO,GAAE,mBAAwB,GAChC,gBAAgB,CAAC,CAAC,CAAC,CA0HrB"}
1
+ {"version":3,"file":"useScrollReveal.d.ts","sourceRoot":"","sources":["../../src/hooks/useScrollReveal.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE1D,KAAK,UAAU,GAAG,QAAQ,GAAG,SAAS,GAAG,WAAW,GAAG,YAAY,GAAG,SAAS,GAAG,UAAU,CAAA;AAE5F,UAAU,mBAAmB;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,UAAU,CAAC,EAAE,UAAU,CAAA;CACxB;AAED,wBAAgB,eAAe,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EACtE,OAAO,GAAE,mBAAwB,GAChC,gBAAgB,CAAC,CAAC,CAAC,GAAG;IACvB,QAAQ,EAAE,MAAM,CAAA;CACjB,CAmIA"}
@@ -1,95 +1,116 @@
1
- import { useRef, useState, useEffect, useCallback } from 'react';
1
+ import { useRef, useEffect, useCallback, useState, useMemo } from 'react';
2
2
  export function useScrollReveal(options = {}) {
3
- const { duration = 700, easing = 'ease-out', revealScale = 1, revealOpacity = 1, revealRotate = 0, revealTranslateY = 0, revealTranslateX = 0, initialScale = 0.8, initialOpacity = 0, initialRotate = 0, initialTranslateY = 50, initialTranslateX = 0, scrollThreshold = 0.1, scrollDirection = 'both', onComplete, onStart, onStop, onReset } = options;
3
+ const { threshold = 0.1, rootMargin = '0px', triggerOnce = true, delay = 0, motionType = 'fadeIn' } = options;
4
4
  const ref = useRef(null);
5
- const [isRevealed, setIsRevealed] = useState(false);
5
+ const [isVisible, setIsVisible] = useState(false);
6
6
  const [isAnimating, setIsAnimating] = useState(false);
7
+ const [hasTriggered, setHasTriggered] = useState(false);
7
8
  const [progress, setProgress] = useState(0);
8
- // 스크롤 이벤트 핸들러
9
- const handleScroll = useCallback(() => {
9
+ const observerCallback = useCallback((entries) => {
10
+ entries.forEach(entry => {
11
+ if (entry.isIntersecting && (!triggerOnce || !hasTriggered)) {
12
+ setIsAnimating(true);
13
+ setTimeout(() => {
14
+ setIsVisible(true);
15
+ setHasTriggered(true);
16
+ setProgress(1);
17
+ setIsAnimating(false);
18
+ }, delay);
19
+ }
20
+ });
21
+ }, [triggerOnce, hasTriggered, delay]);
22
+ useEffect(() => {
10
23
  if (!ref.current)
11
24
  return;
12
- const rect = ref.current.getBoundingClientRect();
13
- const threshold = window.innerHeight * scrollThreshold;
14
- const shouldReveal = rect.top <= threshold;
15
- if (shouldReveal && !isRevealed) {
16
- setIsRevealed(true);
17
- setIsAnimating(true);
18
- setProgress(0);
19
- onStart?.();
20
- setTimeout(() => {
21
- setIsAnimating(false);
22
- setProgress(1);
23
- onComplete?.();
24
- }, duration);
25
- }
26
- }, [isRevealed, scrollThreshold, duration, onStart, onComplete]);
27
- // 스크롤 이벤트 리스너 설정
28
- useEffect(() => {
29
- window.addEventListener('scroll', handleScroll, { passive: true });
30
- handleScroll();
25
+ const observer = new IntersectionObserver(observerCallback, {
26
+ threshold,
27
+ rootMargin
28
+ });
29
+ observer.observe(ref.current);
31
30
  return () => {
32
- window.removeEventListener('scroll', handleScroll);
31
+ observer.disconnect();
33
32
  };
34
- }, [handleScroll]);
35
- // 모션 시작 함수
36
- const start = useCallback(() => {
37
- if (!isRevealed) {
38
- setIsRevealed(true);
39
- setIsAnimating(true);
40
- setProgress(0);
41
- onStart?.();
42
- setTimeout(() => {
43
- setIsAnimating(false);
44
- setProgress(1);
45
- onComplete?.();
46
- }, duration);
33
+ }, [observerCallback, threshold, rootMargin]);
34
+ // 모션 스타일 생성 - 메모이제이션으로 불필요한 리렌더링 방지
35
+ const style = useMemo(() => {
36
+ const baseTransition = 'all 700ms ease-out';
37
+ if (!isVisible) {
38
+ switch (motionType) {
39
+ case 'fadeIn':
40
+ return {
41
+ opacity: 0,
42
+ transition: baseTransition
43
+ };
44
+ case 'slideUp':
45
+ return {
46
+ opacity: 0,
47
+ transform: 'translateY(32px)',
48
+ transition: baseTransition
49
+ };
50
+ case 'slideLeft':
51
+ return {
52
+ opacity: 0,
53
+ transform: 'translateX(-32px)',
54
+ transition: baseTransition
55
+ };
56
+ case 'slideRight':
57
+ return {
58
+ opacity: 0,
59
+ transform: 'translateX(32px)',
60
+ transition: baseTransition
61
+ };
62
+ case 'scaleIn':
63
+ return {
64
+ opacity: 0,
65
+ transform: 'scale(0.95)',
66
+ transition: baseTransition
67
+ };
68
+ case 'bounceIn':
69
+ return {
70
+ opacity: 0,
71
+ transform: 'scale(0.75)',
72
+ transition: baseTransition
73
+ };
74
+ default:
75
+ return {
76
+ opacity: 0,
77
+ transition: baseTransition
78
+ };
79
+ }
47
80
  }
48
- }, [isRevealed, duration, onStart, onComplete]);
49
- // 모션 중단 함수
50
- const stop = useCallback(() => {
51
- setIsAnimating(false);
52
- onStop?.();
53
- }, [onStop]);
54
- // 모션 리셋 함수
81
+ // 보이는 상태일
82
+ return {
83
+ opacity: 1,
84
+ transform: 'none',
85
+ transition: baseTransition
86
+ };
87
+ }, [isVisible, motionType]);
88
+ const start = useCallback(() => {
89
+ setIsAnimating(true);
90
+ setTimeout(() => {
91
+ setIsVisible(true);
92
+ setProgress(1);
93
+ setIsAnimating(false);
94
+ }, delay);
95
+ }, [delay]);
55
96
  const reset = useCallback(() => {
56
- setIsRevealed(false);
97
+ setIsVisible(false);
57
98
  setIsAnimating(false);
58
99
  setProgress(0);
59
- onReset?.();
60
- }, [onReset]);
61
- // 모션 일시정지 함수
62
- const pause = useCallback(() => {
100
+ setHasTriggered(false);
101
+ }, []);
102
+ const stop = useCallback(() => {
63
103
  setIsAnimating(false);
64
104
  }, []);
65
- // 모션 재개 함수
66
- const resume = useCallback(() => {
67
- if (isRevealed) {
68
- setIsAnimating(true);
69
- }
70
- }, [isRevealed]);
71
- // 스타일 계산
72
- const style = {
73
- transform: `
74
- scale(${isRevealed ? revealScale : initialScale})
75
- rotate(${isRevealed ? revealRotate : initialRotate}deg)
76
- translate(${isRevealed ? revealTranslateX : initialTranslateX}px, ${isRevealed ? revealTranslateY : initialTranslateY}px)
77
- `,
78
- opacity: isRevealed ? revealOpacity : initialOpacity,
79
- transition: `all ${duration}ms ${easing}`,
80
- willChange: 'transform, opacity'
81
- };
82
105
  return {
83
106
  ref,
84
- isVisible: isRevealed,
107
+ isVisible,
85
108
  isAnimating,
86
- style,
87
109
  progress,
110
+ style,
88
111
  start,
89
- stop,
90
112
  reset,
91
- pause,
92
- resume
113
+ stop
93
114
  };
94
115
  }
95
116
  //# sourceMappingURL=useScrollReveal.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useScrollReveal.js","sourceRoot":"","sources":["../../src/hooks/useScrollReveal.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAkBhE,MAAM,UAAU,eAAe,CAC7B,UAA+B,EAAE;IAEjC,MAAM,EACJ,QAAQ,GAAG,GAAG,EACd,MAAM,GAAG,UAAU,EACnB,WAAW,GAAG,CAAC,EACf,aAAa,GAAG,CAAC,EACjB,YAAY,GAAG,CAAC,EAChB,gBAAgB,GAAG,CAAC,EACpB,gBAAgB,GAAG,CAAC,EACpB,YAAY,GAAG,GAAG,EAClB,cAAc,GAAG,CAAC,EAClB,aAAa,GAAG,CAAC,EACjB,iBAAiB,GAAG,EAAE,EACtB,iBAAiB,GAAG,CAAC,EACrB,eAAe,GAAG,GAAG,EACrB,eAAe,GAAG,MAAM,EACxB,UAAU,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EACrC,GAAG,OAAO,CAAA;IAEX,MAAM,GAAG,GAAG,MAAM,CAAI,IAAI,CAAC,CAAA;IAC3B,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACnD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IACrD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IAE3C,cAAc;IACd,MAAM,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE;QACpC,IAAI,CAAC,GAAG,CAAC,OAAO;YAAE,OAAM;QAExB,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAA;QAChD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,GAAG,eAAe,CAAA;QACtD,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,IAAI,SAAS,CAAA;QAE1C,IAAI,YAAY,IAAI,CAAC,UAAU,EAAE,CAAC;YAChC,aAAa,CAAC,IAAI,CAAC,CAAA;YACnB,cAAc,CAAC,IAAI,CAAC,CAAA;YACpB,WAAW,CAAC,CAAC,CAAC,CAAA;YACd,OAAO,EAAE,EAAE,CAAA;YAEX,UAAU,CAAC,GAAG,EAAE;gBACd,cAAc,CAAC,KAAK,CAAC,CAAA;gBACrB,WAAW,CAAC,CAAC,CAAC,CAAA;gBACd,UAAU,EAAE,EAAE,CAAA;YAChB,CAAC,EAAE,QAAQ,CAAC,CAAA;QACd,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,eAAe,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAA;IAEhE,iBAAiB;IACjB,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,YAAY,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QAClE,YAAY,EAAE,CAAA;QAEd,OAAO,GAAG,EAAE;YACV,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACpD,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;IAElB,WAAW;IACX,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,aAAa,CAAC,IAAI,CAAC,CAAA;YACnB,cAAc,CAAC,IAAI,CAAC,CAAA;YACpB,WAAW,CAAC,CAAC,CAAC,CAAA;YACd,OAAO,EAAE,EAAE,CAAA;YAEX,UAAU,CAAC,GAAG,EAAE;gBACd,cAAc,CAAC,KAAK,CAAC,CAAA;gBACrB,WAAW,CAAC,CAAC,CAAC,CAAA;gBACd,UAAU,EAAE,EAAE,CAAA;YAChB,CAAC,EAAE,QAAQ,CAAC,CAAA;QACd,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAA;IAE/C,WAAW;IACX,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,EAAE;QAC5B,cAAc,CAAC,KAAK,CAAC,CAAA;QACrB,MAAM,EAAE,EAAE,CAAA;IACZ,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,WAAW;IACX,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,aAAa,CAAC,KAAK,CAAC,CAAA;QACpB,cAAc,CAAC,KAAK,CAAC,CAAA;QACrB,WAAW,CAAC,CAAC,CAAC,CAAA;QACd,OAAO,EAAE,EAAE,CAAA;IACb,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,aAAa;IACb,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE;QAC7B,cAAc,CAAC,KAAK,CAAC,CAAA;IACvB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,WAAW;IACX,MAAM,MAAM,GAAG,WAAW,CAAC,GAAG,EAAE;QAC9B,IAAI,UAAU,EAAE,CAAC;YACf,cAAc,CAAC,IAAI,CAAC,CAAA;QACtB,CAAC;IACH,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAA;IAEhB,SAAS;IACT,MAAM,KAAK,GAAwB;QACjC,SAAS,EAAE;cACD,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,YAAY;eACtC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa;kBACtC,UAAU,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,iBAAiB,OAAO,UAAU,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,iBAAiB;KACtH;QACD,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,cAAc;QACpD,UAAU,EAAE,OAAO,QAAQ,MAAM,MAAM,EAAE;QACzC,UAAU,EAAE,oBAAoB;KACjC,CAAA;IAED,OAAO;QACL,GAAG;QACH,SAAS,EAAE,UAAU;QACrB,WAAW;QACX,KAAK;QACL,QAAQ;QACR,KAAK;QACL,IAAI;QACJ,KAAK;QACL,KAAK;QACL,MAAM;KACP,CAAA;AACH,CAAC"}
1
+ {"version":3,"file":"useScrollReveal.js","sourceRoot":"","sources":["../../src/hooks/useScrollReveal.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ import type { PageType, PageMotionsConfig, MotionRef } from '../types';
2
+ /**
3
+ * 1단계 API: 프리셋 기반 페이지 모션 (기존 방식)
4
+ *
5
+ * 사용법:
6
+ * ```typescript
7
+ * const motions = useSimplePageMotion('home')
8
+ * ```
9
+ *
10
+ * 지원하는 페이지 타입:
11
+ * - 'home': 홈페이지
12
+ * - 'dashboard': 대시보드
13
+ * - 'product': 제품 페이지
14
+ * - 'blog': 블로그
15
+ */
16
+ export declare function useSimplePageMotion(pageType: PageType): Record<string, MotionRef<HTMLElement>>;
17
+ /**
18
+ * 커스텀 페이지 모션 설정
19
+ *
20
+ * 사용법:
21
+ * ```typescript
22
+ * const motions = useCustomPageMotion({
23
+ * hero: { type: 'hero' },
24
+ * title: { type: 'title' }
25
+ * })
26
+ * ```
27
+ */
28
+ export declare function useCustomPageMotion(config: PageMotionsConfig): Record<string, MotionRef<HTMLElement>>;
29
+ //# sourceMappingURL=useSimplePageMotion.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSimplePageMotion.d.ts","sourceRoot":"","sources":["../../src/hooks/useSimplePageMotion.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,iBAAiB,EAAqB,SAAS,EAAE,MAAM,UAAU,CAAA;AAGzF;;;;;;;;;;;;;GAaG;AACH,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,0CAGrD;AAwID;;;;;;;;;;GAUG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,iBAAiB,0CAE5D"}
@@ -0,0 +1,145 @@
1
+ // ========================================
2
+ // 1단계: useSimplePageMotion (프리셋 기반) - 기존 방식
3
+ // ========================================
4
+ import { useRef, useEffect, useState, useCallback } from 'react';
5
+ import { getPagePreset, getMotionPreset, mergeWithPreset } from '../presets';
6
+ /**
7
+ * 1단계 API: 프리셋 기반 페이지 모션 (기존 방식)
8
+ *
9
+ * 사용법:
10
+ * ```typescript
11
+ * const motions = useSimplePageMotion('home')
12
+ * ```
13
+ *
14
+ * 지원하는 페이지 타입:
15
+ * - 'home': 홈페이지
16
+ * - 'dashboard': 대시보드
17
+ * - 'product': 제품 페이지
18
+ * - 'blog': 블로그
19
+ */
20
+ export function useSimplePageMotion(pageType) {
21
+ const config = getPagePreset(pageType);
22
+ return useSimplePageMotions(config);
23
+ }
24
+ /**
25
+ * 1단계 내부 구현: 간단한 페이지 모션 (상태 관리자 없음)
26
+ */
27
+ function useSimplePageMotions(config) {
28
+ const [motions, setMotions] = useState(new Map());
29
+ const observersRef = useRef(new Map());
30
+ // 모션 값 계산
31
+ const calculateMotionValues = useCallback((isVisible, elementConfig) => {
32
+ const preset = getMotionPreset(elementConfig.type);
33
+ const mergedConfig = mergeWithPreset(preset, elementConfig);
34
+ let opacity = isVisible ? 1 : 0;
35
+ let translateY = isVisible ? 0 : 20;
36
+ let translateX = 0;
37
+ let scale = isVisible ? 1 : 0.95;
38
+ return { opacity, translateY, translateX, scale };
39
+ }, []);
40
+ // 모션 초기화
41
+ useEffect(() => {
42
+ const newMotions = new Map();
43
+ Object.entries(config).forEach(([elementId, elementConfig]) => {
44
+ const ref = { current: null };
45
+ const { opacity, translateY, translateX, scale } = calculateMotionValues(false, elementConfig);
46
+ newMotions.set(elementId, {
47
+ ref,
48
+ style: {
49
+ opacity,
50
+ transform: `translate(${translateX}px, ${translateY}px) scale(${scale})`,
51
+ transition: `all ${elementConfig.duration || 700}ms ease-out`,
52
+ pointerEvents: 'auto',
53
+ willChange: 'transform, opacity'
54
+ },
55
+ isVisible: false,
56
+ isHovered: false,
57
+ isClicked: false
58
+ });
59
+ });
60
+ setMotions(newMotions);
61
+ }, [config, calculateMotionValues]);
62
+ // Intersection Observer 설정
63
+ useEffect(() => {
64
+ const visibleElements = new Set();
65
+ Object.entries(config).forEach(([elementId, elementConfig]) => {
66
+ const observer = new IntersectionObserver((entries) => {
67
+ entries.forEach(entry => {
68
+ if (entry.isIntersecting && !visibleElements.has(elementId)) {
69
+ visibleElements.add(elementId);
70
+ // 프리셋의 delay를 적용하여 모션 실행
71
+ const preset = getMotionPreset(elementConfig.type);
72
+ const mergedConfig = mergeWithPreset(preset, elementConfig);
73
+ const delay = mergedConfig.delay || 0;
74
+ setTimeout(() => {
75
+ const { opacity, translateY, translateX, scale } = calculateMotionValues(true, elementConfig);
76
+ setMotions(prev => {
77
+ const current = prev.get(elementId);
78
+ if (!current)
79
+ return prev;
80
+ const newMotion = {
81
+ ...current,
82
+ style: {
83
+ ...current.style,
84
+ opacity,
85
+ transform: `translate(${translateX}px, ${translateY}px) scale(${scale})`
86
+ },
87
+ isVisible: true
88
+ };
89
+ const newMap = new Map(prev);
90
+ newMap.set(elementId, newMotion);
91
+ return newMap;
92
+ });
93
+ if (process.env.NODE_ENV === 'development') {
94
+ console.log('모션 실행:', elementId, 'delay:', delay);
95
+ }
96
+ }, delay);
97
+ observer.unobserve(entry.target);
98
+ }
99
+ });
100
+ }, { threshold: elementConfig.threshold || 0.1 });
101
+ observersRef.current.set(elementId, observer);
102
+ });
103
+ // DOM이 렌더링된 후 observe 시작
104
+ const timer = setTimeout(() => {
105
+ Object.entries(config).forEach(([elementId]) => {
106
+ const observer = observersRef.current.get(elementId);
107
+ if (observer) {
108
+ const element = document.querySelector(`[data-motion-id="${elementId}"]`);
109
+ if (element) {
110
+ observer.observe(element);
111
+ }
112
+ }
113
+ });
114
+ }, 100);
115
+ return () => {
116
+ clearTimeout(timer);
117
+ observersRef.current.forEach(observer => observer.disconnect());
118
+ observersRef.current.clear();
119
+ };
120
+ }, [config, calculateMotionValues]);
121
+ // 모션 refs 반환
122
+ const getMotionRefs = useCallback(() => {
123
+ const result = {};
124
+ motions.forEach((motion, elementId) => {
125
+ result[elementId] = motion;
126
+ });
127
+ return result;
128
+ }, [motions]);
129
+ return getMotionRefs();
130
+ }
131
+ /**
132
+ * 커스텀 페이지 모션 설정
133
+ *
134
+ * 사용법:
135
+ * ```typescript
136
+ * const motions = useCustomPageMotion({
137
+ * hero: { type: 'hero' },
138
+ * title: { type: 'title' }
139
+ * })
140
+ * ```
141
+ */
142
+ export function useCustomPageMotion(config) {
143
+ return useSimplePageMotions(config);
144
+ }
145
+ //# sourceMappingURL=useSimplePageMotion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSimplePageMotion.js","sourceRoot":"","sources":["../../src/hooks/useSimplePageMotion.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,13 @@
1
- import { SlideOptions, BaseMotionReturn, MotionElement } from '../types';
2
- export declare function useSlideLeft<T extends MotionElement = HTMLDivElement>(options?: SlideOptions): BaseMotionReturn<T>;
1
+ import { BaseMotionReturn, MotionElement } from '../types';
2
+ export interface SlideLeftOptions {
3
+ distance?: number;
4
+ duration?: number;
5
+ delay?: number;
6
+ autoStart?: boolean;
7
+ easing?: string;
8
+ }
9
+ export declare function useSlideLeft<T extends MotionElement = HTMLDivElement>(options?: SlideLeftOptions): BaseMotionReturn<T> & {
10
+ translateX: number;
11
+ opacity: number;
12
+ };
3
13
  //# sourceMappingURL=useSlideLeft.d.ts.map