0.6.0 • Published 6 months ago

react-native-theme-switch-animation v0.6.0

Weekly downloads
-
License
MIT
Repository
github
Last release
6 months ago

react-native-theme-switch-animation

A Plug & Play Animations for Switching (Dark/Light) themes. 🌗

🦄 Features

  • ✅ Supports multiple animation types.
  • ✅ Blazing fast - 60/120fps
  • ✅ Plug and Play, doesn't matter what you use for switching themes
  • ✅ Can be used for different theme colors, not necessarily for dark/light
  • ✅ Supports turbo modules for new architecture

Installation

npm install react-native-theme-switch-animation

OR

yarn add react-native-theme-switch-animation

Link

(if you are using expo managed project, do a prebuild - npx expo prebuild)

npx pod-install

For React Native Versions 0.67 and Below

Usage

import switchTheme from 'react-native-theme-switch-animation';

export default function Example() {
  const [theme, setTheme] = React.useState('light');

  return (
    <Button
      title="Switch Theme"
      onPress={() => {

        switchTheme({
          switchThemeFunction: () => {
            setTheme(theme === 'light' ? 'dark' : 'light'); // your switch theme function
          },
          animationConfig: {
            type: 'fade',
            duration: 900,
          },
        });

      }}
    />
  );
}

Circular Example

switchTheme({
  switchThemeFunction: () => {
    setTheme(theme === 'light' ? 'dark' : 'light'); // your switch theme function
  },
  animationConfig: {
    type: 'circular',
    duration: 900,
    startingPoint: {
      cxRatio: 0.5,
      cyRatio: 0.5
    }
  },
});

switchTheme Function Props

NameTypeDescription
switchThemeFunction() => voidAdds the function you use in your app to switch themes, doesn't matter if you use redux/context/zustand/mobx or any other way
animationConfigAnimationConfigConfiguration for the animation -> type, duration, starting point (default is 'fade' with 500ms duration)

animationConfig options

NameTypeDescription
typefade circular inverted-circularSpecifies animation type
durationnumberSpecifies duration in milliseconds
startingPointStartingPointConfigConfiguration for the circular animation, where does the animation start in the screen

startingPoint options

NameTypeDescription
cxnumberSpecifies starting x point for circular and inverted-circular animation (should not exceed your screen width)
cynumberSpecifies starting y point for circular and inverted-circular animation (should not exceed your screen height)
cxRationumberSpecifies starting percentage of x point for circular and inverted-circular animation (should be number between -1 and 1)
cyRationumberSpecifies starting percentage of y point for circular and inverted-circular animation (should be number between -1 and 1)

Start Circular Animation from/to speceific Button

If you would like the circular animation to start from/to a button/view on your ui automatically, you can do the following

import switchTheme from 'react-native-theme-switch-animation';

<TouchableOpacity
  onPress={(e) => {
    e.currentTarget.measure((x1, y1, width, height, px, py) => {
      switchTheme({
        switchThemeFunction: () => {
          setTheme(theme === 'light' ? 'dark' : 'light');
        },
        animationConfig: {
          type: 'circular',
          duration: 900,
          startingPoint: {
            cy: py + height / 2,
            cx: px + width / 2,
          }
        },
      });
    });
  }}
/>

Trouble shooting

iOS Artifact for some components with border

https://github.com/WadhahEssam/react-native-theme-switch-animation/assets/24798045/8ad14c41-8757-4c21-b7e7-bf47b23e7f8b

this can be solved by adding a borderRadius of any value more than 1.2 for the component

<View
  style={{
    borderWidth: 1,
    borderColor: theme === 'light' ? 'black' : 'white',
    borderRadius: 1.2, // -> Add This
    padding: 20,
    marginBottom: 20,
  }}
>
  <Text
    style={{
      color: theme === 'light' ? 'black' : 'white',
    }}
  >
    test
  </Text>
</View>

License

MIT

0.6.0

6 months ago

0.5.2

6 months ago

0.5.1

6 months ago

0.5.0

6 months ago

0.4.1

6 months ago

0.4.0

6 months ago

0.3.0

6 months ago

0.2.7

6 months ago