Welcome to Moti
Moti is the universal animation package for React Native, made by Fernando Rojo.
#
Highlights- Universal: works on all platforms
- 60 FPS animations run on the native thread
- Mount/unmount animations, like Framer Motion
- Powered by Reanimated 3
- Intuitive API
- Variant & keyframe animations
- Strong TypeScript support
- Highly-configurable animations
- Sequence animations
- Loop & repeat animations
- Web support
- Expo support
- Next.js support
#
Motivation#
Write once, animate anywhere.First and foremost, I made Moti because I need animations and transitions that work well on both websites & native apps.
In my opinion, React Native has the best mental model for building products. But when it comes to designing a multi-platform product at scale, you end up using Platform.select
all over the place. I consider this an anti-pattern.
If you find yourself writing Platform.OS === 'web'
when building UI inside of your app, something is wrong. Platform inconsistencies should be handled by third-party libraries that provide a centralized API. That's what makes (the ideal behind) React Native's mental model so great: write once, run anywhere.
I've spent most of my open source time on such inconsistencies. For example, Dripsy encourages you to design products based on screen size, not platform.
After months of trying different animation solutions on web and native, I decided I should make my own. Then Reanimated released v2 with a hooks API, and suddenly it all made sense. What we need is a performant animation library that lets us use component props to define different animation states. Hooks shouldn't be necessary. Styles should automatically transition the way CSS transitions do.
Adding an animation should be as easy as adding a background color. It should feel like play.
I started abstracting Reanimated's hooks into a single component. Pass it plain style objects, and it does the work for you. It feels like magic, and the animations are slick.
I've used Framer Motion, React Native Animatable, React Spring, CSS transitions / keyframes throughout the years, and I wanted to combine the best of these approaches into one.
The funny part of all of this is, React web already has great solutions for animations. And yet, I'm spending my time building a solution for React Native, and then making sure it also works on web. It may seem a bit odd and circular.
#
A final thoughtThe fact that React Native works on all platforms is great. But it's more of a consequence of its greatness than the greatness itself. What makes React Native so interesting as a technology is that it's so intuitive. Its simplicity lets you focus on the only thing that really matters: building great products, quickly. Thanks to its intuitive mental model, React Native lends itself to use on any platform.
With React Native, we have an instrument to turn ideas into great user experiences, without getting bogged down by the concept of "what platform someone is using."
Today, it might be an iPhone.
Tomorrow, it might be a virtual browser running on a cloud server.
If we get this right, it won't matter.
#
BackgroundIf you want to learn more about the motivations behind the creation of moti
, you can read this GitHub issue that I created on Dripsy.
These tweets also preview some of the features:
#
AuthorMoti was created by Fernando Rojo. Follow me on Twitter to stay up to date.
Also, please star the repo on Github.
#
VideosThere are a number of videos on the videos page.
#
Contributing to React NativeIf you're wondering how you can contribute to the React Native community, I encourage you to create packages that solve platform inconsistences. Help us give people a delightful user experience, regardless of what "device" they're using.
#
ThanksIt's hard to name all the people I should credit for Moti. There are the obvious ones, like Software Mansion and the Expo team, who do the hard work that makes a library like this easy to build. Everyone who contributes to Reanimated has been really helpful.
Then there are the people behind great projects Framer Motion and React Spring, who gave me both guidance and inspiration on the best APIs to use.
Chadwick Maycumber has been especially helpful making Moti and Dripsy happen.
Matt Perry helped me integrate AnimatePresence
, giving Moti a huge boost.
Terry Sahaidak offered useful ideas for integrating a performant API.