@hua-labs/motion-core 2.1.0-alpha.6 → 2.1.0-alpha.8

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 (174) hide show
  1. package/README.md +16 -10
  2. package/dist/index.d.mts +1091 -0
  3. package/dist/index.d.ts +1091 -35
  4. package/dist/index.js +4241 -65
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +4187 -0
  7. package/dist/index.mjs.map +1 -0
  8. package/package.json +7 -4
  9. package/dist/.tsbuildinfo +0 -1
  10. package/dist/core/MotionEngine.d.ts +0 -111
  11. package/dist/core/MotionEngine.d.ts.map +0 -1
  12. package/dist/core/MotionEngine.js +0 -206
  13. package/dist/core/MotionEngine.js.map +0 -1
  14. package/dist/core/PerformanceOptimizer.d.ts +0 -124
  15. package/dist/core/PerformanceOptimizer.d.ts.map +0 -1
  16. package/dist/core/PerformanceOptimizer.js +0 -334
  17. package/dist/core/PerformanceOptimizer.js.map +0 -1
  18. package/dist/core/TransitionEffects.d.ts +0 -76
  19. package/dist/core/TransitionEffects.d.ts.map +0 -1
  20. package/dist/core/TransitionEffects.js +0 -321
  21. package/dist/core/TransitionEffects.js.map +0 -1
  22. package/dist/hooks/useBounceIn.d.ts +0 -12
  23. package/dist/hooks/useBounceIn.d.ts.map +0 -1
  24. package/dist/hooks/useBounceIn.js +0 -75
  25. package/dist/hooks/useBounceIn.js.map +0 -1
  26. package/dist/hooks/useButtonEffect.d.ts +0 -48
  27. package/dist/hooks/useButtonEffect.d.ts.map +0 -1
  28. package/dist/hooks/useButtonEffect.js +0 -311
  29. package/dist/hooks/useButtonEffect.js.map +0 -1
  30. package/dist/hooks/useCardList.d.ts +0 -23
  31. package/dist/hooks/useCardList.d.ts.map +0 -1
  32. package/dist/hooks/useCardList.js +0 -119
  33. package/dist/hooks/useCardList.js.map +0 -1
  34. package/dist/hooks/useClickToggle.d.ts +0 -30
  35. package/dist/hooks/useClickToggle.d.ts.map +0 -1
  36. package/dist/hooks/useClickToggle.js +0 -137
  37. package/dist/hooks/useClickToggle.js.map +0 -1
  38. package/dist/hooks/useFadeIn.d.ts +0 -3
  39. package/dist/hooks/useFadeIn.d.ts.map +0 -1
  40. package/dist/hooks/useFadeIn.js +0 -107
  41. package/dist/hooks/useFadeIn.js.map +0 -1
  42. package/dist/hooks/useFocusToggle.d.ts +0 -30
  43. package/dist/hooks/useFocusToggle.d.ts.map +0 -1
  44. package/dist/hooks/useFocusToggle.js +0 -137
  45. package/dist/hooks/useFocusToggle.js.map +0 -1
  46. package/dist/hooks/useGesture.d.ts +0 -45
  47. package/dist/hooks/useGesture.d.ts.map +0 -1
  48. package/dist/hooks/useGesture.js +0 -274
  49. package/dist/hooks/useGesture.js.map +0 -1
  50. package/dist/hooks/useGestureMotion.d.ts +0 -26
  51. package/dist/hooks/useGestureMotion.d.ts.map +0 -1
  52. package/dist/hooks/useGestureMotion.js +0 -167
  53. package/dist/hooks/useGestureMotion.js.map +0 -1
  54. package/dist/hooks/useGradient.d.ts +0 -14
  55. package/dist/hooks/useGradient.d.ts.map +0 -1
  56. package/dist/hooks/useGradient.js +0 -87
  57. package/dist/hooks/useGradient.js.map +0 -1
  58. package/dist/hooks/useHoverMotion.d.ts +0 -5
  59. package/dist/hooks/useHoverMotion.d.ts.map +0 -1
  60. package/dist/hooks/useHoverMotion.js +0 -48
  61. package/dist/hooks/useHoverMotion.js.map +0 -1
  62. package/dist/hooks/useLoadingSpinner.d.ts +0 -30
  63. package/dist/hooks/useLoadingSpinner.d.ts.map +0 -1
  64. package/dist/hooks/useLoadingSpinner.js +0 -283
  65. package/dist/hooks/useLoadingSpinner.js.map +0 -1
  66. package/dist/hooks/useMotion.d.ts +0 -103
  67. package/dist/hooks/useMotion.d.ts.map +0 -1
  68. package/dist/hooks/useMotion.js +0 -266
  69. package/dist/hooks/useMotion.js.map +0 -1
  70. package/dist/hooks/useMotionState.d.ts +0 -29
  71. package/dist/hooks/useMotionState.d.ts.map +0 -1
  72. package/dist/hooks/useMotionState.js +0 -202
  73. package/dist/hooks/useMotionState.js.map +0 -1
  74. package/dist/hooks/useNavigation.d.ts +0 -40
  75. package/dist/hooks/useNavigation.d.ts.map +0 -1
  76. package/dist/hooks/useNavigation.js +0 -212
  77. package/dist/hooks/useNavigation.js.map +0 -1
  78. package/dist/hooks/usePageMotions.d.ts +0 -17
  79. package/dist/hooks/usePageMotions.d.ts.map +0 -1
  80. package/dist/hooks/usePageMotions.js +0 -352
  81. package/dist/hooks/usePageMotions.js.map +0 -1
  82. package/dist/hooks/usePulse.d.ts +0 -10
  83. package/dist/hooks/usePulse.d.ts.map +0 -1
  84. package/dist/hooks/usePulse.js +0 -108
  85. package/dist/hooks/usePulse.js.map +0 -1
  86. package/dist/hooks/useRepeat.d.ts +0 -21
  87. package/dist/hooks/useRepeat.d.ts.map +0 -1
  88. package/dist/hooks/useRepeat.js +0 -65
  89. package/dist/hooks/useRepeat.js.map +0 -1
  90. package/dist/hooks/useScaleIn.d.ts +0 -13
  91. package/dist/hooks/useScaleIn.d.ts.map +0 -1
  92. package/dist/hooks/useScaleIn.js +0 -72
  93. package/dist/hooks/useScaleIn.js.map +0 -1
  94. package/dist/hooks/useScrollProgress.d.ts +0 -11
  95. package/dist/hooks/useScrollProgress.d.ts.map +0 -1
  96. package/dist/hooks/useScrollProgress.js +0 -37
  97. package/dist/hooks/useScrollProgress.js.map +0 -1
  98. package/dist/hooks/useScrollReveal.d.ts +0 -14
  99. package/dist/hooks/useScrollReveal.d.ts.map +0 -1
  100. package/dist/hooks/useScrollReveal.js +0 -116
  101. package/dist/hooks/useScrollReveal.js.map +0 -1
  102. package/dist/hooks/useScrollToggle.d.ts +0 -17
  103. package/dist/hooks/useScrollToggle.d.ts.map +0 -1
  104. package/dist/hooks/useScrollToggle.js +0 -119
  105. package/dist/hooks/useScrollToggle.js.map +0 -1
  106. package/dist/hooks/useSimplePageMotion.d.ts +0 -29
  107. package/dist/hooks/useSimplePageMotion.d.ts.map +0 -1
  108. package/dist/hooks/useSimplePageMotion.js +0 -145
  109. package/dist/hooks/useSimplePageMotion.js.map +0 -1
  110. package/dist/hooks/useSkeleton.d.ts +0 -21
  111. package/dist/hooks/useSkeleton.d.ts.map +0 -1
  112. package/dist/hooks/useSkeleton.js +0 -139
  113. package/dist/hooks/useSkeleton.js.map +0 -1
  114. package/dist/hooks/useSlideDown.d.ts +0 -25
  115. package/dist/hooks/useSlideDown.d.ts.map +0 -1
  116. package/dist/hooks/useSlideDown.js +0 -263
  117. package/dist/hooks/useSlideDown.js.map +0 -1
  118. package/dist/hooks/useSlideLeft.d.ts +0 -13
  119. package/dist/hooks/useSlideLeft.d.ts.map +0 -1
  120. package/dist/hooks/useSlideLeft.js +0 -72
  121. package/dist/hooks/useSlideLeft.js.map +0 -1
  122. package/dist/hooks/useSlideRight.d.ts +0 -13
  123. package/dist/hooks/useSlideRight.d.ts.map +0 -1
  124. package/dist/hooks/useSlideRight.js +0 -72
  125. package/dist/hooks/useSlideRight.js.map +0 -1
  126. package/dist/hooks/useSlideUp.d.ts +0 -3
  127. package/dist/hooks/useSlideUp.d.ts.map +0 -1
  128. package/dist/hooks/useSlideUp.js +0 -122
  129. package/dist/hooks/useSlideUp.js.map +0 -1
  130. package/dist/hooks/useSmartMotion.d.ts +0 -31
  131. package/dist/hooks/useSmartMotion.d.ts.map +0 -1
  132. package/dist/hooks/useSmartMotion.js +0 -257
  133. package/dist/hooks/useSmartMotion.js.map +0 -1
  134. package/dist/hooks/useSpringMotion.d.ts +0 -22
  135. package/dist/hooks/useSpringMotion.d.ts.map +0 -1
  136. package/dist/hooks/useSpringMotion.js +0 -133
  137. package/dist/hooks/useSpringMotion.js.map +0 -1
  138. package/dist/hooks/useStaggerMotion.d.ts +0 -81
  139. package/dist/hooks/useStaggerMotion.d.ts.map +0 -1
  140. package/dist/hooks/useStaggerMotion.js +0 -113
  141. package/dist/hooks/useStaggerMotion.js.map +0 -1
  142. package/dist/hooks/useToggleMotion.d.ts +0 -16
  143. package/dist/hooks/useToggleMotion.d.ts.map +0 -1
  144. package/dist/hooks/useToggleMotion.js +0 -53
  145. package/dist/hooks/useToggleMotion.js.map +0 -1
  146. package/dist/hooks/useUnifiedMotion.d.ts +0 -51
  147. package/dist/hooks/useUnifiedMotion.d.ts.map +0 -1
  148. package/dist/hooks/useUnifiedMotion.js +0 -106
  149. package/dist/hooks/useUnifiedMotion.js.map +0 -1
  150. package/dist/hooks/useVisibilityToggle.d.ts +0 -15
  151. package/dist/hooks/useVisibilityToggle.d.ts.map +0 -1
  152. package/dist/hooks/useVisibilityToggle.js +0 -106
  153. package/dist/hooks/useVisibilityToggle.js.map +0 -1
  154. package/dist/index.d.ts.map +0 -1
  155. package/dist/managers/MotionStateManager.d.ts +0 -63
  156. package/dist/managers/MotionStateManager.d.ts.map +0 -1
  157. package/dist/managers/MotionStateManager.js +0 -159
  158. package/dist/managers/MotionStateManager.js.map +0 -1
  159. package/dist/presets/index.d.ts +0 -16
  160. package/dist/presets/index.d.ts.map +0 -1
  161. package/dist/presets/index.js +0 -120
  162. package/dist/presets/index.js.map +0 -1
  163. package/dist/types/common.d.ts +0 -155
  164. package/dist/types/common.d.ts.map +0 -1
  165. package/dist/types/common.js +0 -5
  166. package/dist/types/common.js.map +0 -1
  167. package/dist/types/index.d.ts +0 -77
  168. package/dist/types/index.d.ts.map +0 -1
  169. package/dist/types/index.js +0 -5
  170. package/dist/types/index.js.map +0 -1
  171. package/dist/utils/easing.d.ts +0 -98
  172. package/dist/utils/easing.d.ts.map +0 -1
  173. package/dist/utils/easing.js +0 -233
  174. package/dist/utils/easing.js.map +0 -1
