@hua-labs/motion-core 2.0.0

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 (116) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +245 -0
  3. package/dist/.tsbuildinfo +1 -0
  4. package/dist/hooks/useBounceIn.d.ts +3 -0
  5. package/dist/hooks/useBounceIn.d.ts.map +1 -0
  6. package/dist/hooks/useBounceIn.js +141 -0
  7. package/dist/hooks/useBounceIn.js.map +1 -0
  8. package/dist/hooks/useButtonEffect.d.ts +48 -0
  9. package/dist/hooks/useButtonEffect.d.ts.map +1 -0
  10. package/dist/hooks/useButtonEffect.js +311 -0
  11. package/dist/hooks/useButtonEffect.js.map +1 -0
  12. package/dist/hooks/useCardList.d.ts +23 -0
  13. package/dist/hooks/useCardList.d.ts.map +1 -0
  14. package/dist/hooks/useCardList.js +119 -0
  15. package/dist/hooks/useCardList.js.map +1 -0
  16. package/dist/hooks/useClickToggle.d.ts +15 -0
  17. package/dist/hooks/useClickToggle.d.ts.map +1 -0
  18. package/dist/hooks/useClickToggle.js +102 -0
  19. package/dist/hooks/useClickToggle.js.map +1 -0
  20. package/dist/hooks/useFadeIn.d.ts +17 -0
  21. package/dist/hooks/useFadeIn.d.ts.map +1 -0
  22. package/dist/hooks/useFadeIn.js +133 -0
  23. package/dist/hooks/useFadeIn.js.map +1 -0
  24. package/dist/hooks/useFocusToggle.d.ts +15 -0
  25. package/dist/hooks/useFocusToggle.d.ts.map +1 -0
  26. package/dist/hooks/useFocusToggle.js +99 -0
  27. package/dist/hooks/useFocusToggle.js.map +1 -0
  28. package/dist/hooks/useGradient.d.ts +25 -0
  29. package/dist/hooks/useGradient.d.ts.map +1 -0
  30. package/dist/hooks/useGradient.js +144 -0
  31. package/dist/hooks/useGradient.js.map +1 -0
  32. package/dist/hooks/useHoverMotion.d.ts +15 -0
  33. package/dist/hooks/useHoverMotion.d.ts.map +1 -0
  34. package/dist/hooks/useHoverMotion.js +99 -0
  35. package/dist/hooks/useHoverMotion.js.map +1 -0
  36. package/dist/hooks/useLoadingSpinner.d.ts +30 -0
  37. package/dist/hooks/useLoadingSpinner.d.ts.map +1 -0
  38. package/dist/hooks/useLoadingSpinner.js +283 -0
  39. package/dist/hooks/useLoadingSpinner.js.map +1 -0
  40. package/dist/hooks/useMotion.d.ts +103 -0
  41. package/dist/hooks/useMotion.d.ts.map +1 -0
  42. package/dist/hooks/useMotion.js +266 -0
  43. package/dist/hooks/useMotion.js.map +1 -0
  44. package/dist/hooks/useMotionState.d.ts +26 -0
  45. package/dist/hooks/useMotionState.d.ts.map +1 -0
  46. package/dist/hooks/useMotionState.js +119 -0
  47. package/dist/hooks/useMotionState.js.map +1 -0
  48. package/dist/hooks/useNavigation.d.ts +40 -0
  49. package/dist/hooks/useNavigation.d.ts.map +1 -0
  50. package/dist/hooks/useNavigation.js +212 -0
  51. package/dist/hooks/useNavigation.js.map +1 -0
  52. package/dist/hooks/usePulse.d.ts +3 -0
  53. package/dist/hooks/usePulse.d.ts.map +1 -0
  54. package/dist/hooks/usePulse.js +134 -0
  55. package/dist/hooks/usePulse.js.map +1 -0
  56. package/dist/hooks/useRepeat.d.ts +26 -0
  57. package/dist/hooks/useRepeat.d.ts.map +1 -0
  58. package/dist/hooks/useRepeat.js +179 -0
  59. package/dist/hooks/useRepeat.js.map +1 -0
  60. package/dist/hooks/useScaleIn.d.ts +3 -0
  61. package/dist/hooks/useScaleIn.d.ts.map +1 -0
  62. package/dist/hooks/useScaleIn.js +111 -0
  63. package/dist/hooks/useScaleIn.js.map +1 -0
  64. package/dist/hooks/useScrollProgress.d.ts +21 -0
  65. package/dist/hooks/useScrollProgress.d.ts.map +1 -0
  66. package/dist/hooks/useScrollProgress.js +139 -0
  67. package/dist/hooks/useScrollProgress.js.map +1 -0
  68. package/dist/hooks/useScrollReveal.d.ts +17 -0
  69. package/dist/hooks/useScrollReveal.d.ts.map +1 -0
  70. package/dist/hooks/useScrollReveal.js +95 -0
  71. package/dist/hooks/useScrollReveal.js.map +1 -0
  72. package/dist/hooks/useScrollToggle.d.ts +17 -0
  73. package/dist/hooks/useScrollToggle.d.ts.map +1 -0
  74. package/dist/hooks/useScrollToggle.js +119 -0
  75. package/dist/hooks/useScrollToggle.js.map +1 -0
  76. package/dist/hooks/useSkeleton.d.ts +21 -0
  77. package/dist/hooks/useSkeleton.d.ts.map +1 -0
  78. package/dist/hooks/useSkeleton.js +139 -0
  79. package/dist/hooks/useSkeleton.js.map +1 -0
  80. package/dist/hooks/useSlideDown.d.ts +25 -0
  81. package/dist/hooks/useSlideDown.d.ts.map +1 -0
  82. package/dist/hooks/useSlideDown.js +263 -0
  83. package/dist/hooks/useSlideDown.js.map +1 -0
  84. package/dist/hooks/useSlideLeft.d.ts +3 -0
  85. package/dist/hooks/useSlideLeft.d.ts.map +1 -0
  86. package/dist/hooks/useSlideLeft.js +111 -0
  87. package/dist/hooks/useSlideLeft.js.map +1 -0
  88. package/dist/hooks/useSlideRight.d.ts +3 -0
  89. package/dist/hooks/useSlideRight.d.ts.map +1 -0
  90. package/dist/hooks/useSlideRight.js +111 -0
  91. package/dist/hooks/useSlideRight.js.map +1 -0
  92. package/dist/hooks/useSlideUp.d.ts +3 -0
  93. package/dist/hooks/useSlideUp.d.ts.map +1 -0
  94. package/dist/hooks/useSlideUp.js +111 -0
  95. package/dist/hooks/useSlideUp.js.map +1 -0
  96. package/dist/hooks/useSpringMotion.d.ts +32 -0
  97. package/dist/hooks/useSpringMotion.d.ts.map +1 -0
  98. package/dist/hooks/useSpringMotion.js +185 -0
  99. package/dist/hooks/useSpringMotion.js.map +1 -0
  100. package/dist/hooks/useVisibilityToggle.d.ts +15 -0
  101. package/dist/hooks/useVisibilityToggle.d.ts.map +1 -0
  102. package/dist/hooks/useVisibilityToggle.js +106 -0
  103. package/dist/hooks/useVisibilityToggle.js.map +1 -0
  104. package/dist/index.d.ts +29 -0
  105. package/dist/index.d.ts.map +1 -0
  106. package/dist/index.js +43 -0
  107. package/dist/index.js.map +1 -0
  108. package/dist/types/index.d.ts +109 -0
  109. package/dist/types/index.d.ts.map +1 -0
  110. package/dist/types/index.js +5 -0
  111. package/dist/types/index.js.map +1 -0
  112. package/dist/utils/easing.d.ts +44 -0
  113. package/dist/utils/easing.d.ts.map +1 -0
  114. package/dist/utils/easing.js +98 -0
  115. package/dist/utils/easing.js.map +1 -0
  116. package/package.json +69 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMotion.js","sourceRoot":"","sources":["../../src/hooks/useMotion.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
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;
19
+ }
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
+ };
26
+ //# sourceMappingURL=useMotionState.d.ts.map
@@ -0,0 +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"}
@@ -0,0 +1,119 @@
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);
7
+ 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);
17
+ return;
18
+ }
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);
35
+ return;
36
+ }
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
+ // 모션 중단 함수
64
+ const stop = useCallback(() => {
65
+ setIsAnimating(false);
66
+ onStop?.();
67
+ }, [onStop]);
68
+ // 모션 리셋 함수
69
+ const reset = useCallback(() => {
70
+ setIsVisible(false);
71
+ setIsAnimating(false);
72
+ setProgress(0);
73
+ setCurrentState(initialState);
74
+ setTargetState(initialState);
75
+ onReset?.();
76
+ }, [initialState, onReset]);
77
+ // 모션 일시정지 함수
78
+ const pause = useCallback(() => {
79
+ setIsAnimating(false);
80
+ }, []);
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
+ return {
103
+ ref,
104
+ isVisible,
105
+ isAnimating,
106
+ style,
107
+ progress,
108
+ start,
109
+ stop,
110
+ reset,
111
+ pause,
112
+ resume,
113
+ currentState,
114
+ availableStates,
115
+ setState,
116
+ transitionToState
117
+ };
118
+ }
119
+ //# sourceMappingURL=useMotionState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useMotionState.js","sourceRoot":"","sources":["../../src/hooks/useMotionState.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ import { BaseMotionOptions, BaseMotionReturn, MotionElement } from '../types';
2
+ export interface NavigationOptions extends BaseMotionOptions {
3
+ type?: 'slide' | 'fade' | 'scale' | 'rotate' | 'custom';
4
+ slideDirection?: 'left' | 'right' | 'up' | 'down';
5
+ staggerDelay?: number;
6
+ itemScale?: number;
7
+ itemOpacity?: number;
8
+ itemRotate?: number;
9
+ itemTranslateY?: number;
10
+ itemTranslateX?: number;
11
+ initialScale?: number;
12
+ initialOpacity?: number;
13
+ initialRotate?: number;
14
+ initialTranslateY?: number;
15
+ initialTranslateX?: number;
16
+ activeScale?: number;
17
+ activeOpacity?: number;
18
+ activeRotate?: number;
19
+ activeTranslateY?: number;
20
+ activeTranslateX?: number;
21
+ hoverScale?: number;
22
+ hoverOpacity?: number;
23
+ hoverRotate?: number;
24
+ hoverTranslateY?: number;
25
+ hoverTranslateX?: number;
26
+ itemCount?: number;
27
+ autoStart?: boolean;
28
+ }
29
+ export declare function useNavigation<T extends MotionElement = HTMLDivElement>(options?: NavigationOptions): BaseMotionReturn<T> & {
30
+ isOpen: boolean;
31
+ activeIndex: number;
32
+ itemStyles: React.CSSProperties[];
33
+ openMenu: () => void;
34
+ closeMenu: () => void;
35
+ toggleMenu: () => void;
36
+ setActiveItem: (index: number) => void;
37
+ goToNext: () => void;
38
+ goToPrevious: () => void;
39
+ };
40
+ //# sourceMappingURL=useNavigation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useNavigation.d.ts","sourceRoot":"","sources":["../../src/hooks/useNavigation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7E,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAE1D,IAAI,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,GAAG,QAAQ,CAAA;IAGvD,cAAc,CAAC,EAAE,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,MAAM,CAAA;IAGjD,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,cAAc,CAAC,EAAE,MAAM,CAAA;IAGvB,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;IAG1B,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;IAGzB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IAGxB,SAAS,CAAC,EAAE,MAAM,CAAA;IAGlB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAED,wBAAgB,aAAa,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EACpE,OAAO,GAAE,iBAAsB,GAC9B,gBAAgB,CAAC,CAAC,CAAC,GAAG;IACvB,MAAM,EAAE,OAAO,CAAA;IACf,WAAW,EAAE,MAAM,CAAA;IACnB,UAAU,EAAE,KAAK,CAAC,aAAa,EAAE,CAAA;IACjC,QAAQ,EAAE,MAAM,IAAI,CAAA;IACpB,SAAS,EAAE,MAAM,IAAI,CAAA;IACrB,UAAU,EAAE,MAAM,IAAI,CAAA;IACtB,aAAa,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACtC,QAAQ,EAAE,MAAM,IAAI,CAAA;IACpB,YAAY,EAAE,MAAM,IAAI,CAAA;CACzB,CAoQA"}
@@ -0,0 +1,212 @@
1
+ import { useRef, useState, useEffect, useCallback } from 'react';
2
+ export function useNavigation(options = {}) {
3
+ const { duration = 300, easing = 'ease-out', type = 'slide', slideDirection = 'left', staggerDelay = 50, itemScale = 1, itemOpacity = 1, itemRotate = 0, itemTranslateY = 0, itemTranslateX = 0, initialScale = 0.8, initialOpacity = 0, initialRotate = -10, initialTranslateY = 20, initialTranslateX = 0, activeScale = 1.05, activeOpacity = 1, activeRotate = 0, activeTranslateY = 0, activeTranslateX = 0, hoverScale = 1.1, hoverOpacity = 1, hoverRotate = 5, hoverTranslateY = -5, hoverTranslateX = 0, itemCount = 5, autoStart = false, 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 [isOpen, setIsOpen] = useState(false);
9
+ const [activeIndex, setActiveIndex] = useState(0);
10
+ const [hoveredIndex, setHoveredIndex] = useState(null);
11
+ // 메뉴 열기 함수
12
+ const openMenu = useCallback(() => {
13
+ if (isOpen)
14
+ return;
15
+ setIsOpen(true);
16
+ setIsAnimating(true);
17
+ setProgress(0);
18
+ onStart?.();
19
+ // 순차적으로 아이템들 나타나기
20
+ const totalDuration = itemCount * staggerDelay + duration;
21
+ const interval = setInterval(() => {
22
+ setProgress(prev => {
23
+ const newProgress = prev + 0.1;
24
+ if (newProgress >= 1) {
25
+ setIsAnimating(false);
26
+ onComplete?.();
27
+ clearInterval(interval);
28
+ return 1;
29
+ }
30
+ return newProgress;
31
+ });
32
+ }, totalDuration / 10);
33
+ }, [isOpen, itemCount, staggerDelay, duration, onStart, onComplete]);
34
+ // 메뉴 닫기 함수
35
+ const closeMenu = useCallback(() => {
36
+ if (!isOpen)
37
+ return;
38
+ setIsOpen(false);
39
+ setIsAnimating(true);
40
+ setProgress(1);
41
+ setTimeout(() => {
42
+ setIsAnimating(false);
43
+ setProgress(0);
44
+ }, duration);
45
+ }, [isOpen, duration]);
46
+ // 메뉴 토글 함수
47
+ const toggleMenu = useCallback(() => {
48
+ if (isOpen) {
49
+ closeMenu();
50
+ }
51
+ else {
52
+ openMenu();
53
+ }
54
+ }, [isOpen, openMenu, closeMenu]);
55
+ // 활성 아이템 설정 함수
56
+ const setActiveItem = useCallback((index) => {
57
+ if (index >= 0 && index < itemCount) {
58
+ setActiveIndex(index);
59
+ }
60
+ }, [itemCount]);
61
+ // 다음 아이템으로 이동
62
+ const goToNext = useCallback(() => {
63
+ setActiveItem((activeIndex + 1) % itemCount);
64
+ }, [activeIndex, itemCount, setActiveItem]);
65
+ // 이전 아이템으로 이동
66
+ const goToPrevious = useCallback(() => {
67
+ setActiveItem(activeIndex === 0 ? itemCount - 1 : activeIndex - 1);
68
+ }, [activeIndex, itemCount, setActiveItem]);
69
+ // 모션 시작 함수
70
+ const start = useCallback(() => {
71
+ if (!isVisible) {
72
+ setIsVisible(true);
73
+ openMenu();
74
+ }
75
+ }, [isVisible, openMenu]);
76
+ // 모션 중단 함수
77
+ const stop = useCallback(() => {
78
+ setIsAnimating(false);
79
+ onStop?.();
80
+ }, [onStop]);
81
+ // 모션 리셋 함수
82
+ const reset = useCallback(() => {
83
+ setIsVisible(false);
84
+ setIsAnimating(false);
85
+ setProgress(0);
86
+ setIsOpen(false);
87
+ setActiveIndex(0);
88
+ setHoveredIndex(null);
89
+ onReset?.();
90
+ }, [onReset]);
91
+ // 모션 일시정지 함수
92
+ const pause = useCallback(() => {
93
+ setIsAnimating(false);
94
+ }, []);
95
+ // 모션 재개 함수
96
+ const resume = useCallback(() => {
97
+ if (isVisible) {
98
+ setIsAnimating(true);
99
+ }
100
+ }, [isVisible]);
101
+ // 자동 시작
102
+ useEffect(() => {
103
+ if (autoStart) {
104
+ start();
105
+ }
106
+ }, [autoStart, start]);
107
+ // 메뉴 아이템 스타일 배열 생성
108
+ const itemStyles = Array.from({ length: itemCount }, (_, index) => {
109
+ const delay = isOpen ? index * staggerDelay : 0;
110
+ const isItemVisible = isOpen && delay <= progress * (itemCount * staggerDelay);
111
+ const isActive = index === activeIndex;
112
+ const isHovered = index === hoveredIndex;
113
+ let scale = initialScale;
114
+ let opacity = initialOpacity;
115
+ let rotate = initialRotate;
116
+ let translateY = initialTranslateY;
117
+ let translateX = initialTranslateX;
118
+ if (isItemVisible) {
119
+ if (isHovered) {
120
+ scale = hoverScale;
121
+ opacity = hoverOpacity;
122
+ rotate = hoverRotate;
123
+ translateY = hoverTranslateY;
124
+ translateX = hoverTranslateX;
125
+ }
126
+ else if (isActive) {
127
+ scale = activeScale;
128
+ opacity = activeOpacity;
129
+ rotate = activeRotate;
130
+ translateY = activeTranslateY;
131
+ translateX = activeTranslateX;
132
+ }
133
+ else {
134
+ scale = itemScale;
135
+ opacity = itemOpacity;
136
+ rotate = itemRotate;
137
+ translateY = itemTranslateY;
138
+ translateX = itemTranslateX;
139
+ }
140
+ }
141
+ return {
142
+ transform: `
143
+ scale(${scale})
144
+ rotate(${rotate}deg)
145
+ translate(${translateX}px, ${translateY}px)
146
+ `,
147
+ opacity,
148
+ transition: `all ${duration}ms ${easing} ${delay}ms`,
149
+ willChange: 'transform, opacity',
150
+ cursor: 'pointer'
151
+ };
152
+ });
153
+ // 네비게이션 스타일 계산
154
+ const getNavigationStyle = () => {
155
+ let baseStyle = {
156
+ transition: `all ${duration}ms ${easing}`,
157
+ willChange: 'transform, opacity'
158
+ };
159
+ switch (type) {
160
+ case 'slide':
161
+ if (slideDirection === 'left') {
162
+ baseStyle.transform = `translateX(${isOpen ? 0 : -100}%)`;
163
+ }
164
+ else if (slideDirection === 'right') {
165
+ baseStyle.transform = `translateX(${isOpen ? 0 : 100}%)`;
166
+ }
167
+ else if (slideDirection === 'up') {
168
+ baseStyle.transform = `translateY(${isOpen ? 0 : -100}%)`;
169
+ }
170
+ else if (slideDirection === 'down') {
171
+ baseStyle.transform = `translateY(${isOpen ? 0 : 100}%)`;
172
+ }
173
+ break;
174
+ case 'fade':
175
+ baseStyle.opacity = isOpen ? 1 : 0;
176
+ break;
177
+ case 'scale':
178
+ baseStyle.transform = `scale(${isOpen ? 1 : 0})`;
179
+ break;
180
+ case 'rotate':
181
+ baseStyle.transform = `rotate(${isOpen ? 0 : 180}deg)`;
182
+ break;
183
+ case 'custom':
184
+ // 사용자 정의 스타일은 기본값 사용
185
+ break;
186
+ }
187
+ return baseStyle;
188
+ };
189
+ const style = getNavigationStyle();
190
+ return {
191
+ ref,
192
+ isVisible,
193
+ isAnimating,
194
+ style,
195
+ progress,
196
+ start,
197
+ stop,
198
+ reset,
199
+ pause,
200
+ resume,
201
+ isOpen,
202
+ activeIndex,
203
+ itemStyles,
204
+ openMenu,
205
+ closeMenu,
206
+ toggleMenu,
207
+ setActiveItem,
208
+ goToNext,
209
+ goToPrevious
210
+ };
211
+ }
212
+ //# sourceMappingURL=useNavigation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useNavigation.js","sourceRoot":"","sources":["../../src/hooks/useNavigation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { PulseOptions, BaseMotionReturn, MotionElement } from '../types';
2
+ export declare function usePulse<T extends MotionElement = HTMLDivElement>(options?: PulseOptions): BaseMotionReturn<T>;
3
+ //# sourceMappingURL=usePulse.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePulse.d.ts","sourceRoot":"","sources":["../../src/hooks/usePulse.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAExE,wBAAgB,QAAQ,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EAC/D,OAAO,GAAE,YAAiB,GACzB,gBAAgB,CAAC,CAAC,CAAC,CA+JrB"}
@@ -0,0 +1,134 @@
1
+ import { useRef, useState, useEffect, useCallback } from 'react';
2
+ export function usePulse(options = {}) {
3
+ const { delay = 0, duration = 1000, threshold = 0.1, triggerOnce = true, easing = 'ease-in-out', autoStart = true, pulseScale = 1.1, pulseCount = 2, 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 observerRef = useRef(null);
9
+ const timeoutRef = useRef(null);
10
+ // 모션 시작 함수
11
+ const start = useCallback(() => {
12
+ if (isAnimating)
13
+ return;
14
+ setIsAnimating(true);
15
+ setProgress(0);
16
+ onStart?.();
17
+ // 지연 시간 적용
18
+ if (delay > 0) {
19
+ timeoutRef.current = window.setTimeout(() => {
20
+ setIsVisible(true);
21
+ setProgress(1);
22
+ setIsAnimating(false);
23
+ onComplete?.();
24
+ }, delay);
25
+ }
26
+ else {
27
+ setIsVisible(true);
28
+ setProgress(1);
29
+ setIsAnimating(false);
30
+ onComplete?.();
31
+ }
32
+ }, [delay, isAnimating, onStart, onComplete]);
33
+ // 모션 중단 함수
34
+ const stop = useCallback(() => {
35
+ if (timeoutRef.current) {
36
+ clearTimeout(timeoutRef.current);
37
+ timeoutRef.current = null;
38
+ }
39
+ setIsAnimating(false);
40
+ onStop?.();
41
+ }, [onStop]);
42
+ // 모션 리셋 함수
43
+ const reset = useCallback(() => {
44
+ stop();
45
+ setIsVisible(false);
46
+ setProgress(0);
47
+ onReset?.();
48
+ }, [stop, onReset]);
49
+ // 모션 일시정지 함수
50
+ const pause = useCallback(() => {
51
+ if (timeoutRef.current) {
52
+ clearTimeout(timeoutRef.current);
53
+ timeoutRef.current = null;
54
+ }
55
+ setIsAnimating(false);
56
+ }, []);
57
+ // 모션 재개 함수
58
+ const resume = useCallback(() => {
59
+ if (!isVisible && !isAnimating) {
60
+ start();
61
+ }
62
+ }, [isVisible, isAnimating, start]);
63
+ // Intersection Observer 설정
64
+ useEffect(() => {
65
+ if (!ref.current || !autoStart)
66
+ return;
67
+ observerRef.current = new IntersectionObserver((entries) => {
68
+ entries.forEach((entry) => {
69
+ if (entry.isIntersecting) {
70
+ start();
71
+ if (triggerOnce) {
72
+ observerRef.current?.disconnect();
73
+ }
74
+ }
75
+ });
76
+ }, { threshold });
77
+ observerRef.current.observe(ref.current);
78
+ return () => {
79
+ if (observerRef.current) {
80
+ observerRef.current.disconnect();
81
+ }
82
+ };
83
+ }, [autoStart, threshold, triggerOnce, start]);
84
+ // 컴포넌트 언마운트 시 정리
85
+ useEffect(() => {
86
+ return () => {
87
+ if (timeoutRef.current) {
88
+ clearTimeout(timeoutRef.current);
89
+ }
90
+ };
91
+ }, []);
92
+ // 펄스 애니메이션 스타일 계산
93
+ const getPulseStyle = () => {
94
+ if (!isVisible) {
95
+ return {
96
+ transform: 'scale(1)',
97
+ transition: `transform ${duration}ms ${easing}`,
98
+ willChange: 'transform'
99
+ };
100
+ }
101
+ // 펄스 효과를 위한 CSS 애니메이션
102
+ const pulseKeyframes = `
103
+ @keyframes pulse {
104
+ 0% {
105
+ transform: scale(1);
106
+ }
107
+ 50% {
108
+ transform: scale(${pulseScale});
109
+ }
110
+ 100% {
111
+ transform: scale(1);
112
+ }
113
+ }
114
+ `;
115
+ return {
116
+ animation: `pulse ${duration}ms ${easing} ${pulseCount}`,
117
+ willChange: 'transform'
118
+ };
119
+ };
120
+ const style = getPulseStyle();
121
+ return {
122
+ ref,
123
+ isVisible,
124
+ isAnimating,
125
+ style,
126
+ progress,
127
+ start,
128
+ stop,
129
+ reset,
130
+ pause,
131
+ resume
132
+ };
133
+ }
134
+ //# sourceMappingURL=usePulse.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"usePulse.js","sourceRoot":"","sources":["../../src/hooks/usePulse.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import { BaseMotionOptions, BaseMotionReturn, MotionElement } from '../types';
2
+ export interface RepeatOptions extends BaseMotionOptions {
3
+ repeatCount?: number;
4
+ repeatDelay?: number;
5
+ repeatDirection?: 'forward' | 'reverse' | 'alternate';
6
+ repeatMode?: 'loop' | 'bounce' | 'ping-pong';
7
+ autoStart?: boolean;
8
+ initialScale?: number;
9
+ initialOpacity?: number;
10
+ initialRotate?: number;
11
+ initialTranslateY?: number;
12
+ initialTranslateX?: number;
13
+ targetScale?: number;
14
+ targetOpacity?: number;
15
+ targetRotate?: number;
16
+ targetTranslateY?: number;
17
+ targetTranslateX?: number;
18
+ }
19
+ export declare function useRepeat<T extends MotionElement = HTMLDivElement>(options?: RepeatOptions): BaseMotionReturn<T> & {
20
+ repeatCount: number;
21
+ currentRepeat: number;
22
+ isRepeating: boolean;
23
+ repeatDirection: 'forward' | 'reverse' | 'alternate';
24
+ repeatMode: 'loop' | 'bounce' | 'ping-pong';
25
+ };
26
+ //# sourceMappingURL=useRepeat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useRepeat.d.ts","sourceRoot":"","sources":["../../src/hooks/useRepeat.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7E,MAAM,WAAW,aAAc,SAAQ,iBAAiB;IACtD,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,eAAe,CAAC,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,CAAA;IACrD,UAAU,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,WAAW,CAAA;IAC5C,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,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,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;CAC1B;AAED,wBAAgB,SAAS,CAAC,CAAC,SAAS,aAAa,GAAG,cAAc,EAChE,OAAO,GAAE,aAAkB,GAC1B,gBAAgB,CAAC,CAAC,CAAC,GAAG;IACvB,WAAW,EAAE,MAAM,CAAA;IACnB,aAAa,EAAE,MAAM,CAAA;IACrB,WAAW,EAAE,OAAO,CAAA;IACpB,eAAe,EAAE,SAAS,GAAG,SAAS,GAAG,WAAW,CAAA;IACpD,UAAU,EAAE,MAAM,GAAG,QAAQ,GAAG,WAAW,CAAA;CAC5C,CA2NA"}