@milosptrdev/react-native-auto-skeleton
TypeScript icon, indicating that this package has built-in type declarations

0.1.16Β β€’Β PublicΒ β€’Β Published

react-native-auto-skeleton

react-native-auto-skeleton Provides automatic skeleton loading indicators based on your existing UI components, without manual configuration..

Demo

react-native-auto-skeleton demo

βœ… Platform Support

Platform Old Arch Fabric
iOS βœ… βœ…
Android βœ… βœ…

Installation

Using npm:

npm install react-native-auto-skeleton

Using yarn:

yarn add react-native-auto-skeleton

Usage

⚠️ Warning: Warning: On Android, automatic detection of a view’s border-radius is not supported. You can override it manually via the defaultRadius prop.

Here's a quick example to get started:

import { AutoSkeletonView, AutoSkeletonIgnoreView } from 'react-native-auto-skeleton';
...

<AutoSkeletonView isLoading={isLoading}>
    ...YOUR VIEWS
  <AutoSkeletonIgnoreView> // Content that will be ignored by the skeleton
    ... Views without skeleton
  </AutoSkeletonIgnoreView>
</AutoSkeletonView>

Full example

import { AutoSkeletonView } from 'react-native-auto-skeleton';

interface IProfile {
  name: string;
  jobTitle: string;
  avatar: string;
}

const getProfile = async (): Promise<IProfile> => {
  // Fetch profile data from your API
};

export default function App() {
  const [isLoading, setIsLoading] = useState(true);
  const [profile, setProfile] = useState<IProfile>({} as IProfile);

  useEffect(() => {
    (async () => {
      const res = await getProfile();
      setProfile(res);
      setIsLoading(false);
    })();
  }, []);

  return (
    <AutoSkeletonView isLoading={isLoading}>
      <View style={styles.avatarWithName}>
        <Image style={styles.avatar} source={{ uri: profile.avatar }} />
        <View style={{ flex: 1 }}>
          <Text style={styles.name}>{profile.name}</Text>
          <Text style={styles.jobTitle}>{profile.jobTitle}</Text>
        </View>
      </View>

      {/* This buttons block will have skeleton applied */}
      <View style={styles.buttons}>
        <TouchableOpacity style={styles.button}>
          <Text style={styles.buttonTitle}>Add</Text>
        </TouchableOpacity>
        <TouchableOpacity style={styles.button}>
          <Text style={styles.buttonTitle}>Delete</Text>
        </TouchableOpacity>
      </View>

      {/* Alternatively, to exclude buttons from skeleton rendering: */}
      <AutoSkeletonIgnoreView>
        <View style={styles.buttons}>...</View>
      </AutoSkeletonIgnoreView>
    </AutoSkeletonView>
  );
}

API

Prop Type Default Description
isLoading boolean β€” Enables or disables the skeleton state. When true, skeleton placeholders will be shown.
shimmerSpeed Float 1.0 Duration of one shimmer animation cycle in seconds. Lower values = faster shimmer.
shimmerBackgroundColors [string, string] [#C7C7CC, #ECECEC] Background color of skeleton shapes in hex format (e.g., #E0E0E0).
defaultRadius Float 4 Default corner radius for skeleton elements that don't have a defined borderRadius.

Best Practices

  • For rapid implementation, wrap entire UI sections with <AutoSkeletonView>.
  • For precise control, wrap individual UI components or groups separately.
  • Ensure components have clearly defined dimensions, backgrounds, or styles for optimal skeleton rendering.
  • To exclude specific components from skeleton rendering, wrap them with <AutoSkeletonIgnoreView>. Any content inside this wrapper will not be processed by the skeleton system.

License

MIT

Package Sidebar

Install

npm i @milosptrdev/react-native-auto-skeleton

Weekly Downloads

9

Version

0.1.16

License

MIT

Unpacked Size

51.7 kB

Total Files

47

Last publish

Collaborators

  • milospetrovic