@@ -1,352 +0,0 @@
1
- // ========================================
2
- // 2단계: usePageMotions (페이지 레벨) - 상태 관리자 버전
3
- // ========================================
4
- import { useRef, useEffect, useState, useCallback } from 'react';
5
- import { getMotionPreset, mergeWithPreset } from '../presets';
6
- import { motionStateManager } from '../managers/MotionStateManager';
7
- /**
8
- * 2단계 API: 페이지 레벨 모션 관리 (상태 관리자 버전)
9
- *
10
- * 사용법:
11
- * ```typescript
12
- * const motions = usePageMotions({
13
- * hero: { type: 'hero' },
14
- * title: { type: 'title' },
15
- * button: { type: 'button', hover: true, click: true }
16
- * })
17
- * ```
18
- */
19
- export function usePageMotions(config) {
20
- const [motions, setMotions] = useState(new Map());
21
- const observersRef = useRef(new Map());
22
- const unsubscribeRef = useRef(new Map());
23
- const [resetKey, setResetKey] = useState(0);
24
- // 리셋 함수
25
- const reset = useCallback(() => {
26
- // 기존 observer들 정리
27
- observersRef.current.forEach(observer => observer.disconnect());
28
- observersRef.current.clear();
29
- // 구독 해제
30
- unsubscribeRef.current.forEach(unsubscribe => unsubscribe());
31
- unsubscribeRef.current.clear();
32
- // 상태 관리자 리셋
33
- motionStateManager.reset();
34
- // 모션 상태 초기화
35
- setMotions(new Map());
36
- // 리셋 키 증가로 useEffect 재실행
37
- setResetKey(prev => prev + 1);
38
- }, []);
39
- // 모션 값 계산
40
- const calculateMotionValues = useCallback((state, elementConfig) => {
41
- const preset = getMotionPreset(elementConfig.type);
42
- const mergedConfig = mergeWithPreset(preset, elementConfig);
43
- // 스크롤 리빌 모션 처리
44
- let opacity = state.finalVisibility ? 1 : 0;
45
- let translateY = state.finalVisibility ? 0 : 20;
46
- let translateX = 0;
47
- let scale = state.finalVisibility ? 1 : 0.95;
48
- // 호버 효과 (더 눈에 띄게)
49
- if (mergedConfig.hover && state.isHovered) {
50
- scale *= 1.1; // 10% 확대
51
- translateY -= 5; // 5px 위로
52
- opacity = 0.9; // 약간 투명도
53
- }
54
- // 클릭 효과 (더 눈에 띄게)
55
- if (mergedConfig.click && state.isClicked) {
56
- scale *= 0.9; // 10% 축소
57
- translateY += 3; // 3px 아래로
58
- opacity = 0.8; // 더 투명하게
59
- }
60
- return { opacity, translateY, translateX, scale };
61
- }, []); // 빈 의존성 배열로 고정
62
- // 모션 상태 업데이트
63
- const updateMotionState = useCallback((elementId, updates) => {
64
- const currentState = motionStateManager.getState(elementId);
65
- if (!currentState)
66
- return;
67
- // 상태 관리자에 업데이트 적용
68
- if (updates.opacity !== undefined || updates.translateY !== undefined ||
69
- updates.translateX !== undefined || updates.scale !== undefined) {
70
- motionStateManager.updateMotionValues(elementId, updates);
71
- }
72
- if (updates.isHovered !== undefined) {
73
- currentState.isHovered = updates.isHovered;
74
- // 호버 상태 변경 시 리스너들에게 알림
75
- motionStateManager.notifyListeners(elementId, currentState);
76
- }
77
- if (updates.isClicked !== undefined) {
78
- currentState.isClicked = updates.isClicked;
79
- // 클릭 상태 변경 시 리스너들에게 알림
80
- motionStateManager.notifyListeners(elementId, currentState);
81
- }
82
- }, []); // 빈 의존성 배열로 고정
83
- // 모션 초기화
84
- useEffect(() => {
85
- const newMotions = new Map();
86
- // config가 유효하지 않으면 early return
87
- if (!config || typeof config !== 'object') {
88
- if (process.env.NODE_ENV === 'development') {
89
- console.warn('usePageMotions: config가 유효하지 않습니다:', config);
90
- }
91
- return;
92
- }
93
- // 페이지별로 상태 관리자 초기화 (기존 상태 클리어)
94
- motionStateManager.reset();
95
- Object.entries(config).forEach(([elementId, elementConfig]) => {
96
- const ref = { current: null };
97
- // 상태 관리자에 요소 초기화
98
- motionStateManager.initializeElement(elementId, elementConfig);
99
- // 초기 상태 가져오기
100
- const initialState = motionStateManager.getState(elementId);
101
- if (process.env.NODE_ENV === 'development') {
102
- console.log(`초기 상태 [${elementId}]:`, initialState);
103
- }
104
- const { opacity, translateY, translateX, scale } = calculateMotionValues(initialState, elementConfig);
105
- newMotions.set(elementId, {
106
- ref,
107
- style: {
108
- opacity,
109
- transform: `translate(${translateX}px, ${translateY}px) scale(${scale})`,
110
- transition: `all ${elementConfig.duration || 700}ms ease-out`,
111
- pointerEvents: 'auto',
112
- willChange: 'transform, opacity'
113
- },
114
- isVisible: initialState.finalVisibility,
115
- isHovered: initialState.isHovered,
116
- isClicked: initialState.isClicked
117
- });
118
- // 상태 변경 리스너 등록
119
- const unsubscribe = motionStateManager.subscribe(elementId, (newState) => {
120
- const { opacity, translateY, translateX, scale } = calculateMotionValues(newState, elementConfig);
121
- setMotions(prev => {
122
- const current = prev.get(elementId);
123
- if (!current)
124
- return prev;
125
- // 변경 감지: 실제로 값이 변경되었을 때만 업데이트
126
- const transform = `translate(${translateX}px, ${translateY}px) scale(${scale})`;
127
- const hasChanged = current.style.opacity !== opacity ||
128
- current.style.transform !== transform ||
129
- current.isVisible !== newState.finalVisibility ||
130
- current.isHovered !== newState.isHovered ||
131
- current.isClicked !== newState.isClicked;
132
- // 변경이 없으면 이전 Map 반환 (불필요한 리렌더링 방지)
133
- if (!hasChanged)
134
- return prev;
135
- const newMotion = {
136
- ...current,
137
- style: {
138
- ...current.style,
139
- opacity,
140
- transform
141
- },
142
- isVisible: newState.finalVisibility,
143
- isHovered: newState.isHovered,
144
- isClicked: newState.isClicked
145
- };
146
- // 변경된 항목만 업데이트하는 새 Map 생성
147
- const newMap = new Map(prev);
148
- newMap.set(elementId, newMotion);
149
- return newMap;
150
- });
151
- });
152
- unsubscribeRef.current.set(elementId, unsubscribe);
153
- });
154
- setMotions(newMotions);
155
- // 클린업
156
- return () => {
157
- unsubscribeRef.current.forEach(unsubscribe => unsubscribe());
158
- unsubscribeRef.current.clear();
159
- // 페이지 언마운트 시 상태 관리자 클리어
160
- motionStateManager.reset();
161
- };
162
- }, [config, resetKey]); // resetKey 추가
163
- // Intersection Observer 설정
164
- useEffect(() => {
165
- const visibleElements = new Set();
166
- // config가 유효하지 않으면 early return
167
- if (!config || typeof config !== 'object') {
168
- return;
169
- }
170
- Object.entries(config).forEach(([elementId, elementConfig]) => {
171
- const observer = new IntersectionObserver((entries) => {
172
- entries.forEach(entry => {
173
- if (entry.isIntersecting && !visibleElements.has(elementId)) {
174
- visibleElements.add(elementId);
175
- // 프리셋의 delay를 적용하여 모션 실행
176
- const preset = getMotionPreset(elementConfig.type);
177
- const mergedConfig = mergeWithPreset(preset, elementConfig);
178
- const delay = mergedConfig.delay || 0;
179
- setTimeout(() => {
180
- // 외부 트리거로 가시성 설정
181
- motionStateManager.setTriggeredVisibility(elementId, true);
182
- if (process.env.NODE_ENV === 'development') {
183
- console.log('모션 실행:', elementId, 'delay:', delay);
184
- }
185
- }, delay);
186
- observer.unobserve(entry.target);
187
- }
188
- });
189
- }, {
190
- threshold: elementConfig.threshold || 0.3, // 30% 보여야 실행
191
- rootMargin: '0px 0px -50px 0px' // 하단에서 50px 전에 실행
192
- });
193
- observersRef.current.set(elementId, observer);
194
- });
195
- // DOM이 렌더링된 후 observe 시작
196
- const timer = setTimeout(() => {
197
- // config가 유효하지 않으면 early return
198
- if (!config || typeof config !== 'object') {
199
- return;
200
- }
201
- Object.entries(config).forEach(([elementId]) => {
202
- const observer = observersRef.current.get(elementId);
203
- if (observer) {
204
- const element = document.querySelector(`[data-motion-id="${elementId}"]`);
205
- if (element) {
206
- observer.observe(element);
207
- }
208
- }
209
- });
210
- }, 100);
211
- return () => {
212
- clearTimeout(timer);
213
- observersRef.current.forEach(observer => observer.disconnect());
214
- observersRef.current.clear();
215
- };
216
- }, [config, resetKey]); // resetKey 추가
217
- // 이벤트 리스너 설정
218
- useEffect(() => {
219
- // config가 유효하지 않으면 early return
220
- if (!config || typeof config !== 'object') {
221
- return;
222
- }
223
- const handleMouseEnter = (event) => {
224
- const target = event.target;
225
- if (!target)
226
- return;
227
- // data-motion-id를 가진 요소나 그 하위 요소에서 찾기
228
- let element = target;
229
- let elementId = null;
230
- while (element && element !== document.body) {
231
- if (element.getAttribute && typeof element.getAttribute === 'function') {
232
- elementId = element.getAttribute('data-motion-id');
233
- if (elementId)
234
- break;
235
- }
236
- element = element.parentElement;
237
- }
238
- if (elementId && config[elementId]?.hover) {
239
- if (process.env.NODE_ENV === 'development') {
240
- console.log('호버 시작:', elementId);
241
- }
242
- updateMotionState(elementId, { isHovered: true });
243
- }
244
- };
245
- const handleMouseLeave = (event) => {
246
- const target = event.target;
247
- if (!target)
248
- return;
249
- // data-motion-id를 가진 요소나 그 하위 요소에서 찾기
250
- let element = target;
251
- let elementId = null;
252
- while (element && element !== document.body) {
253
- if (element.getAttribute && typeof element.getAttribute === 'function') {
254
- elementId = element.getAttribute('data-motion-id');
255
- if (elementId)
256
- break;
257
- }
258
- element = element.parentElement;
259
- }
260
- if (elementId && config[elementId]?.hover) {
261
- if (process.env.NODE_ENV === 'development') {
262
- console.log('호버 종료:', elementId);
263
- }
264
- updateMotionState(elementId, { isHovered: false });
265
- }
266
- };
267
- const handleMouseDown = (event) => {
268
- const target = event.target;
269
- if (!target)
270
- return;
271
- // data-motion-id를 가진 요소나 그 하위 요소에서 찾기
272
- let element = target;
273
- let elementId = null;
274
- while (element && element !== document.body) {
275
- if (element.getAttribute && typeof element.getAttribute === 'function') {
276
- elementId = element.getAttribute('data-motion-id');
277
- if (elementId)
278
- break;
279
- }
280
- element = element.parentElement;
281
- }
282
- if (elementId && config[elementId]?.click) {
283
- if (process.env.NODE_ENV === 'development') {
284
- console.log('클릭 시작:', elementId);
285
- }
286
- updateMotionState(elementId, { isClicked: true });
287
- }
288
- };
289
- const handleMouseUp = (event) => {
290
- const target = event.target;
291
- if (!target)
292
- return;
293
- // data-motion-id를 가진 요소나 그 하위 요소에서 찾기
294
- let element = target;
295
- let elementId = null;
296
- while (element && element !== document.body) {
297
- if (element.getAttribute && typeof element.getAttribute === 'function') {
298
- elementId = element.getAttribute('data-motion-id');
299
- if (elementId)
300
- break;
301
- }
302
- element = element.parentElement;
303
- }
304
- if (elementId && config[elementId]?.click) {
305
- if (process.env.NODE_ENV === 'development') {
306
- console.log('클릭 종료:', elementId);
307
- }
308
- updateMotionState(elementId, { isClicked: false });
309
- }
310
- };
311
- // 이벤트 위임: bubble phase 사용 (capture phase보다 성능 우수)
312
- // 각 요소에 직접 등록하는 대신 document에 한 번만 등록하여 메모리 효율성 향상
313
- const timer = setTimeout(() => {
314
- document.addEventListener('mouseenter', handleMouseEnter, false);
315
- document.addEventListener('mouseleave', handleMouseLeave, false);
316
- document.addEventListener('mousedown', handleMouseDown, false);
317
- document.addEventListener('mouseup', handleMouseUp, false);
318
- }, 200);
319
- return () => {
320
- clearTimeout(timer);
321
- document.removeEventListener('mouseenter', handleMouseEnter, false);
322
- document.removeEventListener('mouseleave', handleMouseLeave, false);
323
- document.removeEventListener('mousedown', handleMouseDown, false);
324
- document.removeEventListener('mouseup', handleMouseUp, false);
325
- };
326
- }, [config]); // config 직접 사용 (참조 안정성)
327
- // 디버그 모드 (개발 환경에서만) - 제거됨
328
- // useEffect(() => {
329
- // const isDevelopment = typeof window !== 'undefined' && window.location.hostname === 'localhost'
330
- //
331
- // if (isDevelopment) {
332
- // const interval = setInterval(() => {
333
- // motionStateManager.debug()
334
- // }, 5000)
335
- //
336
- // return () => clearInterval(interval)
337
- // }
338
- // }, [])
339
- // 모션 refs 반환
340
- const getMotionRefs = useCallback(() => {
341
- const result = {};
342
- motions.forEach((motion, elementId) => {
343
- result[elementId] = motion;
344
- });
345
- return result;
346
- }, [motions]);
347
- return {
348
- ...getMotionRefs(),
349
- reset
350
- };
351
- }
352
- //# sourceMappingURL=usePageMotions.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"usePageMotions.js","sourceRoot":"","sources":["../../src/hooks/usePageMotions.ts"],"names":[],"mappings":"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"}
@@ -1,10 +0,0 @@
1
- import { BaseMotionReturn, MotionElement } from '../types';
2
- export interface PulseOptions {
3
- duration?: number;
4
- intensity?: number;
5
- repeat?: number;
6
- yoyo?: boolean;
7
- autoStart?: boolean;
8
- }
9
- export declare function usePulse<T extends MotionElement = HTMLDivElement>(options?: PulseOptions): BaseMotionReturn<T>;
10
- //# sourceMappingURL=usePulse.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"usePulse.d.ts","sourceRoot":"","sources":["../../src/hooks/usePulse.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAG1D,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAGD,wBAAgB,QAAQ,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EAC/D,OAAO,GAAE,YAAiB,GACzB,gBAAgB,CAAC,CAAC,CAAC,CA8HrB"}
@@ -1,108 +0,0 @@
1
- import { useRef, useEffect, useCallback, useState, useMemo } from 'react';
2
- import { getEasing } from '../utils/easing';
3
- // 💫 진짜 간단한 펄스 훅!
4
- export function usePulse(options = {}) {
5
- const { duration = 3000, intensity = 1, repeat = Infinity, yoyo = true, autoStart = false } = options;
6
- const ref = useRef(null);
7
- const [isAnimating, setIsAnimating] = useState(false);
8
- const [isVisible, setIsVisible] = useState(true);
9
- const [progress, setProgress] = useState(0);
10
- const motionRef = useRef(null);
11
- // 이징 함수 메모이제이션 (애니메이션 루프 내 반복 호출 방지)
12
- const easingFn = useMemo(() => getEasing('easeInOut'), []);
13
- // 🚀 모션 시작
14
- const start = useCallback(() => {
15
- if (!ref.current)
16
- return;
17
- const element = ref.current;
18
- let repeatCount = 0;
19
- setIsAnimating(true);
20
- const animate = (startTime) => {
21
- const updateMotion = (currentTime) => {
22
- const elapsed = currentTime - startTime;
23
- const progress = Math.min(elapsed / duration, 1);
24
- const easedProgress = easingFn(progress);
25
- // Yoyo 효과
26
- const finalProgress = yoyo && repeatCount % 2 === 1 ? 1 - easedProgress : easedProgress;
27
- // 펄스 효과 (투명도 변화)
28
- const opacity = 0.3 + (0.7 * finalProgress * intensity);
29
- element.style.opacity = opacity.toString();
30
- setProgress(progress);
31
- if (progress < 1) {
32
- motionRef.current = requestAnimationFrame(updateMotion);
33
- }
34
- else {
35
- repeatCount++;
36
- if (repeat === Infinity || repeatCount < repeat) {
37
- // 다음 반복 시작
38
- motionRef.current = requestAnimationFrame(() => animate(performance.now()));
39
- }
40
- else {
41
- setIsAnimating(false);
42
- }
43
- }
44
- };
45
- motionRef.current = requestAnimationFrame(updateMotion);
46
- };
47
- animate(performance.now());
48
- }, [duration, intensity, repeat, yoyo, easingFn]);
49
- // 🛑 모션 정지
50
- const stop = useCallback(() => {
51
- if (motionRef.current) {
52
- cancelAnimationFrame(motionRef.current);
53
- motionRef.current = null;
54
- }
55
- setIsAnimating(false);
56
- }, []);
57
- // 🔄 모션 리셋
58
- const reset = useCallback(() => {
59
- // 모션 중단
60
- if (motionRef.current) {
61
- cancelAnimationFrame(motionRef.current);
62
- motionRef.current = null;
63
- }
64
- // 상태 초기화
65
- setIsAnimating(false);
66
- // DOM 요소 초기 상태로 복원
67
- if (ref.current) {
68
- const element = ref.current;
69
- // opacity를 1로 설정하고 transition 제거하여 즉시 적용
70
- element.style.transition = 'none';
71
- element.style.opacity = '1';
72
- // 다음 프레임에서 transition 복원
73
- requestAnimationFrame(() => {
74
- element.style.transition = '';
75
- });
76
- }
77
- }, []);
78
- // 자동 시작
79
- useEffect(() => {
80
- if (autoStart) {
81
- start();
82
- }
83
- }, [autoStart, start]);
84
- // 컴포넌트 언마운트 시 정리
85
- useEffect(() => {
86
- return () => {
87
- if (motionRef.current) {
88
- cancelAnimationFrame(motionRef.current);
89
- }
90
- };
91
- }, []);
92
- // 스타일 계산
93
- const style = useMemo(() => ({
94
- opacity: isAnimating ? 0.3 + (0.7 * progress * intensity) : 1,
95
- transition: isAnimating ? 'none' : 'opacity 0.3s ease-in-out'
96
- }), [isAnimating, progress, intensity]);
97
- return {
98
- ref,
99
- isVisible,
100
- isAnimating,
101
- style,
102
- progress,
103
- start,
104
- stop,
105
- reset
106
- };
107
- }
108
- //# sourceMappingURL=usePulse.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"usePulse.js","sourceRoot":"","sources":["../../src/hooks/usePulse.ts"],"names":[],"mappings":"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"}
@@ -1,21 +0,0 @@
1
- export interface RepeatConfig {
2
- duration?: number;
3
- delay?: number;
4
- autoStart?: boolean;
5
- type?: 'pulse' | 'bounce' | 'wave' | 'fade';
6
- intensity?: number;
7
- }
8
- export interface RepeatState {
9
- scale: number;
10
- opacity: number;
11
- isAnimating: boolean;
12
- }
13
- export declare function useRepeat(config?: RepeatConfig): {
14
- ref: (element: HTMLDivElement | null) => void;
15
- scale: number;
16
- opacity: number;
17
- isAnimating: boolean;
18
- start: () => void;
19
- stop: () => void;
20
- };
21
- //# sourceMappingURL=useRepeat.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useRepeat.d.ts","sourceRoot":"","sources":["../../src/hooks/useRepeat.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,IAAI,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAA;IAC3C,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,EAAE,OAAO,CAAA;CACrB;AAED,wBAAgB,SAAS,CAAC,MAAM,GAAE,YAAiB;mBA+DxB,cAAc,GAAG,IAAI;;;;;;EAc/C"}
@@ -1,65 +0,0 @@
1
- import { useRef, useState, useEffect } from 'react';
2
- export function useRepeat(config = {}) {
3
- const { duration = 1000, delay = 0, autoStart = true, type = 'pulse', intensity = 0.1 } = config;
4
- const ref = useRef(null);
5
- const [scale, setScale] = useState(1);
6
- const [opacity, setOpacity] = useState(1);
7
- const [isAnimating, setIsAnimating] = useState(false);
8
- const animate = () => {
9
- setIsAnimating(true);
10
- switch (type) {
11
- case 'pulse':
12
- setScale(1 + intensity);
13
- setTimeout(() => setScale(1), duration / 2);
14
- break;
15
- case 'bounce':
16
- setScale(1 + intensity);
17
- setTimeout(() => setScale(1 - intensity), duration / 3);
18
- setTimeout(() => setScale(1), duration);
19
- break;
20
- case 'wave':
21
- setScale(1 + intensity);
22
- setTimeout(() => setScale(1 - intensity), duration / 2);
23
- setTimeout(() => setScale(1), duration);
24
- break;
25
- case 'fade':
26
- setOpacity(0.5);
27
- setTimeout(() => setOpacity(1), duration / 2);
28
- break;
29
- }
30
- setTimeout(() => {
31
- setIsAnimating(false);
32
- if (autoStart) {
33
- animate();
34
- }
35
- }, duration);
36
- };
37
- const start = () => {
38
- setTimeout(() => animate(), delay);
39
- };
40
- const stop = () => {
41
- setIsAnimating(false);
42
- setScale(1);
43
- setOpacity(1);
44
- };
45
- useEffect(() => {
46
- if (autoStart) {
47
- start();
48
- }
49
- return () => stop();
50
- }, []);
51
- const setRef = (element) => {
52
- if (ref.current !== element) {
53
- ref.current = element;
54
- }
55
- };
56
- return {
57
- ref: setRef,
58
- scale,
59
- opacity,
60
- isAnimating,
61
- start,
62
- stop
63
- };
64
- }
65
- //# sourceMappingURL=useRepeat.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useRepeat.js","sourceRoot":"","sources":["../../src/hooks/useRepeat.ts"],"names":[],"mappings":"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"}
@@ -1,13 +0,0 @@
1
- import { BaseMotionReturn, MotionElement } from '../types';
2
- export interface ScaleInOptions {
3
- scale?: number;
4
- duration?: number;
5
- delay?: number;
6
- autoStart?: boolean;
7
- easing?: string;
8
- }
9
- export declare function useScaleIn<T extends MotionElement = HTMLDivElement>(options?: ScaleInOptions): BaseMotionReturn<T> & {
10
- scale: number;
11
- opacity: number;
12
- };
13
- //# sourceMappingURL=useScaleIn.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useScaleIn.d.ts","sourceRoot":"","sources":["../../src/hooks/useScaleIn.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE1D,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,wBAAgB,UAAU,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EACjE,OAAO,GAAE,cAAmB,GAC3B,gBAAgB,CAAC,CAAC,CAAC,GAAG;IACvB,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;CAChB,CAqFA"}