diff options
Diffstat (limited to 'packages/mobile/components/ui/Skeleton.tsx')
| -rw-r--r-- | packages/mobile/components/ui/Skeleton.tsx | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/packages/mobile/components/ui/Skeleton.tsx b/packages/mobile/components/ui/Skeleton.tsx new file mode 100644 index 00000000..68b22e1e --- /dev/null +++ b/packages/mobile/components/ui/Skeleton.tsx @@ -0,0 +1,38 @@ +import { useEffect, useRef } from "react"; +import { Animated, type View } from "react-native"; + +import { cn } from "@/lib/utils"; + +function Skeleton({ + className, + ...props +}: { className?: string } & React.ComponentPropsWithoutRef<typeof View>) { + const fadeAnim = useRef(new Animated.Value(0.5)).current; + + useEffect(() => { + Animated.loop( + Animated.sequence([ + Animated.timing(fadeAnim, { + toValue: 1, + duration: 1000, + useNativeDriver: true, + }), + Animated.timing(fadeAnim, { + toValue: 0.5, + duration: 1000, + useNativeDriver: true, + }), + ]), + ).start(); + }, [fadeAnim]); + + return ( + <Animated.View + className={cn("bg-muted rounded-md", className)} + style={[{ opacity: fadeAnim }]} + {...props} + /> + ); +} + +export { Skeleton }; |
