https://github.com/maximcoding/react-native-firebase-app
https://github.com/maximcoding/react-native-firebase-app
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/maximcoding/react-native-firebase-app
- Owner: maximcoding
- Created: 2023-09-13T20:03:08.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-09-13T21:42:00.000Z (over 2 years ago)
- Last Synced: 2023-09-14T11:30:06.735Z (over 2 years ago)
- Language: TypeScript
- Size: 207 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# React Native Typescript Firebase
> **Note** :exclamation: This project is without [~~expo~~](https://expo.dev/).
## 💁 What's Included ?
> - [X] Latest React Native:0.72.4 :star2:
> - [x] Typescript
> - [x] [React Navigation](https://reactnavigation.org/) (@react-navigation ) - `useNavigation()` hook
> - [x] [Localization](https://react.i18next.com/) (react-i18next) - `useTranslation()`
> - [x] [Zustand](https://github.com/pmndrs/zustand) State Management - with `useState()` hook
> - [x] Firebase Authentication [@react-native-firebase/auth](https://rnfirebase.io/auth/usage)
> - [x] Firebase Realtime Database [@react-native-firebase/database](https://rnfirebase.io/auth/usage)
> - [ ] Social Authentication
> - [ ] Push Notifications
> - [ ] File Upload
> - [ ] Barcode QR Code Scanner
> - [x] [AsyncStorage](@react-native-async-storage/async-storage) - community package
> - [x] [Reactoron](https://github.com/infinitered/reactotron) - Project State Inspector
> - [ ] Vector Icons [react-native-vector-icons]() , [react-native-dynamic-vector-icons]()
> - [ ] Form Validation with [react-hook-form](react-hook-form)
> - [ ] Splash Screen
> - [ ] Theme (Colors, Palette)
> - [ ] Dark / Light Mode
> - [ ] Custom Fonts
> - [ ] AI Tools ( TensorFlow )
>
### :coffee: How to use ?
* First clone the repo
> ``git clone https://github.com/maximcoding/react-native-firebase-app.git``
##### What next ?
### For collaboration:
* Switch to new branch: ``git checkout -b myNewBranch``
* Enjoy ! :)
#### For Personal Use:
* Remove ".git" from project root folder with `rm -rf .git` (Terminal MacOS)
* Switch to new branch (recommended) ``git checkout -b rename-app``
- Rename the project ``npx react-native-rename@latest "new_name"``
- Or rename with custom Bundle Identifier ``npx react-native-rename@latest "new_name" -b "bundle_identifier"``
- Then, Rename your app ``npx react-native-rename "Travel App"``
- With custom Bundle Identifier `` npx react-native-rename "Travel App" -b "com.junedomingo.travelapp"``
```bash
# using npm
npm start
# OR using Yarn
yarn start
```
## Step 2: Start your Application
Let Metro Bundler run in its _own_ terminal. Open a _new_ terminal from the _root_ of your React Native project. Run the following command to start your _Android_ or _iOS_ app:
### For Android
```bash
# using npm
npm run android
# OR using Yarn
yarn android
```
### For iOS
```bash
# using npm
npm run ios
# OR using Yarn
yarn ios
```
If everything is set up _correctly_, you should see your new app running in your _Android Emulator_ or _iOS Simulator_ shortly provided you have set up your emulator/simulator correctly.
This is one way to run your app — you can also run it directly from within Android Studio and Xcode respectively.
## Step 3: Modifying your App
Now that you have successfully run the app, let's modify it.
1. Open `App.tsx` in your text editor of choice and edit some lines.
2. For **Android**: Press the R key twice or select **"Reload"** from the **Developer Menu** (Ctrl + M (on Window and Linux) or Cmd ⌘ + M (on macOS)) to see your changes!
For **iOS**: Hit Cmd ⌘ + R in your iOS Simulator to reload the app and see your changes!
## Congratulations! :tada:
You've successfully run and modified your React Native App. :partying_face:
### Now what?
- If you want to add this new React Native code to an existing application, check out the [Integration guide](https://reactnative.dev/docs/integration-with-existing-apps).
- If you're curious to learn more about React Native, check out the [Introduction to React Native](https://reactnative.dev/docs/getting-started).
# Troubleshooting
If you can't get this to work, see the [Troubleshooting](https://reactnative.dev/docs/troubleshooting) page.
# Learn More
To learn more about React Native, take a look at the following resources:
- [React Native Website](https://reactnative.dev) - learn more about React Native.
- [Getting Started](https://reactnative.dev/docs/environment-setup) - an **overview** of React Native and how setup your environment.
- [Learn the Basics](https://reactnative.dev/docs/getting-started) - a **guided tour** of the React Native **basics**.
- [Blog](https://reactnative.dev/blog) - read the latest official React Native **Blog** posts.
- [`@facebook/react-native`](https://github.com/facebook/react-native) - the Open Source; GitHub **repository** for React Native.
This is a new [**React Native**](https://reactnative.dev) project, bootstrapped using [`@react-native-community/cli`](https://github.com/react-native-community/cli).
# Getting Started
>**Note**: Make sure you have completed the [React Native - Environment Setup](https://reactnative.dev/docs/environment-setup) instructions till "Creating a new application" step, before proceeding.
## Step 1: Start the Metro Server
First, you will need to start **Metro**, the JavaScript _bundler_ that ships _with_ React Native.
To start Metro, run the following command from the _root_ of your React Native project:
```bash
# using npm
npm start
# OR using Yarn
yarn start
```
## Step 2: Start your Application
Let Metro Bundler run in its _own_ terminal. Open a _new_ terminal from the _root_ of your React Native project. Run the following command to start your _Android_ or _iOS_ app:
### For Android
```bash
# using npm
npm run android
# OR using Yarn
yarn android
```
### For iOS
```bash
# using npm
npm run ios
# OR using Yarn
yarn ios
```
If everything is set up _correctly_, you should see your new app running in your _Android Emulator_ or _iOS Simulator_ shortly provided you have set up your emulator/simulator correctly.
This is one way to run your app — you can also run it directly from within Android Studio and Xcode respectively.
## Step 3: Modifying your App
Now that you have successfully run the app, let's modify it.
1. Open `App.tsx` in your text editor of choice and edit some lines.
2. For **Android**: Press the R key twice or select **"Reload"** from the **Developer Menu** (Ctrl + M (on Window and Linux) or Cmd ⌘ + M (on macOS)) to see your changes!
For **iOS**: Hit Cmd ⌘ + R in your iOS Simulator to reload the app and see your changes!
## Congratulations! :tada:
You've successfully run and modified your React Native App. :partying_face:
### Now what?
- If you want to add this new React Native code to an existing application, check out the [Integration guide](https://reactnative.dev/docs/integration-with-existing-apps).
- If you're curious to learn more about React Native, check out the [Introduction to React Native](https://reactnative.dev/docs/getting-started).
# Troubleshooting
If you can't get this to work, see the [Troubleshooting](https://reactnative.dev/docs/troubleshooting) page.
# Learn More
To learn more about React Native, take a look at the following resources:
- [React Native Website](https://reactnative.dev) - learn more about React Native.
- [Getting Started](https://reactnative.dev/docs/environment-setup) - an **overview** of React Native and how setup your environment.
- [Learn the Basics](https://reactnative.dev/docs/getting-started) - a **guided tour** of the React Native **basics**.
- [Blog](https://reactnative.dev/blog) - read the latest official React Native **Blog** posts.
- [`@facebook/react-native`](https://github.com/facebook/react-native) - the Open Source; GitHub **repository** for React Native.