@hua-labs/motion-core 2.0.0 → 2.1.0-alpha.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 +1 @@
1
- {"version":3,"file":"useHoverMotion.js","sourceRoot":"","sources":["../../src/hooks/useHoverMotion.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useHoverMotion.js","sourceRoot":"","sources":["../../src/hooks/useHoverMotion.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAEtD,MAAM,UAAU,cAAc,CAC5B,UAA6B,EAC7B,UAGI,EAAE;IAEN,MAAM,EACJ,OAAO,GAAG,OAAO,EACjB,OAAO,GAAG,SAAS,EACpB,GAAG,OAAO,CAAA;IAEX,MAAM,UAAU,GAAG,MAAM,CAAqB,IAAI,CAAC,CAAA;IACnD,MAAM,SAAS,GAAG,MAAM,CAAM,IAAI,CAAC,CAAA;IAEnC,sBAAsB;IACtB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QACvB,SAAS,CAAC,OAAO,GAAG,OAAO,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,UAAU,CAAA;IAClF,CAAC;IAED,MAAM,gBAAgB,GAAG,WAAW,CAAC,GAAG,EAAE;QACxC,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;YACxB,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;QAC5B,CAAC;aAAM,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YACjC,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA;QAC5B,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,MAAM,gBAAgB,GAAG,WAAW,CAAC,GAAG,EAAE;QACxC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YAC1B,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAA,CAAC,qBAAqB;QACjD,CAAC;aAAM,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;YAC/B,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,CAAA,CAAC,uBAAuB;QACpD,CAAC;IACH,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IAEb,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,CAAA;QAClC,IAAI,CAAC,OAAO;YAAE,OAAM;QAEpB,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;QACxD,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;QAExD,OAAO,GAAG,EAAE;YACV,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;YAC3D,OAAO,CAAC,mBAAmB,CAAC,YAAY,EAAE,gBAAgB,CAAC,CAAA;QAC7D,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAAC,CAAA;IAExC,MAAM,MAAM,GAAG,WAAW,CAAC,CAAC,OAA2B,EAAE,EAAE;QACzD,UAAU,CAAC,OAAO,GAAG,OAAO,CAAA;QAC5B,IAAI,SAAS,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC;YAC3B,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAChC,CAAC;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO;QACL,GAAG,SAAS,CAAC,OAAO;QACpB,GAAG,EAAE,MAAM;KACZ,CAAA;AACH,CAAC"}
@@ -1,26 +1,29 @@
1
- import { BaseMotionOptions, BaseMotionReturn, MotionElement } from '../types';
2
- export interface MotionStateOptions extends BaseMotionOptions {
3
- states: {
4
- [key: string]: {
5
- scale?: number;
6
- opacity?: number;
7
- rotate?: number;
8
- translateY?: number;
9
- translateX?: number;
10
- backgroundColor?: string;
11
- color?: string;
12
- borderColor?: string;
13
- boxShadow?: string;
14
- };
15
- };
16
- initialState?: string;
17
- stateTransitionDuration?: number;
18
- stateTransitionEasing?: string;
1
+ type MotionState = 'idle' | 'playing' | 'paused' | 'completed' | 'error';
2
+ type MotionDirection = 'forward' | 'reverse' | 'alternate';
3
+ interface MotionStateOptions {
4
+ initialState?: MotionState;
5
+ autoPlay?: boolean;
6
+ loop?: boolean;
7
+ direction?: MotionDirection;
8
+ duration?: number;
9
+ delay?: number;
10
+ showOnMount?: boolean;
19
11
  }
20
- export declare function useMotionState<T extends MotionElement = HTMLDivElement>(options: MotionStateOptions): BaseMotionReturn<T> & {
21
- currentState: string;
22
- availableStates: string[];
23
- setState: (stateName: string) => void;
24
- transitionToState: (stateName: string, duration?: number) => void;
25
- };
12
+ interface MotionStateReturn {
13
+ state: MotionState;
14
+ direction: MotionDirection;
15
+ progress: number;
16
+ elapsed: number;
17
+ remaining: number;
18
+ mounted: boolean;
19
+ play: () => void;
20
+ pause: () => void;
21
+ stop: () => void;
22
+ reset: () => void;
23
+ reverse: () => void;
24
+ seek: (progress: number) => void;
25
+ setState: (newState: MotionState) => void;
26
+ }
27
+ export declare function useMotionState(options?: MotionStateOptions): MotionStateReturn;
28
+ export {};
26
29
  //# sourceMappingURL=useMotionState.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useMotionState.d.ts","sourceRoot":"","sources":["../../src/hooks/useMotionState.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7E,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,MAAM,EAAE;QACN,CAAC,GAAG,EAAE,MAAM,GAAG;YACb,KAAK,CAAC,EAAE,MAAM,CAAA;YACd,OAAO,CAAC,EAAE,MAAM,CAAA;YAChB,MAAM,CAAC,EAAE,MAAM,CAAA;YACf,UAAU,CAAC,EAAE,MAAM,CAAA;YACnB,UAAU,CAAC,EAAE,MAAM,CAAA;YACnB,eAAe,CAAC,EAAE,MAAM,CAAA;YACxB,KAAK,CAAC,EAAE,MAAM,CAAA;YACd,WAAW,CAAC,EAAE,MAAM,CAAA;YACpB,SAAS,CAAC,EAAE,MAAM,CAAA;SACnB,CAAA;KACF,CAAA;IACD,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,qBAAqB,CAAC,EAAE,MAAM,CAAA;CAC/B;AAED,wBAAgB,cAAc,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EACrE,OAAO,EAAE,kBAAkB,GAC1B,gBAAgB,CAAC,CAAC,CAAC,GAAG;IACvB,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,EAAE,CAAA;IACzB,QAAQ,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IACrC,iBAAiB,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,KAAK,IAAI,CAAA;CAClE,CA8IA"}
1
+ {"version":3,"file":"useMotionState.d.ts","sourceRoot":"","sources":["../../src/hooks/useMotionState.ts"],"names":[],"mappings":"AAEA,KAAK,WAAW,GAAG,MAAM,GAAG,SAAS,GAAG,QAAQ,GAAG,WAAW,GAAG,OAAO,CAAA;AACxE,KAAK,eAAe,GAAG,SAAS,GAAG,SAAS,GAAG,WAAW,CAAA;AAE1D,UAAU,kBAAkB;IAC1B,YAAY,CAAC,EAAE,WAAW,CAAA;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,SAAS,CAAC,EAAE,eAAe,CAAA;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB;AAED,UAAU,iBAAiB;IACzB,KAAK,EAAE,WAAW,CAAA;IAClB,SAAS,EAAE,eAAe,CAAA;IAC1B,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,SAAS,EAAE,MAAM,CAAA;IACjB,OAAO,EAAE,OAAO,CAAA;IAChB,IAAI,EAAE,MAAM,IAAI,CAAA;IAChB,KAAK,EAAE,MAAM,IAAI,CAAA;IACjB,IAAI,EAAE,MAAM,IAAI,CAAA;IAChB,KAAK,EAAE,MAAM,IAAI,CAAA;IACjB,OAAO,EAAE,MAAM,IAAI,CAAA;IACnB,IAAI,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,CAAA;IAChC,QAAQ,EAAE,CAAC,QAAQ,EAAE,WAAW,KAAK,IAAI,CAAA;CAC1C;AAED,wBAAgB,cAAc,CAAC,OAAO,GAAE,kBAAuB,GAAG,iBAAiB,CAyOlF"}
@@ -1,119 +1,202 @@
1
- import { useRef, useState, useCallback } from 'react';
2
- export function useMotionState(options) {
3
- const { duration = 300, easing = 'ease-out', states, initialState = Object.keys(states)[0] || 'default', stateTransitionDuration, stateTransitionEasing, onComplete, onStart, onStop, onReset } = options;
4
- const ref = useRef(null);
5
- const [isVisible, setIsVisible] = useState(false);
6
- const [isAnimating, setIsAnimating] = useState(false);
1
+ import { useState, useEffect, useRef, useCallback } from 'react';
2
+ export function useMotionState(options = {}) {
3
+ const { initialState = 'idle', autoPlay = false, loop = false, direction = 'forward', duration = 1000, delay = 0, showOnMount = false } = options;
4
+ const [state, setState] = useState(showOnMount ? initialState : 'idle');
5
+ const [currentDirection, setCurrentDirection] = useState(direction);
7
6
  const [progress, setProgress] = useState(0);
8
- const [currentState, setCurrentState] = useState(initialState);
9
- const [targetState, setTargetState] = useState(initialState);
10
- const availableStates = Object.keys(states);
11
- const currentStateConfig = states[currentState] || {};
12
- const targetStateConfig = states[targetState] || {};
13
- // 상태 변경 함수
14
- const setState = useCallback((stateName) => {
15
- if (!states[stateName]) {
16
- console.warn(`State "${stateName}" not found in available states:`, availableStates);
7
+ const [elapsed, setElapsed] = useState(0);
8
+ const [mounted, setMounted] = useState(false);
9
+ const motionRef = useRef(null);
10
+ const startTimeRef = useRef(null);
11
+ const pauseTimeRef = useRef(null);
12
+ const totalPausedTimeRef = useRef(0);
13
+ // 하이드레이션 이슈 해결을 위한 mounted 상태 관리
14
+ useEffect(() => {
15
+ setMounted(true);
16
+ }, []);
17
+ // 모션 루프
18
+ const animate = useCallback((timestamp) => {
19
+ if (!startTimeRef.current) {
20
+ startTimeRef.current = timestamp;
21
+ }
22
+ const adjustedTimestamp = timestamp - totalPausedTimeRef.current;
23
+ const elapsedTime = adjustedTimestamp - startTimeRef.current;
24
+ const newElapsed = Math.max(0, elapsedTime - delay);
25
+ setElapsed(newElapsed);
26
+ // 진행률 계산
27
+ let newProgress = 0;
28
+ if (newElapsed >= 0) {
29
+ newProgress = Math.min(100, (newElapsed / duration) * 100);
30
+ }
31
+ // 방향에 따른 진행률 조정
32
+ if (currentDirection === 'reverse') {
33
+ newProgress = 100 - newProgress;
34
+ }
35
+ else if (currentDirection === 'alternate') {
36
+ const cycle = Math.floor(newElapsed / duration);
37
+ const cycleProgress = (newElapsed % duration) / duration;
38
+ newProgress = cycle % 2 === 0 ? cycleProgress * 100 : (1 - cycleProgress) * 100;
39
+ }
40
+ setProgress(newProgress);
41
+ // 모션 완료 체크
42
+ if (newElapsed >= duration) {
43
+ if (loop) {
44
+ // 루프: 처음부터 다시 시작
45
+ startTimeRef.current = timestamp || performance.now();
46
+ totalPausedTimeRef.current = 0;
47
+ setElapsed(0);
48
+ setProgress(currentDirection === 'reverse' ? 100 : 0);
49
+ }
50
+ else {
51
+ // 완료
52
+ setState('completed');
53
+ setProgress(currentDirection === 'reverse' ? 0 : 100);
54
+ if (motionRef.current) {
55
+ cancelAnimationFrame(motionRef.current);
56
+ motionRef.current = null;
57
+ }
58
+ return;
59
+ }
60
+ }
61
+ // 다음 프레임 요청
62
+ if (state === 'playing') {
63
+ motionRef.current = requestAnimationFrame(animate);
64
+ }
65
+ }, [state, duration, delay, loop, currentDirection]);
66
+ // 재생 시작
67
+ const play = useCallback(() => {
68
+ if (!mounted)
17
69
  return;
70
+ if (state === 'completed') {
71
+ // 완료된 상태에서 재생 시 처음부터 시작
72
+ reset();
18
73
  }
19
- setTargetState(stateName);
20
- setIsAnimating(true);
21
- setProgress(0);
22
- onStart?.();
23
- const transitionDuration = stateTransitionDuration || duration;
24
- setTimeout(() => {
25
- setCurrentState(stateName);
26
- setIsAnimating(false);
27
- setProgress(1);
28
- onComplete?.();
29
- }, transitionDuration);
30
- }, [states, stateTransitionDuration, duration, onStart, onComplete]);
31
- // 상태 전환 함수 (애니메이션과 함께)
32
- const transitionToState = useCallback((stateName, customDuration) => {
33
- if (!states[stateName]) {
34
- console.warn(`State "${stateName}" not found in available states:`, availableStates);
74
+ setState('playing');
75
+ if (pauseTimeRef.current) {
76
+ // 일시정지에서 재개
77
+ totalPausedTimeRef.current += performance.now() - pauseTimeRef.current;
78
+ pauseTimeRef.current = null;
79
+ }
80
+ else {
81
+ // 새로운 모션 시작
82
+ startTimeRef.current = null;
83
+ totalPausedTimeRef.current = 0;
84
+ }
85
+ if (!motionRef.current) {
86
+ motionRef.current = requestAnimationFrame(animate);
87
+ }
88
+ }, [mounted, state, animate]);
89
+ // 일시정지
90
+ const pause = useCallback(() => {
91
+ if (state !== 'playing')
35
92
  return;
93
+ setState('paused');
94
+ pauseTimeRef.current = performance.now();
95
+ if (motionRef.current) {
96
+ cancelAnimationFrame(motionRef.current);
97
+ motionRef.current = null;
36
98
  }
37
- setTargetState(stateName);
38
- setIsAnimating(true);
39
- setProgress(0);
40
- onStart?.();
41
- const transitionDuration = customDuration || stateTransitionDuration || duration;
42
- setTimeout(() => {
43
- setCurrentState(stateName);
44
- setIsAnimating(false);
45
- setProgress(1);
46
- onComplete?.();
47
- }, transitionDuration);
48
- }, [states, stateTransitionDuration, duration, onStart, onComplete]);
49
- // 모션 시작 함수
50
- const start = useCallback(() => {
51
- if (!isVisible) {
52
- setIsVisible(true);
53
- setIsAnimating(true);
54
- setProgress(0);
55
- onStart?.();
56
- setTimeout(() => {
57
- setIsAnimating(false);
58
- setProgress(1);
59
- onComplete?.();
60
- }, duration);
61
- }
62
- }, [isVisible, duration, onStart, onComplete]);
63
- // 모션 중단 함수
99
+ }, [state]);
100
+ // 정지
64
101
  const stop = useCallback(() => {
65
- setIsAnimating(false);
66
- onStop?.();
67
- }, [onStop]);
68
- // 모션 리셋 함수
102
+ setState('idle');
103
+ setProgress(0);
104
+ setElapsed(0);
105
+ startTimeRef.current = null;
106
+ pauseTimeRef.current = null;
107
+ totalPausedTimeRef.current = 0;
108
+ if (motionRef.current) {
109
+ cancelAnimationFrame(motionRef.current);
110
+ motionRef.current = null;
111
+ }
112
+ }, []);
113
+ // 리셋
69
114
  const reset = useCallback(() => {
70
- setIsVisible(false);
71
- setIsAnimating(false);
115
+ setState('idle');
72
116
  setProgress(0);
73
- setCurrentState(initialState);
74
- setTargetState(initialState);
75
- onReset?.();
76
- }, [initialState, onReset]);
77
- // 모션 일시정지 함수
78
- const pause = useCallback(() => {
79
- setIsAnimating(false);
117
+ setElapsed(0);
118
+ setCurrentDirection(direction);
119
+ startTimeRef.current = null;
120
+ pauseTimeRef.current = null;
121
+ totalPausedTimeRef.current = 0;
122
+ if (motionRef.current) {
123
+ cancelAnimationFrame(motionRef.current);
124
+ motionRef.current = null;
125
+ }
126
+ }, [direction]);
127
+ // 역방향 전환
128
+ const reverse = useCallback(() => {
129
+ const newDirection = currentDirection === 'forward' ? 'reverse' : 'forward';
130
+ setCurrentDirection(newDirection);
131
+ // 현재 진행률을 역방향으로 조정
132
+ if (state === 'playing') {
133
+ const remainingTime = duration - elapsed;
134
+ startTimeRef.current = performance.now() - remainingTime;
135
+ totalPausedTimeRef.current = 0;
136
+ }
137
+ }, [currentDirection, state, duration, elapsed]);
138
+ // 특정 진행률로 이동
139
+ const seek = useCallback((targetProgress) => {
140
+ const clampedProgress = Math.max(0, Math.min(100, targetProgress));
141
+ setProgress(clampedProgress);
142
+ // 경과 시간 계산
143
+ let targetElapsed = 0;
144
+ if (currentDirection === 'reverse') {
145
+ targetElapsed = ((100 - clampedProgress) / 100) * duration;
146
+ }
147
+ else if (currentDirection === 'alternate') {
148
+ // alternate의 경우 복잡하므로 단순화
149
+ targetElapsed = (clampedProgress / 100) * duration;
150
+ }
151
+ else {
152
+ targetElapsed = (clampedProgress / 100) * duration;
153
+ }
154
+ setElapsed(targetElapsed);
155
+ // 모션이 재생 중이면 시간 조정
156
+ if (state === 'playing' && startTimeRef.current) {
157
+ const currentTime = performance.now();
158
+ startTimeRef.current = currentTime - targetElapsed - totalPausedTimeRef.current;
159
+ }
160
+ }, [currentDirection, duration, state]);
161
+ // 상태 직접 설정
162
+ const setMotionState = useCallback((newState) => {
163
+ setState(newState);
164
+ if (newState === 'playing' && !motionRef.current) {
165
+ motionRef.current = requestAnimationFrame(animate);
166
+ }
167
+ else if (newState !== 'playing' && motionRef.current) {
168
+ cancelAnimationFrame(motionRef.current);
169
+ motionRef.current = null;
170
+ }
171
+ }, [animate]);
172
+ // 자동 재생
173
+ useEffect(() => {
174
+ if (mounted && autoPlay && state === 'idle') {
175
+ play();
176
+ }
177
+ }, [mounted, autoPlay, state, play]);
178
+ // 클린업
179
+ useEffect(() => {
180
+ return () => {
181
+ if (motionRef.current) {
182
+ cancelAnimationFrame(motionRef.current);
183
+ }
184
+ };
80
185
  }, []);
81
- // 모션 재개 함수
82
- const resume = useCallback(() => {
83
- if (isVisible) {
84
- setIsAnimating(true);
85
- }
86
- }, [isVisible]);
87
- // 현재 상태에 따른 스타일 계산
88
- const style = {
89
- transform: `
90
- scale(${currentStateConfig.scale || 1})
91
- rotate(${currentStateConfig.rotate || 0}deg)
92
- translate(${currentStateConfig.translateX || 0}px, ${currentStateConfig.translateY || 0}px)
93
- `,
94
- opacity: currentStateConfig.opacity ?? 1,
95
- backgroundColor: currentStateConfig.backgroundColor,
96
- color: currentStateConfig.color,
97
- borderColor: currentStateConfig.borderColor,
98
- boxShadow: currentStateConfig.boxShadow,
99
- transition: `all ${stateTransitionDuration || duration}ms ${stateTransitionEasing || easing}`,
100
- willChange: 'transform, opacity, background-color, color, border-color, box-shadow'
101
- };
102
186
  return {
103
- ref,
104
- isVisible,
105
- isAnimating,
106
- style,
187
+ state,
188
+ direction: currentDirection,
107
189
  progress,
108
- start,
190
+ elapsed,
191
+ remaining: Math.max(0, duration - elapsed),
192
+ mounted,
193
+ play,
194
+ pause,
109
195
  stop,
110
196
  reset,
111
- pause,
112
- resume,
113
- currentState,
114
- availableStates,
115
- setState,
116
- transitionToState
197
+ reverse,
198
+ seek,
199
+ setState: setMotionState
117
200
  };
118
201
  }
119
202
  //# sourceMappingURL=useMotionState.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useMotionState.js","sourceRoot":"","sources":["../../src/hooks/useMotionState.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useMotionState.js","sourceRoot":"","sources":["../../src/hooks/useMotionState.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import type { PageMotionsConfig } from '../types';
2
+ /**
3
+ * 2단계 API: 페이지 레벨 모션 관리 (상태 관리자 버전)
4
+ *
5
+ * 사용법:
6
+ * ```typescript
7
+ * const motions = usePageMotions({
8
+ * hero: { type: 'hero' },
9
+ * title: { type: 'title' },
10
+ * button: { type: 'button', hover: true, click: true }
11
+ * })
12
+ * ```
13
+ */
14
+ export declare function usePageMotions(config: PageMotionsConfig): {
15
+ reset: () => void;
16
+ };
17
+ //# sourceMappingURL=usePageMotions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePageMotions.d.ts","sourceRoot":"","sources":["../../src/hooks/usePageMotions.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,iBAAiB,EAIlB,MAAM,UAAU,CAAA;AAIjB;;;;;;;;;;;GAWG;AACH,wBAAgB,cAAc,CAAC,MAAM,EAAE,iBAAiB;;EAsYvD"}