react-native-confetti-reanimated 0.1.3 → 0.1.5
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.
- package/README.md +4 -14
- package/lib/commonjs/ConfettiCanvas.js +11 -0
- package/lib/commonjs/ConfettiCanvas.js.map +1 -1
- package/lib/commonjs/ConfettiParticle.js +44 -20
- package/lib/commonjs/ConfettiParticle.js.map +1 -1
- package/lib/commonjs/utils.js +1 -0
- package/lib/commonjs/utils.js.map +1 -1
- package/lib/module/ConfettiCanvas.js +11 -0
- package/lib/module/ConfettiCanvas.js.map +1 -1
- package/lib/module/ConfettiParticle.js +44 -20
- package/lib/module/ConfettiParticle.js.map +1 -1
- package/lib/module/utils.js +1 -0
- package/lib/module/utils.js.map +1 -1
- package/lib/typescript/ConfettiCanvas.d.ts.map +1 -1
- package/lib/typescript/ConfettiParticle.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +6 -0
- package/lib/typescript/types.d.ts.map +1 -1
- package/lib/typescript/utils.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/ConfettiCanvas.tsx +23 -2
- package/src/ConfettiParticle.tsx +64 -19
- package/src/types.ts +7 -0
- package/src/utils.ts +1 -0
package/README.md
CHANGED
|
@@ -108,7 +108,7 @@ fire({
|
|
|
108
108
|
spread: 70,
|
|
109
109
|
origin: { y: 0.6 },
|
|
110
110
|
colors: ['#ff0000', '#00ff00', '#0000ff'],
|
|
111
|
-
shapes: ['square', 'circle', '
|
|
111
|
+
shapes: ['square', 'circle', 'star'],
|
|
112
112
|
startVelocity: 45,
|
|
113
113
|
gravity: 1,
|
|
114
114
|
decay: 0.9,
|
|
@@ -128,19 +128,6 @@ fire(presets.rightCannon);
|
|
|
128
128
|
fire(presets.bottomCannon);
|
|
129
129
|
```
|
|
130
130
|
|
|
131
|
-
### Continuous Effect
|
|
132
|
-
|
|
133
|
-
```tsx
|
|
134
|
-
const startContinuous = () => {
|
|
135
|
-
const interval = setInterval(() => {
|
|
136
|
-
fire({ particleCount: 10 });
|
|
137
|
-
}, 200);
|
|
138
|
-
|
|
139
|
-
// Stop after 3 seconds
|
|
140
|
-
setTimeout(() => clearInterval(interval), 3000);
|
|
141
|
-
};
|
|
142
|
-
```
|
|
143
|
-
|
|
144
131
|
## API Reference
|
|
145
132
|
|
|
146
133
|
### `ConfettiCanvas`
|
|
@@ -176,6 +163,7 @@ interface ConfettiConfig {
|
|
|
176
163
|
gravity?: number; // Default: 1
|
|
177
164
|
drift?: number; // Default: 0
|
|
178
165
|
duration?: number; // Default: 3000 (ms)
|
|
166
|
+
ticks?: number; // Default: 200 (frames @ 60fps)
|
|
179
167
|
colors?: string[]; // Default: vibrant colors
|
|
180
168
|
scalar?: number; // Default: 1
|
|
181
169
|
origin?: { x?: number; y?: number }; // Default: { x: 0.5, y: 0.5 }
|
|
@@ -185,6 +173,8 @@ interface ConfettiConfig {
|
|
|
185
173
|
}
|
|
186
174
|
```
|
|
187
175
|
|
|
176
|
+
> `ticks` (frames) overrides `duration` when provided (60fps assumed).
|
|
177
|
+
|
|
188
178
|
### Available Presets
|
|
189
179
|
|
|
190
180
|
```typescript
|
|
@@ -30,6 +30,17 @@ const ConfettiCanvas = exports.ConfettiCanvas = /*#__PURE__*/_react.default.forw
|
|
|
30
30
|
...config.origin
|
|
31
31
|
}
|
|
32
32
|
};
|
|
33
|
+
const resolvedTicks = config.ticks ?? config.tickDuration ?? mergedConfig.ticks ?? mergedConfig.tickDuration;
|
|
34
|
+
if (resolvedTicks !== undefined) {
|
|
35
|
+
mergedConfig.ticks = resolvedTicks;
|
|
36
|
+
mergedConfig.tickDuration = resolvedTicks;
|
|
37
|
+
}
|
|
38
|
+
if (config.duration === undefined && resolvedTicks !== undefined) {
|
|
39
|
+
mergedConfig.duration = Math.round(resolvedTicks / 60 * 1000);
|
|
40
|
+
} else if (config.ticks === undefined && config.tickDuration === undefined) {
|
|
41
|
+
mergedConfig.ticks = Math.max(1, Math.round(mergedConfig.duration / 1000 * 60));
|
|
42
|
+
mergedConfig.tickDuration = mergedConfig.ticks;
|
|
43
|
+
}
|
|
33
44
|
const newParticles = (0, _utils.createConfettiParticles)(mergedConfig, width, height);
|
|
34
45
|
const particlesWithConfig = newParticles.map(p => ({
|
|
35
46
|
...p,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_utils","_ConfettiParticle","_jsxRuntime","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ConfettiCanvas","exports","React","forwardRef","containerStyle","zIndex","fullScreen","ref","particles","setParticles","useState","width","height","useWindowDimensions","fire","useCallback","config","Promise","resolve","mergedConfig","DEFAULT_CONFIG","origin","newParticles","createConfettiParticles","particlesWithConfig","map","p","prev","setTimeout","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_utils","_ConfettiParticle","_jsxRuntime","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ConfettiCanvas","exports","React","forwardRef","containerStyle","zIndex","fullScreen","ref","particles","setParticles","useState","width","height","useWindowDimensions","fire","useCallback","config","Promise","resolve","mergedConfig","DEFAULT_CONFIG","origin","resolvedTicks","ticks","tickDuration","undefined","duration","Math","round","max","newParticles","createConfettiParticles","particlesWithConfig","map","p","prev","setTimeout","reset","useImperativeHandle","confetti","handleParticleComplete","particleId","length","filter","id","slice","jsx","View","style","styles","container","pointerEvents","children","particle","ConfettiParticle","onComplete","displayName","StyleSheet","create","position","top","left","right","bottom"],"sourceRoot":"../../src","sources":["ConfettiCanvas.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -24,6 +24,7 @@ const ConfettiParticle = ({
|
|
|
24
24
|
const velX = (0, _reactNativeReanimated.useSharedValue)(particle.velocity.x);
|
|
25
25
|
const velY = (0, _reactNativeReanimated.useSharedValue)(particle.velocity.y);
|
|
26
26
|
const startTime = (0, _reactNativeReanimated.useSharedValue)(Date.now());
|
|
27
|
+
const lastFrameTime = (0, _reactNativeReanimated.useSharedValue)(Date.now());
|
|
27
28
|
const isComplete = (0, _reactNativeReanimated.useSharedValue)(false);
|
|
28
29
|
|
|
29
30
|
// Canvas-confetti realistic wobble and tilt variables
|
|
@@ -34,11 +35,13 @@ const ConfettiParticle = ({
|
|
|
34
35
|
const tiltCos = (0, _reactNativeReanimated.useSharedValue)(0);
|
|
35
36
|
const random = (0, _reactNativeReanimated.useSharedValue)(Math.random() + 2);
|
|
36
37
|
const tick = (0, _reactNativeReanimated.useSharedValue)(0);
|
|
37
|
-
const totalTicks = (0, _reactNativeReanimated.useSharedValue)(duration / 1000 * 60);
|
|
38
|
-
|
|
38
|
+
const totalTicks = (0, _reactNativeReanimated.useSharedValue)(Math.max(1, Math.round(config.ticks ?? config.tickDuration ?? duration / 1000 * 60)));
|
|
39
39
|
(0, _react.useEffect)(() => {
|
|
40
|
-
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
startTime.value = now;
|
|
42
|
+
lastFrameTime.value = now;
|
|
41
43
|
tick.value = 0;
|
|
44
|
+
totalTicks.value = Math.max(1, Math.round(config.ticks ?? config.tickDuration ?? duration / 1000 * 60));
|
|
42
45
|
|
|
43
46
|
// Cleanup callback
|
|
44
47
|
const timer = setTimeout(() => {
|
|
@@ -54,54 +57,75 @@ const ConfettiParticle = ({
|
|
|
54
57
|
(0, _reactNativeReanimated.cancelAnimation)(rotation);
|
|
55
58
|
(0, _reactNativeReanimated.cancelAnimation)(opacity);
|
|
56
59
|
};
|
|
57
|
-
}, [duration, onComplete, opacity, isComplete, startTime, translateX, translateY, rotation, tick]);
|
|
60
|
+
}, [config.tickDuration, config.ticks, duration, onComplete, opacity, isComplete, startTime, lastFrameTime, totalTicks, translateX, translateY, rotation, tick]);
|
|
58
61
|
|
|
59
62
|
// Real-time physics simulation using frame callback
|
|
60
|
-
|
|
63
|
+
// Frame-rate independent: uses deltaTime to ensure consistent speed across devices
|
|
64
|
+
(0, _reactNativeReanimated.useFrameCallback)(frameInfo => {
|
|
61
65
|
'worklet';
|
|
62
66
|
|
|
63
67
|
if (isComplete.value) {
|
|
64
68
|
return;
|
|
65
69
|
}
|
|
66
|
-
const
|
|
70
|
+
const currentTime = Date.now();
|
|
71
|
+
const elapsed = currentTime - startTime.value;
|
|
67
72
|
if (elapsed >= duration) {
|
|
68
73
|
isComplete.value = true;
|
|
69
74
|
return;
|
|
70
75
|
}
|
|
71
76
|
|
|
72
|
-
//
|
|
73
|
-
|
|
74
|
-
|
|
77
|
+
// Calculate deltaTime normalized to 60fps (16.67ms per frame)
|
|
78
|
+
// This ensures consistent animation speed regardless of device frame rate
|
|
79
|
+
const frameDelta = currentTime - lastFrameTime.value;
|
|
80
|
+
|
|
81
|
+
// Handle first frame or invalid deltas
|
|
82
|
+
if (frameDelta <= 0 || frameDelta > 1000) {
|
|
83
|
+
lastFrameTime.value = currentTime;
|
|
84
|
+
return; // Skip this frame
|
|
85
|
+
}
|
|
86
|
+
const deltaTime = frameDelta / 16.67;
|
|
87
|
+
lastFrameTime.value = currentTime;
|
|
88
|
+
|
|
89
|
+
// Clamp deltaTime to prevent large jumps (e.g., when app resumes from background)
|
|
90
|
+
// Max 2.0 means we allow up to 2x normal frame time (30fps equivalent)
|
|
91
|
+
const clampedDelta = Math.min(deltaTime, 2.0);
|
|
92
|
+
|
|
93
|
+
// Update position based on current velocity (scaled by deltaTime for frame-rate independence)
|
|
94
|
+
// Velocity is in pixels per frame at 60fps, so we scale by deltaTime
|
|
95
|
+
translateX.value += velX.value * clampedDelta;
|
|
96
|
+
translateY.value += velY.value * clampedDelta;
|
|
75
97
|
|
|
76
98
|
// Apply gravity (increases downward velocity) - realistic physics!
|
|
77
|
-
|
|
99
|
+
// Gravity is per frame at 60fps, so scale by deltaTime
|
|
100
|
+
velY.value += config.gravity * clampedDelta;
|
|
78
101
|
|
|
79
102
|
// Apply drift (horizontal wind)
|
|
80
|
-
velX.value += config.drift;
|
|
103
|
+
velX.value += config.drift * clampedDelta;
|
|
81
104
|
|
|
82
|
-
// Apply decay (air resistance)
|
|
83
|
-
velX.value *= config.decay;
|
|
84
|
-
velY.value *= config.decay;
|
|
105
|
+
// Apply decay (air resistance) - decay per frame, so raise to power of deltaTime
|
|
106
|
+
velX.value *= Math.pow(config.decay, clampedDelta);
|
|
107
|
+
velY.value *= Math.pow(config.decay, clampedDelta);
|
|
85
108
|
|
|
86
109
|
// Update rotation - ALL particles spin faster when moving fast, slower when slowing down
|
|
87
110
|
const speed = Math.sqrt(velX.value * velX.value + velY.value * velY.value);
|
|
88
111
|
const speedBoost = 1 + speed / 20;
|
|
89
|
-
rotation.value += particle.rotationVelocity * speedBoost;
|
|
112
|
+
rotation.value += particle.rotationVelocity * speedBoost * clampedDelta;
|
|
90
113
|
|
|
91
114
|
// Canvas-confetti wobble effect (creates side-to-side flutter)
|
|
92
|
-
wobble.value += wobbleSpeed.value;
|
|
115
|
+
wobble.value += wobbleSpeed.value * clampedDelta;
|
|
93
116
|
|
|
94
117
|
// Canvas-confetti tilt animation (creates 3D tumbling effect)
|
|
95
|
-
tiltAngle.value += 0.1;
|
|
118
|
+
tiltAngle.value += 0.1 * clampedDelta;
|
|
96
119
|
tiltSin.value = Math.sin(tiltAngle.value);
|
|
97
120
|
tiltCos.value = Math.cos(tiltAngle.value);
|
|
98
121
|
random.value = Math.random() + 2;
|
|
99
122
|
|
|
100
|
-
// Update tick for progressive opacity fade
|
|
101
|
-
|
|
123
|
+
// Update tick for progressive opacity fade (time-based, not frame-based)
|
|
124
|
+
// Use elapsed time instead of frame count for frame-rate independence
|
|
125
|
+
const progress = Math.min(1, elapsed / duration);
|
|
126
|
+
tick.value = progress * totalTicks.value;
|
|
102
127
|
|
|
103
128
|
// Canvas-confetti progressive fade: opacity decreases linearly over lifetime
|
|
104
|
-
const progress = tick.value / totalTicks.value;
|
|
105
129
|
opacity.value = 1 - progress;
|
|
106
130
|
});
|
|
107
131
|
const animatedStyle = (0, _reactNativeReanimated.useAnimatedStyle)(() => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_jsxRuntime","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ConfettiParticle","particle","config","duration","onComplete","translateX","useSharedValue","translateY","rotation","opacity","velX","velocity","x","velY","y","startTime","Date","now","isComplete","wobble","Math","random","wobbleSpeed","min","tiltAngle","tiltSin","tiltCos","tick","totalTicks","useEffect","value","timer","setTimeout","clearTimeout","cancelAnimation","useFrameCallback","elapsed","gravity","drift","decay","speed","sqrt","speedBoost","rotationVelocity","sin","cos","progress","animatedStyle","useAnimatedStyle","wobbleX","scalar","wobbleY","x1","y1","x2","y2","scaleX","abs","scaleY","transform","rotate","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_jsxRuntime","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ConfettiParticle","particle","config","duration","onComplete","translateX","useSharedValue","translateY","rotation","opacity","velX","velocity","x","velY","y","startTime","Date","now","lastFrameTime","isComplete","wobble","Math","random","wobbleSpeed","min","tiltAngle","tiltSin","tiltCos","tick","totalTicks","max","round","ticks","tickDuration","useEffect","value","timer","setTimeout","clearTimeout","cancelAnimation","useFrameCallback","frameInfo","currentTime","elapsed","frameDelta","deltaTime","clampedDelta","gravity","drift","pow","decay","speed","sqrt","speedBoost","rotationVelocity","sin","cos","progress","animatedStyle","useAnimatedStyle","wobbleX","scalar","wobbleY","x1","y1","x2","y2","scaleX","abs","scaleY","transform","rotate","renderShape","shape","size","width","jsx","View","style","styles","circle","height","backgroundColor","color","fontSize","Text","star","textShadowColor","children","container","left","top","exports","StyleSheet","create","position","borderRadius","textShadowOffset","textShadowRadius"],"sourceRoot":"../../src","sources":["ConfettiParticle.tsx"],"mappings":"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","ignoreList":[]}
|
package/lib/commonjs/utils.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DEFAULT_COLORS","exports","DEFAULT_CONFIG","particleCount","angle","spread","startVelocity","decay","gravity","drift","duration","colors","scalar","origin","x","y","shapes","tilt","tiltAngleIncrement","tickDuration","disableForReducedMotion","usePerformanceMode","degreesToRadians","degrees","Math","PI","randomRange","min","max","random","randomFromArray","arr","item","floor","length","undefined","Error","createConfettiParticles","config","screenWidth","screenHeight","particles","angleInRadians","spreadInRadians","timestamp","Date","now","i","spreadVariation","particleAngle","velocityMagnitude","baseWidth","aspectRatio","particle","id","color","shape","width","height","velocity","cos","sin","rotation","rotationVelocity","tiltAngle","opacity","push","updateParticle","deltaTime","dt","newVelocityY","newVelocityX","newX","newY","newRotation","newOpacity","pow"],"sourceRoot":"../../src","sources":["utils.ts"],"mappings":";;;;;;AAEA;AACA;AACO,MAAMA,cAAc,GAAAC,OAAA,CAAAD,cAAA,GAAG;AAC5B;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS,CAAE;AAAA,CACZ;AAEM,MAAME,cAAwC,GAAAD,OAAA,CAAAC,cAAA,GAAG;EACtDC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,EAAE;EACTC,MAAM,EAAE,EAAE;EACVC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,GAAG;EACVC,OAAO,EAAE,CAAC;EACVC,KAAK,EAAE,CAAC;EACRC,QAAQ,EAAE,IAAI;EACdC,MAAM,EAAEX,cAAc;EACtBY,MAAM,EAAE,CAAC;EACTC,MAAM,EAAE;IAAEC,CAAC,EAAE,GAAG;IAAEC,CAAC,EAAE;EAAI,CAAC;EAC1BC,MAAM,EAAE,CAAC,QAAQ,CAAC;EAAE;EACpBC,IAAI,EAAE,IAAI;EACVC,kBAAkB,EAAE,EAAE;EACtBC,YAAY,EAAE,GAAG;EACjBC,uBAAuB,EAAE,KAAK;EAC9BC,kBAAkB,EAAE;AACtB,CAAC;;AAED;AACA;AACA;AACO,MAAMC,gBAAgB,GAAIC,OAAe,IAAa;EAC3D,OAAQA,OAAO,GAAGC,IAAI,CAACC,EAAE,GAAI,GAAG;AAClC,CAAC;;AAED;AACA;AACA;
|
|
1
|
+
{"version":3,"names":["DEFAULT_COLORS","exports","DEFAULT_CONFIG","particleCount","angle","spread","startVelocity","decay","gravity","drift","duration","colors","scalar","origin","x","y","shapes","tilt","tiltAngleIncrement","tickDuration","ticks","disableForReducedMotion","usePerformanceMode","degreesToRadians","degrees","Math","PI","randomRange","min","max","random","randomFromArray","arr","item","floor","length","undefined","Error","createConfettiParticles","config","screenWidth","screenHeight","particles","angleInRadians","spreadInRadians","timestamp","Date","now","i","spreadVariation","particleAngle","velocityMagnitude","baseWidth","aspectRatio","particle","id","color","shape","width","height","velocity","cos","sin","rotation","rotationVelocity","tiltAngle","opacity","push","updateParticle","deltaTime","dt","newVelocityY","newVelocityX","newX","newY","newRotation","newOpacity","pow"],"sourceRoot":"../../src","sources":["utils.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -25,6 +25,17 @@ export const ConfettiCanvas = /*#__PURE__*/React.forwardRef(({
|
|
|
25
25
|
...config.origin
|
|
26
26
|
}
|
|
27
27
|
};
|
|
28
|
+
const resolvedTicks = config.ticks ?? config.tickDuration ?? mergedConfig.ticks ?? mergedConfig.tickDuration;
|
|
29
|
+
if (resolvedTicks !== undefined) {
|
|
30
|
+
mergedConfig.ticks = resolvedTicks;
|
|
31
|
+
mergedConfig.tickDuration = resolvedTicks;
|
|
32
|
+
}
|
|
33
|
+
if (config.duration === undefined && resolvedTicks !== undefined) {
|
|
34
|
+
mergedConfig.duration = Math.round(resolvedTicks / 60 * 1000);
|
|
35
|
+
} else if (config.ticks === undefined && config.tickDuration === undefined) {
|
|
36
|
+
mergedConfig.ticks = Math.max(1, Math.round(mergedConfig.duration / 1000 * 60));
|
|
37
|
+
mergedConfig.tickDuration = mergedConfig.ticks;
|
|
38
|
+
}
|
|
28
39
|
const newParticles = createConfettiParticles(mergedConfig, width, height);
|
|
29
40
|
const particlesWithConfig = newParticles.map(p => ({
|
|
30
41
|
...p,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useCallback","useImperativeHandle","useState","StyleSheet","View","useWindowDimensions","createConfettiParticles","DEFAULT_CONFIG","ConfettiParticle","jsx","_jsx","ConfettiCanvas","forwardRef","containerStyle","zIndex","fullScreen","ref","particles","setParticles","width","height","fire","config","Promise","resolve","mergedConfig","origin","newParticles","particlesWithConfig","map","p","prev","setTimeout","
|
|
1
|
+
{"version":3,"names":["React","useCallback","useImperativeHandle","useState","StyleSheet","View","useWindowDimensions","createConfettiParticles","DEFAULT_CONFIG","ConfettiParticle","jsx","_jsx","ConfettiCanvas","forwardRef","containerStyle","zIndex","fullScreen","ref","particles","setParticles","width","height","fire","config","Promise","resolve","mergedConfig","origin","resolvedTicks","ticks","tickDuration","undefined","duration","Math","round","max","newParticles","particlesWithConfig","map","p","prev","setTimeout","reset","confetti","handleParticleComplete","particleId","length","filter","id","slice","style","styles","container","pointerEvents","children","particle","onComplete","displayName","create","position","top","left","right","bottom"],"sourceRoot":"../../src","sources":["ConfettiCanvas.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -19,6 +19,7 @@ export const ConfettiParticle = ({
|
|
|
19
19
|
const velX = useSharedValue(particle.velocity.x);
|
|
20
20
|
const velY = useSharedValue(particle.velocity.y);
|
|
21
21
|
const startTime = useSharedValue(Date.now());
|
|
22
|
+
const lastFrameTime = useSharedValue(Date.now());
|
|
22
23
|
const isComplete = useSharedValue(false);
|
|
23
24
|
|
|
24
25
|
// Canvas-confetti realistic wobble and tilt variables
|
|
@@ -29,11 +30,13 @@ export const ConfettiParticle = ({
|
|
|
29
30
|
const tiltCos = useSharedValue(0);
|
|
30
31
|
const random = useSharedValue(Math.random() + 2);
|
|
31
32
|
const tick = useSharedValue(0);
|
|
32
|
-
const totalTicks = useSharedValue(duration / 1000 * 60);
|
|
33
|
-
|
|
33
|
+
const totalTicks = useSharedValue(Math.max(1, Math.round(config.ticks ?? config.tickDuration ?? duration / 1000 * 60)));
|
|
34
34
|
useEffect(() => {
|
|
35
|
-
|
|
35
|
+
const now = Date.now();
|
|
36
|
+
startTime.value = now;
|
|
37
|
+
lastFrameTime.value = now;
|
|
36
38
|
tick.value = 0;
|
|
39
|
+
totalTicks.value = Math.max(1, Math.round(config.ticks ?? config.tickDuration ?? duration / 1000 * 60));
|
|
37
40
|
|
|
38
41
|
// Cleanup callback
|
|
39
42
|
const timer = setTimeout(() => {
|
|
@@ -49,54 +52,75 @@ export const ConfettiParticle = ({
|
|
|
49
52
|
cancelAnimation(rotation);
|
|
50
53
|
cancelAnimation(opacity);
|
|
51
54
|
};
|
|
52
|
-
}, [duration, onComplete, opacity, isComplete, startTime, translateX, translateY, rotation, tick]);
|
|
55
|
+
}, [config.tickDuration, config.ticks, duration, onComplete, opacity, isComplete, startTime, lastFrameTime, totalTicks, translateX, translateY, rotation, tick]);
|
|
53
56
|
|
|
54
57
|
// Real-time physics simulation using frame callback
|
|
55
|
-
|
|
58
|
+
// Frame-rate independent: uses deltaTime to ensure consistent speed across devices
|
|
59
|
+
useFrameCallback(frameInfo => {
|
|
56
60
|
'worklet';
|
|
57
61
|
|
|
58
62
|
if (isComplete.value) {
|
|
59
63
|
return;
|
|
60
64
|
}
|
|
61
|
-
const
|
|
65
|
+
const currentTime = Date.now();
|
|
66
|
+
const elapsed = currentTime - startTime.value;
|
|
62
67
|
if (elapsed >= duration) {
|
|
63
68
|
isComplete.value = true;
|
|
64
69
|
return;
|
|
65
70
|
}
|
|
66
71
|
|
|
67
|
-
//
|
|
68
|
-
|
|
69
|
-
|
|
72
|
+
// Calculate deltaTime normalized to 60fps (16.67ms per frame)
|
|
73
|
+
// This ensures consistent animation speed regardless of device frame rate
|
|
74
|
+
const frameDelta = currentTime - lastFrameTime.value;
|
|
75
|
+
|
|
76
|
+
// Handle first frame or invalid deltas
|
|
77
|
+
if (frameDelta <= 0 || frameDelta > 1000) {
|
|
78
|
+
lastFrameTime.value = currentTime;
|
|
79
|
+
return; // Skip this frame
|
|
80
|
+
}
|
|
81
|
+
const deltaTime = frameDelta / 16.67;
|
|
82
|
+
lastFrameTime.value = currentTime;
|
|
83
|
+
|
|
84
|
+
// Clamp deltaTime to prevent large jumps (e.g., when app resumes from background)
|
|
85
|
+
// Max 2.0 means we allow up to 2x normal frame time (30fps equivalent)
|
|
86
|
+
const clampedDelta = Math.min(deltaTime, 2.0);
|
|
87
|
+
|
|
88
|
+
// Update position based on current velocity (scaled by deltaTime for frame-rate independence)
|
|
89
|
+
// Velocity is in pixels per frame at 60fps, so we scale by deltaTime
|
|
90
|
+
translateX.value += velX.value * clampedDelta;
|
|
91
|
+
translateY.value += velY.value * clampedDelta;
|
|
70
92
|
|
|
71
93
|
// Apply gravity (increases downward velocity) - realistic physics!
|
|
72
|
-
|
|
94
|
+
// Gravity is per frame at 60fps, so scale by deltaTime
|
|
95
|
+
velY.value += config.gravity * clampedDelta;
|
|
73
96
|
|
|
74
97
|
// Apply drift (horizontal wind)
|
|
75
|
-
velX.value += config.drift;
|
|
98
|
+
velX.value += config.drift * clampedDelta;
|
|
76
99
|
|
|
77
|
-
// Apply decay (air resistance)
|
|
78
|
-
velX.value *= config.decay;
|
|
79
|
-
velY.value *= config.decay;
|
|
100
|
+
// Apply decay (air resistance) - decay per frame, so raise to power of deltaTime
|
|
101
|
+
velX.value *= Math.pow(config.decay, clampedDelta);
|
|
102
|
+
velY.value *= Math.pow(config.decay, clampedDelta);
|
|
80
103
|
|
|
81
104
|
// Update rotation - ALL particles spin faster when moving fast, slower when slowing down
|
|
82
105
|
const speed = Math.sqrt(velX.value * velX.value + velY.value * velY.value);
|
|
83
106
|
const speedBoost = 1 + speed / 20;
|
|
84
|
-
rotation.value += particle.rotationVelocity * speedBoost;
|
|
107
|
+
rotation.value += particle.rotationVelocity * speedBoost * clampedDelta;
|
|
85
108
|
|
|
86
109
|
// Canvas-confetti wobble effect (creates side-to-side flutter)
|
|
87
|
-
wobble.value += wobbleSpeed.value;
|
|
110
|
+
wobble.value += wobbleSpeed.value * clampedDelta;
|
|
88
111
|
|
|
89
112
|
// Canvas-confetti tilt animation (creates 3D tumbling effect)
|
|
90
|
-
tiltAngle.value += 0.1;
|
|
113
|
+
tiltAngle.value += 0.1 * clampedDelta;
|
|
91
114
|
tiltSin.value = Math.sin(tiltAngle.value);
|
|
92
115
|
tiltCos.value = Math.cos(tiltAngle.value);
|
|
93
116
|
random.value = Math.random() + 2;
|
|
94
117
|
|
|
95
|
-
// Update tick for progressive opacity fade
|
|
96
|
-
|
|
118
|
+
// Update tick for progressive opacity fade (time-based, not frame-based)
|
|
119
|
+
// Use elapsed time instead of frame count for frame-rate independence
|
|
120
|
+
const progress = Math.min(1, elapsed / duration);
|
|
121
|
+
tick.value = progress * totalTicks.value;
|
|
97
122
|
|
|
98
123
|
// Canvas-confetti progressive fade: opacity decreases linearly over lifetime
|
|
99
|
-
const progress = tick.value / totalTicks.value;
|
|
100
124
|
opacity.value = 1 - progress;
|
|
101
125
|
});
|
|
102
126
|
const animatedStyle = useAnimatedStyle(() => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","useEffect","StyleSheet","Animated","useAnimatedStyle","useSharedValue","useFrameCallback","cancelAnimation","jsx","_jsx","ConfettiParticle","particle","config","duration","onComplete","translateX","translateY","rotation","opacity","velX","velocity","x","velY","y","startTime","Date","now","isComplete","wobble","Math","random","wobbleSpeed","min","tiltAngle","tiltSin","tiltCos","tick","totalTicks","value","timer","setTimeout","clearTimeout","elapsed","gravity","drift","decay","speed","sqrt","speedBoost","rotationVelocity","sin","cos","progress","animatedStyle","wobbleX","scalar","wobbleY","x1","y1","x2","y2","scaleX","abs","scaleY","transform","rotate","
|
|
1
|
+
{"version":3,"names":["React","useEffect","StyleSheet","Animated","useAnimatedStyle","useSharedValue","useFrameCallback","cancelAnimation","jsx","_jsx","ConfettiParticle","particle","config","duration","onComplete","translateX","translateY","rotation","opacity","velX","velocity","x","velY","y","startTime","Date","now","lastFrameTime","isComplete","wobble","Math","random","wobbleSpeed","min","tiltAngle","tiltSin","tiltCos","tick","totalTicks","max","round","ticks","tickDuration","value","timer","setTimeout","clearTimeout","frameInfo","currentTime","elapsed","frameDelta","deltaTime","clampedDelta","gravity","drift","pow","decay","speed","sqrt","speedBoost","rotationVelocity","sin","cos","progress","animatedStyle","wobbleX","scalar","wobbleY","x1","y1","x2","y2","scaleX","abs","scaleY","transform","rotate","renderShape","shape","size","width","View","style","styles","circle","height","backgroundColor","color","fontSize","Text","star","textShadowColor","children","container","left","top","create","position","borderRadius","textShadowOffset","textShadowRadius"],"sourceRoot":"../../src","sources":["ConfettiParticle.tsx"],"mappings":"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","ignoreList":[]}
|
package/lib/module/utils.js
CHANGED
package/lib/module/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DEFAULT_COLORS","DEFAULT_CONFIG","particleCount","angle","spread","startVelocity","decay","gravity","drift","duration","colors","scalar","origin","x","y","shapes","tilt","tiltAngleIncrement","tickDuration","disableForReducedMotion","usePerformanceMode","degreesToRadians","degrees","Math","PI","randomRange","min","max","random","randomFromArray","arr","item","floor","length","undefined","Error","createConfettiParticles","config","screenWidth","screenHeight","particles","angleInRadians","spreadInRadians","timestamp","Date","now","i","spreadVariation","particleAngle","velocityMagnitude","baseWidth","aspectRatio","particle","id","color","shape","width","height","velocity","cos","sin","rotation","rotationVelocity","tiltAngle","opacity","push","updateParticle","deltaTime","dt","newVelocityY","newVelocityX","newX","newY","newRotation","newOpacity","pow"],"sourceRoot":"../../src","sources":["utils.ts"],"mappings":";;AAEA;AACA;AACA,OAAO,MAAMA,cAAc,GAAG;AAC5B;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS,CAAE;AAAA,CACZ;AAED,OAAO,MAAMC,cAAwC,GAAG;EACtDC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,EAAE;EACTC,MAAM,EAAE,EAAE;EACVC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,GAAG;EACVC,OAAO,EAAE,CAAC;EACVC,KAAK,EAAE,CAAC;EACRC,QAAQ,EAAE,IAAI;EACdC,MAAM,EAAEV,cAAc;EACtBW,MAAM,EAAE,CAAC;EACTC,MAAM,EAAE;IAAEC,CAAC,EAAE,GAAG;IAAEC,CAAC,EAAE;EAAI,CAAC;EAC1BC,MAAM,EAAE,CAAC,QAAQ,CAAC;EAAE;EACpBC,IAAI,EAAE,IAAI;EACVC,kBAAkB,EAAE,EAAE;EACtBC,YAAY,EAAE,GAAG;EACjBC,uBAAuB,EAAE,KAAK;EAC9BC,kBAAkB,EAAE;AACtB,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMC,gBAAgB,GAAIC,OAAe,IAAa;EAC3D,OAAQA,OAAO,GAAGC,IAAI,CAACC,EAAE,GAAI,GAAG;AAClC,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMC,WAAW,GAAGA,CAACC,GAAW,EAAEC,GAAW,KAAa;EAC/D,OAAOJ,IAAI,CAACK,MAAM,CAAC,CAAC,IAAID,GAAG,GAAGD,GAAG,CAAC,GAAGA,GAAG;AAC1C,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMG,eAAe,GAAOC,GAAQ,IAAQ;EACjD,MAAMC,IAAI,GAAGD,GAAG,CAACP,IAAI,CAACS,KAAK,CAACT,IAAI,CAACK,MAAM,CAAC,CAAC,GAAGE,GAAG,CAACG,MAAM,CAAC,CAAC;EACxD,IAAIF,IAAI,KAAKG,SAAS,EAAE;IACtB,MAAM,IAAIC,KAAK,CAAC,gBAAgB,CAAC;EACnC;EACA,OAAOJ,IAAI;AACb,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMK,uBAAuB,GAAGA,CACrCC,MAAgC,EAChCC,WAAmB,EACnBC,YAAoB,KACG;EACvB,MAAMC,SAA6B,GAAG,EAAE;EACxC,MAAMC,cAAc,GAAGpB,gBAAgB,CAACgB,MAAM,
|
|
1
|
+
{"version":3,"names":["DEFAULT_COLORS","DEFAULT_CONFIG","particleCount","angle","spread","startVelocity","decay","gravity","drift","duration","colors","scalar","origin","x","y","shapes","tilt","tiltAngleIncrement","tickDuration","ticks","disableForReducedMotion","usePerformanceMode","degreesToRadians","degrees","Math","PI","randomRange","min","max","random","randomFromArray","arr","item","floor","length","undefined","Error","createConfettiParticles","config","screenWidth","screenHeight","particles","angleInRadians","spreadInRadians","timestamp","Date","now","i","spreadVariation","particleAngle","velocityMagnitude","baseWidth","aspectRatio","particle","id","color","shape","width","height","velocity","cos","sin","rotation","rotationVelocity","tiltAngle","opacity","push","updateParticle","deltaTime","dt","newVelocityY","newVelocityX","newX","newY","newRotation","newOpacity","pow"],"sourceRoot":"../../src","sources":["utils.ts"],"mappings":";;AAEA;AACA;AACA,OAAO,MAAMA,cAAc,GAAG;AAC5B;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX;AACA,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS;AAAE;AACX,SAAS,CAAE;AAAA,CACZ;AAED,OAAO,MAAMC,cAAwC,GAAG;EACtDC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,EAAE;EACTC,MAAM,EAAE,EAAE;EACVC,aAAa,EAAE,EAAE;EACjBC,KAAK,EAAE,GAAG;EACVC,OAAO,EAAE,CAAC;EACVC,KAAK,EAAE,CAAC;EACRC,QAAQ,EAAE,IAAI;EACdC,MAAM,EAAEV,cAAc;EACtBW,MAAM,EAAE,CAAC;EACTC,MAAM,EAAE;IAAEC,CAAC,EAAE,GAAG;IAAEC,CAAC,EAAE;EAAI,CAAC;EAC1BC,MAAM,EAAE,CAAC,QAAQ,CAAC;EAAE;EACpBC,IAAI,EAAE,IAAI;EACVC,kBAAkB,EAAE,EAAE;EACtBC,YAAY,EAAE,GAAG;EACjBC,KAAK,EAAE,GAAG;EACVC,uBAAuB,EAAE,KAAK;EAC9BC,kBAAkB,EAAE;AACtB,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMC,gBAAgB,GAAIC,OAAe,IAAa;EAC3D,OAAQA,OAAO,GAAGC,IAAI,CAACC,EAAE,GAAI,GAAG;AAClC,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMC,WAAW,GAAGA,CAACC,GAAW,EAAEC,GAAW,KAAa;EAC/D,OAAOJ,IAAI,CAACK,MAAM,CAAC,CAAC,IAAID,GAAG,GAAGD,GAAG,CAAC,GAAGA,GAAG;AAC1C,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMG,eAAe,GAAOC,GAAQ,IAAQ;EACjD,MAAMC,IAAI,GAAGD,GAAG,CAACP,IAAI,CAACS,KAAK,CAACT,IAAI,CAACK,MAAM,CAAC,CAAC,GAAGE,GAAG,CAACG,MAAM,CAAC,CAAC;EACxD,IAAIF,IAAI,KAAKG,SAAS,EAAE;IACtB,MAAM,IAAIC,KAAK,CAAC,gBAAgB,CAAC;EACnC;EACA,OAAOJ,IAAI;AACb,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMK,uBAAuB,GAAGA,CACrCC,MAAgC,EAChCC,WAAmB,EACnBC,YAAoB,KACG;EACvB,MAAMC,SAA6B,GAAG,EAAE;EACxC,MAAMC,cAAc,GAAGpB,gBAAgB,CAACgB,MAAM,CAACnC,KAAK,CAAC;EACrD,MAAMwC,eAAe,GAAGrB,gBAAgB,CAACgB,MAAM,CAAClC,MAAM,CAAC;EAEvD,MAAMwC,SAAS,GAAGC,IAAI,CAACC,GAAG,CAAC,CAAC;EAC5B,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGT,MAAM,CAACpC,aAAa,EAAE6C,CAAC,EAAE,EAAE;IAC7C;IACA,MAAMC,eAAe,GAAGtB,WAAW,CAAC,CAACiB,eAAe,GAAG,CAAC,EAAEA,eAAe,GAAG,CAAC,CAAC;IAC9E,MAAMM,aAAa,GAAGP,cAAc,GAAGM,eAAe;IACtD;IACA,MAAME,iBAAiB,GAAGZ,MAAM,CAACjC,aAAa,IAAI,GAAG,GAAGmB,IAAI,CAACK,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC;IAC5E;IACA,MAAMsB,SAAS,GAAG,CAAC,CAAC,GAAG3B,IAAI,CAACK,MAAM,CAAC,CAAC,GAAG,CAAC,IAAIS,MAAM,CAAC3B,MAAM,CAAC,CAAC;IAC3D,MAAMyC,WAAW,GAAG,GAAG,GAAG5B,IAAI,CAACK,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;IAC/C,MAAMwB,QAA0B,GAAG;MACjCC,EAAE,EAAE,YAAYV,SAAS,IAAIG,CAAC,IAAIvB,IAAI,CAACK,MAAM,CAAC,CAAC,EAAE;MACjD0B,KAAK,EAAEzB,eAAe,CAACQ,MAAM,CAAC5B,MAAM,CAAC;MACrC8C,KAAK,EAAE1B,eAAe,CAACQ,MAAM,CAACvB,MAAM,CAAC;MACrCF,CAAC,EAAE,CAACyB,MAAM,CAAC1B,MAAM,CAACC,CAAC,IAAI,GAAG,IAAI0B,WAAW;MACzCzB,CAAC,EAAE,CAACwB,MAAM,CAAC1B,MAAM,CAACE,CAAC,IAAI,GAAG,IAAI0B,YAAY;MAC1CiB,KAAK,EAAEN,SAAS;MAChBO,MAAM,EAAEP,SAAS,GAAGC,WAAW;MAAE;MACjCO,QAAQ,EAAE;QACR;QACA;QACA9C,CAAC,EAAEW,IAAI,CAACoC,GAAG,CAACX,aAAa,CAAC,GAAGC,iBAAiB;QAC9CpC,CAAC,EAAE,CAACU,IAAI,CAACqC,GAAG,CAACZ,aAAa,CAAC,GAAGC,iBAAiB,CAAE;MACnD,CAAC;MACDY,QAAQ,EAAEtC,IAAI,CAACK,MAAM,CAAC,CAAC,GAAG,GAAG;MAC7BkC,gBAAgB,EAAErC,WAAW,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC;MAAE;MACxCsC,SAAS,EAAE1B,MAAM,CAACtB,IAAI,GAAGQ,IAAI,CAACK,MAAM,CAAC,CAAC,GAAGS,MAAM,CAACrB,kBAAkB,GAAG,CAAC;MACtEgD,OAAO,EAAE;IACX,CAAC;IAEDxB,SAAS,CAACyB,IAAI,CAACb,QAAQ,CAAC;EAC1B;EAEA,OAAOZ,SAAS;AAClB,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAM0B,cAAc,GAAGA,CAC5Bd,QAA0B,EAC1Bf,MAAgC,EAChC8B,SAAiB,KACI;EACrB,MAAMC,EAAE,GAAGD,SAAS,GAAG,EAAE,CAAC,CAAC;;EAE3B;EACA,MAAME,YAAY,GAAGjB,QAAQ,CAACM,QAAQ,CAAC7C,CAAC,GAAGwB,MAAM,CAAC/B,OAAO,GAAG8D,EAAE;EAC9D;EACA,MAAME,YAAY,GAAGlB,QAAQ,CAACM,QAAQ,CAAC9C,CAAC,GAAGyB,MAAM,CAAC9B,KAAK,GAAG6D,EAAE;;EAE5D;EACA,MAAMG,IAAI,GAAGnB,QAAQ,CAACxC,CAAC,GAAG0D,YAAY,GAAGF,EAAE;EAC3C,MAAMI,IAAI,GAAGpB,QAAQ,CAACvC,CAAC,GAAGwD,YAAY,GAAGD,EAAE;;EAE3C;EACA,MAAMK,WAAW,GAAGrB,QAAQ,CAACS,QAAQ,GAAGT,QAAQ,CAACU,gBAAgB,GAAGM,EAAE;;EAEtE;EACA,MAAMM,UAAU,GAAGtB,QAAQ,CAACY,OAAO,GAAGzC,IAAI,CAACoD,GAAG,CAACtC,MAAM,CAAChC,KAAK,EAAE+D,EAAE,CAAC;EAEhE,OAAO;IACL,GAAGhB,QAAQ;IACXxC,CAAC,EAAE2D,IAAI;IACP1D,CAAC,EAAE2D,IAAI;IACPd,QAAQ,EAAE;MACR9C,CAAC,EAAE0D,YAAY;MACfzD,CAAC,EAAEwD;IACL,CAAC;IACDR,QAAQ,EAAEY,WAAW;IACrBT,OAAO,EAAEU;EACX,CAAC;AACH,CAAC","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfettiCanvas.d.ts","sourceRoot":"","sources":["../../src/ConfettiCanvas.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqD,MAAM,OAAO,CAAC;AAE1E,OAAO,KAAK,EAAkB,eAAe,EAAE,MAAM,SAAS,CAAC;AAK/D,MAAM,WAAW,mBAAmB;IAClC;;OAEG;IACH,cAAc,CAAC,EAAE,GAAG,CAAC;IAErB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAMD,eAAO,MAAM,cAAc,
|
|
1
|
+
{"version":3,"file":"ConfettiCanvas.d.ts","sourceRoot":"","sources":["../../src/ConfettiCanvas.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAqD,MAAM,OAAO,CAAC;AAE1E,OAAO,KAAK,EAAkB,eAAe,EAAE,MAAM,SAAS,CAAC;AAK/D,MAAM,WAAW,mBAAmB;IAClC;;OAEG;IACH,cAAc,CAAC,EAAE,GAAG,CAAC;IAErB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAMD,eAAO,MAAM,cAAc,6FAmG1B,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ConfettiParticle.d.ts","sourceRoot":"","sources":["../../src/ConfettiParticle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAQzC,OAAO,KAAK,EAAE,gBAAgB,IAAI,oBAAoB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAExF,UAAU,KAAK;IACb,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,MAAM,EAAE,QAAQ,CAAC,cAAc,CAAC,CAAC;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;CACzB;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,
|
|
1
|
+
{"version":3,"file":"ConfettiParticle.d.ts","sourceRoot":"","sources":["../../src/ConfettiParticle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAQzC,OAAO,KAAK,EAAE,gBAAgB,IAAI,oBAAoB,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAExF,UAAU,KAAK;IACb,QAAQ,EAAE,oBAAoB,CAAC;IAC/B,MAAM,EAAE,QAAQ,CAAC,cAAc,CAAC,CAAC;IACjC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,IAAI,CAAC;CACzB;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAyO5C,CAAC"}
|
|
@@ -78,6 +78,12 @@ export interface ConfettiConfig {
|
|
|
78
78
|
* @default 200
|
|
79
79
|
*/
|
|
80
80
|
tickDuration?: number;
|
|
81
|
+
/**
|
|
82
|
+
* Total ticks (frames) for the confetti animation
|
|
83
|
+
* Overrides duration when provided (60fps assumed)
|
|
84
|
+
* @default 200
|
|
85
|
+
*/
|
|
86
|
+
ticks?: number;
|
|
81
87
|
/**
|
|
82
88
|
* Disable physics
|
|
83
89
|
* @default false
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;;OAIG;IACH,MAAM,CAAC,EAAE;QACP,CAAC,CAAC,EAAE,MAAM,CAAC;QACX,CAAC,CAAC,EAAE,MAAM,CAAC;KACZ,CAAC;IAEF;;;OAGG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC,CAAC;IAE7C;;;OAGG;IACH,IAAI,CAAC,EAAE,OAAO,CAAC;IAEf;;;OAGG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAE5B;;;OAGG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB;;;OAGG;IACH,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAElC;;;OAGG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAED,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC;IACpC,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE;QACR,CAAC,EAAE,MAAM,CAAC;QACV,CAAC,EAAE,MAAM,CAAC;KACX,CAAC;IACF,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,CAAC,MAAM,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzC;;OAEG;IACH,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,cAAc;IAC7B;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;;OAGG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;;OAIG;IACH,MAAM,CAAC,EAAE;QACP,CAAC,CAAC,EAAE,MAAM,CAAC;QACX,CAAC,CAAC,EAAE,MAAM,CAAC;KACZ,CAAC;IAEF;;;OAGG;IACH,MAAM,CAAC,EAAE,KAAK,CAAC,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC,CAAC;IAE7C;;;OAGG;IACH,IAAI,CAAC,EAAE,OAAO,CAAC;IAEf;;;OAGG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAE5B;;;OAGG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB;;;;OAIG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf;;;OAGG;IACH,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAElC;;;OAGG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAC;CAC9B;AAED,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,CAAC;IACpC,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE;QACR,CAAC,EAAE,MAAM,CAAC;QACV,CAAC,EAAE,MAAM,CAAC;KACX,CAAC;IACF,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,CAAC,MAAM,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzC;;OAEG;IACH,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAIhE,eAAO,MAAM,cAAc,UAuB1B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,QAAQ,CAAC,cAAc,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAIhE,eAAO,MAAM,cAAc,UAuB1B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,QAAQ,CAAC,cAAc,CAmBnD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,gBAAgB,GAAI,SAAS,MAAM,KAAG,MAElD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,WAAW,GAAI,KAAK,MAAM,EAAE,KAAK,MAAM,KAAG,MAEtD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,eAAe,GAAI,CAAC,EAAE,KAAK,CAAC,EAAE,KAAG,CAM7C,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,uBAAuB,GAClC,QAAQ,QAAQ,CAAC,cAAc,CAAC,EAChC,aAAa,MAAM,EACnB,cAAc,MAAM,KACnB,gBAAgB,EAuClB,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,cAAc,GACzB,UAAU,gBAAgB,EAC1B,QAAQ,QAAQ,CAAC,cAAc,CAAC,EAChC,WAAW,MAAM,KAChB,gBA6BF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-confetti-reanimated",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.5",
|
|
4
4
|
"description": "A high-performance confetti component for React Native using Reanimated 4, compatible with Expo",
|
|
5
5
|
"main": "lib/commonjs/index.js",
|
|
6
6
|
"module": "lib/module/index.js",
|
package/src/ConfettiCanvas.tsx
CHANGED
|
@@ -45,6 +45,27 @@ export const ConfettiCanvas = React.forwardRef<ConfettiMethods, ConfettiCanvasPr
|
|
|
45
45
|
},
|
|
46
46
|
};
|
|
47
47
|
|
|
48
|
+
const resolvedTicks =
|
|
49
|
+
config.ticks ??
|
|
50
|
+
config.tickDuration ??
|
|
51
|
+
mergedConfig.ticks ??
|
|
52
|
+
mergedConfig.tickDuration;
|
|
53
|
+
|
|
54
|
+
if (resolvedTicks !== undefined) {
|
|
55
|
+
mergedConfig.ticks = resolvedTicks;
|
|
56
|
+
mergedConfig.tickDuration = resolvedTicks;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
if (config.duration === undefined && resolvedTicks !== undefined) {
|
|
60
|
+
mergedConfig.duration = Math.round((resolvedTicks / 60) * 1000);
|
|
61
|
+
} else if (config.ticks === undefined && config.tickDuration === undefined) {
|
|
62
|
+
mergedConfig.ticks = Math.max(
|
|
63
|
+
1,
|
|
64
|
+
Math.round((mergedConfig.duration / 1000) * 60),
|
|
65
|
+
);
|
|
66
|
+
mergedConfig.tickDuration = mergedConfig.ticks;
|
|
67
|
+
}
|
|
68
|
+
|
|
48
69
|
const newParticles = createConfettiParticles(mergedConfig, width, height);
|
|
49
70
|
const particlesWithConfig = newParticles.map(p => ({
|
|
50
71
|
...p,
|
|
@@ -54,8 +75,8 @@ export const ConfettiCanvas = React.forwardRef<ConfettiMethods, ConfettiCanvasPr
|
|
|
54
75
|
|
|
55
76
|
// Resolve after the duration
|
|
56
77
|
setTimeout(() => {
|
|
57
|
-
|
|
58
|
-
|
|
78
|
+
resolve(null);
|
|
79
|
+
}, mergedConfig.duration);
|
|
59
80
|
});
|
|
60
81
|
},
|
|
61
82
|
[width, height],
|
package/src/ConfettiParticle.tsx
CHANGED
|
@@ -25,6 +25,7 @@ export const ConfettiParticle: React.FC<Props> = ({ particle, config, duration,
|
|
|
25
25
|
const velX = useSharedValue(particle.velocity.x);
|
|
26
26
|
const velY = useSharedValue(particle.velocity.y);
|
|
27
27
|
const startTime = useSharedValue(Date.now());
|
|
28
|
+
const lastFrameTime = useSharedValue(Date.now());
|
|
28
29
|
const isComplete = useSharedValue(false);
|
|
29
30
|
|
|
30
31
|
// Canvas-confetti realistic wobble and tilt variables
|
|
@@ -35,11 +36,19 @@ export const ConfettiParticle: React.FC<Props> = ({ particle, config, duration,
|
|
|
35
36
|
const tiltCos = useSharedValue(0);
|
|
36
37
|
const random = useSharedValue(Math.random() + 2);
|
|
37
38
|
const tick = useSharedValue(0);
|
|
38
|
-
const totalTicks = useSharedValue(
|
|
39
|
+
const totalTicks = useSharedValue(
|
|
40
|
+
Math.max(1, Math.round((config.ticks ?? config.tickDuration ?? (duration / 1000) * 60))),
|
|
41
|
+
);
|
|
39
42
|
|
|
40
43
|
useEffect(() => {
|
|
41
|
-
|
|
44
|
+
const now = Date.now();
|
|
45
|
+
startTime.value = now;
|
|
46
|
+
lastFrameTime.value = now;
|
|
42
47
|
tick.value = 0;
|
|
48
|
+
totalTicks.value = Math.max(
|
|
49
|
+
1,
|
|
50
|
+
Math.round((config.ticks ?? config.tickDuration ?? (duration / 1000) * 60)),
|
|
51
|
+
);
|
|
43
52
|
|
|
44
53
|
// Cleanup callback
|
|
45
54
|
const timer = setTimeout(() => {
|
|
@@ -56,55 +65,91 @@ export const ConfettiParticle: React.FC<Props> = ({ particle, config, duration,
|
|
|
56
65
|
cancelAnimation(rotation);
|
|
57
66
|
cancelAnimation(opacity);
|
|
58
67
|
};
|
|
59
|
-
}, [
|
|
68
|
+
}, [
|
|
69
|
+
config.tickDuration,
|
|
70
|
+
config.ticks,
|
|
71
|
+
duration,
|
|
72
|
+
onComplete,
|
|
73
|
+
opacity,
|
|
74
|
+
isComplete,
|
|
75
|
+
startTime,
|
|
76
|
+
lastFrameTime,
|
|
77
|
+
totalTicks,
|
|
78
|
+
translateX,
|
|
79
|
+
translateY,
|
|
80
|
+
rotation,
|
|
81
|
+
tick,
|
|
82
|
+
]);
|
|
60
83
|
|
|
61
84
|
// Real-time physics simulation using frame callback
|
|
62
|
-
|
|
85
|
+
// Frame-rate independent: uses deltaTime to ensure consistent speed across devices
|
|
86
|
+
useFrameCallback((frameInfo) => {
|
|
63
87
|
'worklet';
|
|
64
88
|
|
|
65
89
|
if (isComplete.value) {
|
|
66
90
|
return;
|
|
67
91
|
}
|
|
68
92
|
|
|
69
|
-
const
|
|
93
|
+
const currentTime = Date.now();
|
|
94
|
+
const elapsed = currentTime - startTime.value;
|
|
70
95
|
if (elapsed >= duration) {
|
|
71
96
|
isComplete.value = true;
|
|
72
97
|
return;
|
|
73
98
|
}
|
|
74
99
|
|
|
75
|
-
//
|
|
76
|
-
|
|
77
|
-
|
|
100
|
+
// Calculate deltaTime normalized to 60fps (16.67ms per frame)
|
|
101
|
+
// This ensures consistent animation speed regardless of device frame rate
|
|
102
|
+
const frameDelta = currentTime - lastFrameTime.value;
|
|
103
|
+
|
|
104
|
+
// Handle first frame or invalid deltas
|
|
105
|
+
if (frameDelta <= 0 || frameDelta > 1000) {
|
|
106
|
+
lastFrameTime.value = currentTime;
|
|
107
|
+
return; // Skip this frame
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
const deltaTime = frameDelta / 16.67;
|
|
111
|
+
lastFrameTime.value = currentTime;
|
|
112
|
+
|
|
113
|
+
// Clamp deltaTime to prevent large jumps (e.g., when app resumes from background)
|
|
114
|
+
// Max 2.0 means we allow up to 2x normal frame time (30fps equivalent)
|
|
115
|
+
const clampedDelta = Math.min(deltaTime, 2.0);
|
|
116
|
+
|
|
117
|
+
// Update position based on current velocity (scaled by deltaTime for frame-rate independence)
|
|
118
|
+
// Velocity is in pixels per frame at 60fps, so we scale by deltaTime
|
|
119
|
+
translateX.value += velX.value * clampedDelta;
|
|
120
|
+
translateY.value += velY.value * clampedDelta;
|
|
78
121
|
|
|
79
122
|
// Apply gravity (increases downward velocity) - realistic physics!
|
|
80
|
-
|
|
123
|
+
// Gravity is per frame at 60fps, so scale by deltaTime
|
|
124
|
+
velY.value += config.gravity * clampedDelta;
|
|
81
125
|
|
|
82
126
|
// Apply drift (horizontal wind)
|
|
83
|
-
velX.value += config.drift;
|
|
127
|
+
velX.value += config.drift * clampedDelta;
|
|
84
128
|
|
|
85
|
-
// Apply decay (air resistance)
|
|
86
|
-
velX.value *= config.decay;
|
|
87
|
-
velY.value *= config.decay;
|
|
129
|
+
// Apply decay (air resistance) - decay per frame, so raise to power of deltaTime
|
|
130
|
+
velX.value *= Math.pow(config.decay, clampedDelta);
|
|
131
|
+
velY.value *= Math.pow(config.decay, clampedDelta);
|
|
88
132
|
|
|
89
133
|
// Update rotation - ALL particles spin faster when moving fast, slower when slowing down
|
|
90
134
|
const speed = Math.sqrt(velX.value * velX.value + velY.value * velY.value);
|
|
91
135
|
const speedBoost = 1 + speed / 20;
|
|
92
|
-
rotation.value += particle.rotationVelocity * speedBoost;
|
|
136
|
+
rotation.value += particle.rotationVelocity * speedBoost * clampedDelta;
|
|
93
137
|
|
|
94
138
|
// Canvas-confetti wobble effect (creates side-to-side flutter)
|
|
95
|
-
wobble.value += wobbleSpeed.value;
|
|
139
|
+
wobble.value += wobbleSpeed.value * clampedDelta;
|
|
96
140
|
|
|
97
141
|
// Canvas-confetti tilt animation (creates 3D tumbling effect)
|
|
98
|
-
tiltAngle.value += 0.1;
|
|
142
|
+
tiltAngle.value += 0.1 * clampedDelta;
|
|
99
143
|
tiltSin.value = Math.sin(tiltAngle.value);
|
|
100
144
|
tiltCos.value = Math.cos(tiltAngle.value);
|
|
101
145
|
random.value = Math.random() + 2;
|
|
102
146
|
|
|
103
|
-
// Update tick for progressive opacity fade
|
|
104
|
-
|
|
147
|
+
// Update tick for progressive opacity fade (time-based, not frame-based)
|
|
148
|
+
// Use elapsed time instead of frame count for frame-rate independence
|
|
149
|
+
const progress = Math.min(1, elapsed / duration);
|
|
150
|
+
tick.value = progress * totalTicks.value;
|
|
105
151
|
|
|
106
152
|
// Canvas-confetti progressive fade: opacity decreases linearly over lifetime
|
|
107
|
-
const progress = tick.value / totalTicks.value;
|
|
108
153
|
opacity.value = 1 - progress;
|
|
109
154
|
});
|
|
110
155
|
|
package/src/types.ts
CHANGED
|
@@ -93,6 +93,13 @@ export interface ConfettiConfig {
|
|
|
93
93
|
*/
|
|
94
94
|
tickDuration?: number;
|
|
95
95
|
|
|
96
|
+
/**
|
|
97
|
+
* Total ticks (frames) for the confetti animation
|
|
98
|
+
* Overrides duration when provided (60fps assumed)
|
|
99
|
+
* @default 200
|
|
100
|
+
*/
|
|
101
|
+
ticks?: number;
|
|
102
|
+
|
|
96
103
|
/**
|
|
97
104
|
* Disable physics
|
|
98
105
|
* @default false
|