Sistema Toronto provides musical and intellectual opportunities to children in vulnerable communities, with the goal of transformative social change. They build stronger communities by enabling children from marginalized neighbourhoods to overcome poverty, grow, and thrive as engaged citizens and future leaders. They are collaborating with us this year to create a mobile application that will help with their mission.
You can learn more about their organization here: https://www.sistema-toronto.ca/
The wiki has a lot of relevant information related to branching, PRs, etc that you should review!
- Sistema
- Table of Contents
- Commmiting and Pushing
- Setup Local Environment (Mac)
- Setup Local Environment (Windows)
- Setup Local Environment (Linux)
- Setting up Simulators/Virtual Devices
- Android
- Troubleshooting
- Contributors
This repository uses commitizen (commit message generator) and Husky (lints and runs scripts triggered by git hooks).
- Add your changed files with
git add
as usual or through your IDE shortcut. - To commit, run
yarn run cm
orgit cz
ornpx cz
to start commitizen and generate a standardized commit message. - To push, run
git push
as usual or through your IDE shortcut.
We use Husky to lint code and run other checks when you push. To bypass hooks:
You can bypass pre-commit
and commit-msg
hooks using Git -n/--no-verify
option:
git commit -m "yolo!" --no-verify
For Git commands that don't have a --no-verify
option, you can use HUSKY
environment variable:
HUSKY=0 git push # yolo!
Prerequisites:
Ensure you have the following prerequisites before trying to run the project locally:
- Node.js and npm (https://nodejs.org/en/download/). Alternatively, check if you have this by using command
node -v
in your terminal console. It is recommended to install Node.js using Homebrew via thebrew install node
command. - For Mac, make sure you install Watchman for file management:
brew install watchman
- Install Yarn, the package manager we'll be using for our project:
npm install --global yarn
- You will need an iOS simulator and an Android simulator. Details to follow!
Setup:
- Install Xcode. If your macOS version is too old to install the latest version, you can browse this link to find a version that works for you, as long as it's 10 or newer.
- You'll need Ruby version 2.7.5 for iOS development. Use command
ruby --version
to check what version you're currently on. Follow the installation instructions for rbenv—this manages your Ruby version for different projects. Install the correct version:rbenv install 2.7.5
. Restart your terminal console. - Install the Command Line Tools for Xcode by opening Xcode, then following Xcode > Preferences... > Locations > Command Line Tools. Choose the latest version.
- Install your iOS simulator by following Xcode > Preferences... > Components. Choose the simulator with the latest iOS.
- Okay, now we're going to install the Android simulator. Download and install Android Studio. While going through the installation wizard, make sure "Android SDK", "Android SDK Platform", and "Android Virtual Device" are all checked.
- Install the Azul Zulu OpenJDK distribution:
brew tap homebrew/cask-versions
andbrew install --cask zulu11
. - Install the Android SDK via your fresh Android Studio app. Open it up, and select "More Actions" > "SDK Manager". From here, select the "SDK Platforms" tab, then check the box next to "Show Package Details" in the bottom right corner. Expand the "Android 12.0 (S)" entry, and check the following:
Android SDK Platform 31
andGoogle APIs Intel x86 Atom System Image
(for Intel Macs) ORGoogle APIs ARM 64 v8a System Image
(for M1 Macs). - Then, select the "SDK Tools" tab and check the box next to "Show Package Details" here as well. Expand the "Android SDK Build-Tools" entry, then select "31.0.0". Hit Apply. You're good to go!
- Configure the ANDROID_SDK_ROOT environment variable by adding the following lines to your $HOME/.bashprofile if you use bash or your ~/.zprofile if you use zsh:\
export ANDROID_SDK_ROOT=$HOME/Library/Android/sdk export PATH=$PATH:$ANDROID_SDK_ROOT/emulator export PATH=$PATH:$ANDROID_SDK_ROOT/platform-tools
- Type
source $HOME/.zprofile
orsource $HOME/.bashprofile
to load the config. - Go back into Android Studio, and see this link to set up your Android Simulator. Alternatively, if you have an Android phone, you can connect it via USB to your computer with the phone set on debugging mode in the developer options, and it'll build the app directly on your phone.
- Clone this repository into your local directory of choice using
git clone https://github.com/uoftblueprint/sistema.git
- cd into folder sistema
cd ./sistema
- Run
yarn --frozen-lockfile
- If using Mac, run
rbenv local 2.7.5
- Run
bundle install
- cd into
cd ios
, then install podspod install
- Run
- cd back out to sistema folder
cd ..
- Start the React Native server (Metro) by running
yarn run start
. Make sure this process is complete and error-free before proceeding to the next step. - Navigate to Setting up Simulators/Virtual Devices and follow the steps. You can either start your simulator and run the build inside Android Studio/XCode, or you can do the follow steps from the root directory:
- Start the Android simulator by running
yarn run android
. Make sure your Android simulator is all set up in Android Studio! - Start the iOS simulator by running
yarn run ios
. Make sure your iOS simulator is all set up in Xcode! - The simulators should open automatically and you should see the current working version of the Sistema app.
Unfortunately, you will have to install a virtual machine to run the iOS simulator. Since this is an incredibly long, painful, and potentially unfruitful process, we don't want to inflict this on you—so let's just install the Android simulator for now. Do what works for you!
Prerequisites:
- Node
- React Native CLI
- a JDK
- Android Studio
Setup:
- Follow this setup tutorial to download necessary prerequisites up until and including the "React Native Command Line Interface" header, then stop there. Even if you have the prerequisites downloaded, make sure the versions are correct.
- From the root folder of the sistema project, run
yarn --frozen-lockfile
to install packages. - Set up the Android simulator. Skip to Setting up Simulators/Virtual Devices and follow the Android section. Once that's set up, you're ready to run your app!
Open Android Studio and start your virtual device. Run yarn run android:start
. Give a few minutes for Metro to start, Gradle to build, and the simulator to load.
What's Metro? Metro is the JavaScript bundler that ships with React Native. Metro "takes in an entry file and various options, and returns a single JavaScript file that includes all your code and its dependencies."—Metro Docs. To start Metro without Android, run yarn run android:metro
inside the root folder.
To start Android studio and the emulator without your app, run yarn run android:studio
.
Again, we'll need a Mac to enable native development for iOS. Follow this tutorial to install MacOS. If you choose to only develop for Android, the Linux setup process for Android is essentially the same as that of Mac; however, since you don't have access to Homebrew, the Node, JDK, and Watchman installations will look a little different. Just make sure to download the correct version for your Linux distribution.
- Open
./sistema/android
inside Android Studio. If it's your first time opening up the project, Android Studio will automatically start the build. Make sure the gradle build is successful. Check Troubleshooting for common errors. - Next, we're going to create the AVD (Android Virtual Device). Click on Device Manager in the top right tool bar (next to gradle build). If you have recently installed Android Studio, you will likely need to create a new AVD. Select Virtual > Create Device.
- Pick the Pixel 6 Pro or any other modern phone and from the list and click "Next". Then select the system image: x86 Images > S (API Level = 31, Target = Android 12.0). Click "Next" then "Finish" to create your AVD.
- At this point you should be able to click on the green triangle button next to your AVD to launch it. It might take a few minutes for the Emulator to start.
- Run your React Native app.
- Once you have your simulator downloaded via the Preferences menu in Xcode, you can directly build and run your app by running
yarn run ios:start
from the root directory of your project.
Error: When you try to run your build on your Android simulator, and the simulator returns an error 500.
Solution: It's possible that it's a port problem. Try running this command in your terminal:
adb reverse tcp:8081 tcp:8082
Error:
Settings file 'C:\%LOCALPATH%\sistema\android\settings.gradle' line: 2
A problem occurred evaluating settings 'sistema'.
> Could not read script 'C:\Users\%LOCALPATH%\sistema\packages\mobile\node_modules\@react-native-community\cli-platform-android\native_modules.gradle' as it does not exist.
Solution:
yarn add @react-native-community/cli-platform-android
Error:
info Starting the app...
'adb' is not recognized as an internal or external command,
operable program or batch file.
error Failed to start the app.
Error: Command failed: adb shell am start -n com.sistema/com.sistema.MainActivity
Solution (Windows only):
- Type in "env" in your Windows search bar. System Properties > Environment Variables. Make sure that
%LOCALAPPDATA%\Android\Sdk\platform-tools
is in your PATH system variables. Replace "%LOCALAPPDATA%" with your local app data path. - Open a new terminal and confirm with the
$Env:Path
command that platform-tools is in the variable. You might have to restart your IDE.
Error:
error Failed to install the app. Make sure you have the Android development environment set up: https://reactnative.dev/docs/environment-setup.
Error: Command failed: gradlew.bat app:installDebug -PreactNativeDevServerPort=8081
Unable to install C:\%LOCALAPPDATA%\sistema\android\app\build\outputs\apk\debug\app-debug.apk
com.android.ddmlib.InstallException: Unknown failure: cmd: Can't find service: package
Solution:
Open Android Studio > Device Manager. Run "Cold Boot Now" on the specific emulator to get it back up.
Error:
TypeError: Cannot read property 'now' of undefined
...
I/HermesVM: JSI rethrowing JS exception: Cannot read property 'now' of undefined
...
E/unknown:ReactNative: Exception in native call
java.lang.RuntimeException: Attempting to call JS function on a bad application bundle: HMRClient.setup()
...
E/unknown:DeviceInfo: Unhandled SoftException
com.facebook.react.bridge.ReactNoCrashSoftException: No active CatalystInstance, cannot emitUpdateDimensionsEvent
Solution: From the root folder:
cd ./android/
./gradlew clean
Error: When pushing, git tells you the following:
hint: The '.husky/pre-commit' hook was ignored because it's not set as executable.
hint: You can disable this warning with git config advice.ignoredHook false.
Solution: From the root folder:
chmod ug+x .husky/*
chmod ug+x .git/hooks/*
- Emily Yu
- Ramy Zhang
- Azamat Khamidov
- Baker Jackson
- Harmit Goswami
- Helena Glowacki
- Kurtis Law
- Min Gi
- Sarah Xu