Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updates README, jdk+node version and setup steps for android and iOS #461

Closed
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
201 changes: 131 additions & 70 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,107 +1,168 @@
## Real Dev Squad Mobile App
# Real Dev Squad Mobile App

Welcome to the repository of our mobile app, which mirrors all the features of our web applications.
## Tech Stack

* React Native
* TypeScript
* StyleSheet
## About the Project
## 📱 Tech Stack

This project serves as the Real Dev Squad cross-platform mobile app, built using React Native.
## First Phase
- React Native
- TypeScript
- StyleSheet

- Github Authentication ✅ (we did it via webview, requirement has changed to browser login from github)
- QR code Scanner Authentication ✅
- Three Screens - Home and Profile ✅
- Home screen Features ✅
- Feature with switching from I am idle to doing task ✅
- Feature with switching from out of office from back again ✅
- Profile Screen in which we can change our profile through our phone’s gallery ✅
- API integration in Profile Screen ✅
## 📖 About the Project

## Second Phase
- Three Screens - Home , Goals and Profile ✅
- Home screen Features ✅
- Goals site Tab
- Goals site feature will have the TODO app where you can assign the task to the member of the RDS.
This project serves as the Real Dev Squad cross-platform mobile app, built using React Native. It aims to provide a seamless experience for our users by replicating the features of our web application.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

not just replicating the web features, it will have other features as well.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What should I add there?

Copy link
Contributor Author

@Ayushsanjdev Ayushsanjdev Oct 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Any suggestions @shreya-mishra @ashifkhn

