Libraries (Which and why)
Expo : It seems like upgrading and shipping the app with expo is quite easy. Expo SDK is also very mature and could help. We are no longer restricted to expo go, which restricts the usage of native api's, now we can create our own custom development client app.
Tailwind (nativewind): It's for the use of tailwind css for styling our UI components. Tailwind CSS provide predefined classes to be used with our components in an easy and readable format.
React-hook-forms: Provides for components to write forms and help manage state quite easily. Also provides integration with zod, for form validation.
zod: zod is a validation library which allows for declarative syntax for the same.
Flashlist: Although react native provides faltlist, it is not well optimized for mobile devices and is known to reduce performance and consume a lot of power.
Flashlist are more memory efficient, has higher performance hence lower loading times, consumes much less power, provide the creation of complex layouts, has consistent performance across android and IOS.
React-query : React quesary helps in fetching and putting data on the server. It helps in the following ways:
Caching - It caches the data it has fetched once and only changes the UI when the data is actually changed.
retrying- When fetching failed it automatically retries.
and deduplicating - if the same request is made more than once, instead of making new request it uses the cache directly.
useQuerry - the hook it gives to fetch the data as and when needed.
useMutation - the hook it gives to put data on server.
infinite query hook - Helps in writing infinite scrolling content.
optimistic updates - If data is written to the server it allows to be reflected in ui directly without fetching from the server again quite easily
integrated dev tools - helps in debugging the data fetched from the server.