Home

Awesome

React Native (React Query) Toolkit Start App <!-- omit in toc -->

A React Native boilerplate app to bootstrap your next app with React-Query!

🔥🔥🔥 Upgraded to the latest React-Native (> 0.69.x) with brand New Architecture (Fabric) 🔥🔥🔥

<br/> <div align="center"> <img src="./react-native-starter-kit.png" width="100%" /> </div>

License<!-- ALL-CONTRIBUTORS-BADGE:START - Do not remove or modify this section --> All Contributors

<!-- ALL-CONTRIBUTORS-BADGE:END -->

Issues

<img src="https://img.icons8.com/color/48/000000/travis-ci.png" width="30px" /> Build

Build Build

<a href="https://www.buymeacoffee.com/IronTony" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/lato-blue.png" alt="Buy Me A Coffee" width="217px" /></a>

Table of Contents <!-- omit in toc -->


Installation :inbox_tray:

# Setup your project
> npx degit IronTony/react-native-react-query-starter-app your-new-app

> cd your-new-app

# Install dependencies
> yarn

# if needed, setup iOS development environment
yarn setup:ios

See environment section for how to configure env variables.

See scripts section for how to run the app.


Rename project and bundles :memo: :package:

To rename the project and bundles, just follow these steps:

iOS & Android

Run npx react-native-rename [name] -b [bundle-identifier] from the project root

Example: npx react-native-rename "Test New App" -b com.testnewapp


Environment Setup :globe_with_meridians:

React Native Starter App environments variables management is based on a custom script and the app.json config file.

Define your environment variables inside app.json inside the environments object under the desired environment key (such as development, staging or production) and then run the app for the required env using one of the available run scripts (e.g. ios:dev).

If you want to use IDEs such Xcode or Android Studio, you have to set up the ENV variables with these commands:


Scripts :wrench:

Run the app

To run the app use one of the following scripts:

Generate app icons

To setup the app icons:

yarn assets:icons

Generate Splashscreen

To setup the app splashscreen:

yarn assets:splashscreen

To enabled React-Native (Fabric) new architecture

Check the official documentation here

Setup iOS

To setup the environment to run on iOS, run

yarn setup:ios

this will run cocoapods to install all the required dependencies.

Typescript (optional)

The use of Typescript in the project is not mandatory. You can just write all your code using plain Javascript. Our hint is to create all files as below:

To enable full Typescript checks, just open the tsconfig.json file and chage as below:<br/>

"noImplicitAny": true, // set to true to be explicit and declare all types now<br/>
"strict": true,  // enable it to use fully Typescript set of invasive rules<br/>

REMEMBER: the entry point file in the root of the project MUST be index.js


Roadmap :running:

✅ Initial Setup<br/> ✅ Splashscreen (https://github.com/crazycodeboy/react-native-splash-screen)<br/> ✅ Toolbox (https://github.com/panz3r/react-native-toolbox)<br/> ✅ Standard tree folders structure<br/>React-Native 0.69 (new architecture)<br/>React-query<br/>React-query Custom hooks (eg. GET, POST, PUT, PATCH, DELETE)<br/>React Native Flipper Integration<br/>i18next<br/>React-navigation v6 ❤️<br/>Nativebase v3 as design system<br />Env variables selection experimental way ⚗️⚗️⚗️<br /> ✅ Typescript (optional use. Read the DOC above)<br />


Screenshots

<div align="center"> <img src="./screenshots/screenshot1.png" width="50%" /> </div> <div align="center"> <img src="./screenshots/screenshot2.png" width="50%" /> </div> <div align="center"> <img src="./screenshots/screenshot3.png" width="50%" /> </div>

Contributors :sparkles:

Thanks goes to these wonderful people (emoji key):

<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> <!-- prettier-ignore-start --> <!-- markdownlint-disable --> <table> <tr> <td align="center"><a href="https://github.com/IronTony"><img src="https://avatars3.githubusercontent.com/u/3645225?v=4" width="100px;" alt=""/><br /><sub><b>IronTony</b></sub></a><br /><a href="#ideas-IronTony" title="Ideas, Planning, & Feedback">🤔</a> <a href="https://github.com/IronTony/react-native-react-query-starter-app/commits?author=IronTony" title="Code">💻</a> <a href="https://github.com/IronTony/react-native-react-query-starter-app/commits?author=IronTony" title="Documentation">📖</a> <a href="https://github.com/IronTony/react-native-react-query-starter-app/issues?q=author%3AIronTony" title="Bug reports">🐛</a> <a href="#maintenance-IronTony" title="Maintenance">🚧</a> <a href="#platform-IronTony" title="Packaging/porting to new platform">📦</a> <a href="#question-IronTony" title="Answering Questions">💬</a> <a href="https://github.com/IronTony/react-native-react-query-starter-app/pulls?q=is%3Apr+reviewed-by%3AIronTony" title="Reviewed Pull Requests">👀</a> <a href="https://github.com/IronTony/react-native-react-query-starter-app/commits?author=IronTony" title="Tests">⚠️</a> <a href="#example-IronTony" title="Examples">💡</a></td> <td align="center"><a href="http://panz3r.dev"><img src="https://avatars3.githubusercontent.com/u/1754457?v=4" width="100px;" alt=""/><br /><sub><b>Mattia Panzeri</b></sub></a><br /><a href="#ideas-panz3r" title="Ideas, Planning, & Feedback">🤔</a></td> </tr> </table> <!-- markdownlint-enable --> <!-- prettier-ignore-end --> <!-- ALL-CONTRIBUTORS-LIST:END -->

This project follows the all-contributors specification. Contributions of any kind welcome!


License :scroll:

Licensed under Mozilla Public License Version 2.0