Feel free to download our RDS app by clicking on ➡️ [RDS App](https://drive.google.com/file/d/1aEv941izi5bOJzttZj22EKl47jTnsYy_/view?usp=sharing)
## 🚀 Features

**Note** : Please delete the previous RDS app build if you have.
### First Phase

- **Github Authentication** ✅ (originally done via WebView, now moved to browser login for GitHub)
- **QR Code Scanner Authentication** ✅
- **Three Screens:** Home and Profile ✅
- **Home Screen Features** ✅
- **Status Switch:** Switch between “I am idle” to “Doing task” ✅
- **Availability Toggle:** Switch between “Out of Office” and “Back Again” ✅
- **Profile Screen:** Modify profile details using your phone’s gallery ✅
- **API Integration in Profile Screen** ✅

## Prerequisites
### Second Phase

- **Three Screens:** Home, Goals, and Profile ✅
- **Home Screen Features** ✅
- **Goals Tab:** Displays the TODO app where you can assign tasks to the members of the Real Dev Squad.

To contribute, make sure you have the following:
Comment on lines +17 to 33
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can remove this from the readme file. Could you take other's opinions as well?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense, sure

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@ashifkhn what are your thoughts on this?

Feel free to download the RDS app by clicking ➡️ [RDS App](https://drive.google.com/file/d/1aEv941izi5bOJzttZj22EKl47jTnsYy_/view?usp=sharing).

- React Native setup
- Android Studio
- JDK ( openjdk 11.0.20.1 2023-08-24 )
- Node setup ( use version v16.*, tested on v16.20.2)
- [Volta](https://docs.volta.sh/guide/getting-started) | [Why Volta?](https://docs.volta.sh/guide/#why-volta)
- React Native development environment set up
- Android Studio installed
- Node.js installed
- for Node version management: [Volta](https://docs.volta.sh/guide/getting-started) | [Why Volta?](https://docs.volta.sh/guide/#why-volta)

# **NOTE** : Make sure to set up the proper development environment required to run Hello world app in RN and drop a video link in #react-native channel.

For detailed setup instructions, refer to [React Native environment setup guide](https://reactnative.dev/docs/environment-setup).
**Note**: Please delete the previous RDS app build if you have it installed.

### Local App setup
## 🛠 Prerequisites

- Set up your local environment for React Native following the environment setup guide.
- Clone the mobile app repository: git clone https://github.com/Real-Dev-Squad/mobile-app.git
- Run the command: `yarn`
- Start contributing!
Before you start contributing, ensure you have the following:

## Contribution Guide
- React Native setup
- Android Studio
- JDK (openjdk "17.0.12" 2024-07-16)
- Node.js setup (use version above v18.8; tested on v20.18)
- [Volta](https://docs.volta.sh/guide/getting-started) for Node version management | [Why Volta?](https://docs.volta.sh/guide/#why-volta)
- For detailed setup instructions, refer to the [React Native environment setup guide](https://reactnative.dev/docs/environment-setup).

**Note:** Ensure that your React Native development environment is set up correctly to run the Hello World app in RN. Share a video link of your setup in the #react-native channel on Discord.

## ⚙️ Local App Setup

To get started with the development setup:

1. **Clone the Repository**
```
git clone https://github.com/Real-Dev-Squad/mobile-app.git
```
2. **Navigate to the Project Directory**
```
cd mobile-app
```
3. **Install Dependencies**
```
yarn
```
4. **Start the Application**
```
yarn start
```

## 📲 Running the App on Android

### Step-by-Step Setup for Android:

1. **Start the Development Server**
- Open your terminal in the project directory and run:
```
yarn start
```
2. **Open Android Studio**
- Open Android Studio and ensure you have a virtual device (emulator) configured.
- If not, go to **AVD Manager** and create a new virtual device.
3. **Launch the Android Emulator**
- Start the emulator from Android Studio or connect a physical device via USB (ensure USB debugging is enabled on your device).
4. **Install the App on the Emulator/Device**
- Go back to the terminal and press:
```
a
```
- This will automatically build and install the app on the connected device/emulator.
5. **Manual Installation (if step 4 fails)**
- Open Android Studio, navigate to `android` folder inside your project.
- Click on **Build** > **Build Bundle(s) / APK(s)** > **Build APK**.
- After the build completes, install the APK on your device manually.

### Troubleshooting:

- If you encounter errors related to build tools or environment configurations, ensure that your Android SDK is up-to-date.
- If you have issues with device/emulator connectivity, restart ADB using:
```
adb kill-server
adb start-server
```

## 📲 Running the App on iOS

### Step-by-Step Setup for iOS:

1. **Start the Development Server**
- Open your terminal in the project directory and run:
```
yarn start
```
2. **Open Xcode**
- Navigate to the `ios` folder inside your project.
- Open the `.xcworkspace` file in Xcode.
3. **Select a Simulator**
- Choose an iOS simulator from the top bar of Xcode (e.g., iPhone 14).
4. **Install the App on the Simulator**
- Press the `Run` button in Xcode (or use the shortcut `Cmd + R`).
5. **Install on a Physical Device**
- Connect your iPhone via USB.
- In Xcode, select your device as the target and ensure the app is signed correctly using your Apple Developer account.
- Click `Run` to install the app on your iPhone.

### Troubleshooting:

- If you encounter errors related to pods or library installations, run the following commands inside the `ios` folder:
```
cd ios
pod install
cd ..
```
- If Xcode shows a signing error, ensure your app’s bundle identifier is unique and configured correctly.

## 📝 Contribution Guide

To contribute to our project:

- Browse the issues and comment on the one you'd like to work on.
- Once an issue is assigned to you, follow the local app setup steps.
- Before pushing code, ensure it runs without errors.
- Run yarn run `precommit-check`.
- Commit your changes with a descriptive message.
- Push your code to your branch.
- If you need assistance, reach out on the mobile-app-react-native channel on Discord.
1. Browse the issues and comment on the one you'd like to work on.
2. Once an issue is assigned to you, follow the local app setup steps.
3. Ensure that your code runs without errors before pushing changes.
4. Run `yarn run precommit-check` to validate your changes.
5. Commit your changes with a descriptive message and push your code to your branch.


## Git commands for local setup
### Git Commands for Local Setup

```
git clone https://github.com/Real-Dev-Squad/mobile-app.git

cd mobile-app

yarn
```

### Git Commands to Commit Your Code

## Git commands to commit your code:
```
git checkout -b 'your-PR-name'

git add <files>

git commit -m "Your commit message"

git push origin your-PR-name

```

## 🧪 Test-Driven Development (TDD)

## Test-Driven Development (TDD)

All PRs should have 100% test coverage. Before submitting PRs, run yarn test to ensure all tests pass.

**Running/Development**

- Start Metro (JavaScript bundler): `yarn react-native start`
- For Android: `yarn react-native run-android`
- For iOS: yarn `react-native run-ios`
All PRs should have 100% test coverage. Before submitting PRs, run `yarn test` to ensure all tests pass.

If the above commands fail, try building the Android app from Android Studio and the iOS app from Xcode.
If you need assistance at any point, feel free to reach out on the `#mobile-app-react-native` channel on Discord. Happy contributing! 😊
Binary file added image.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@
]
},
"volta": {
"node": "18.0.0",
"node": "20.18.0",
"yarn": "1.22.19"
},
"engines": {
Expand Down
Loading