This project is a mobile application for nonprofit organization Psyches of Color, to raise mental health awareness and provide support for Black and Latinx communities. The app is built with a React Native with a Node/Express backend, connected to a MongoDB database.
This section describes how to get started with development work, including some set up steps and important project information.
Refer to the development resources doc for help with these tools.
- Git
- Text Editor (VS Code, Notepad, Vim, etc.)
- Node.js and NPM
- MongoDB
- Prettier VS Code extension to auto-format code (recommended)
- Postman to design/test API's (recommended)
Before running the project, you must configure environment variables for the frontend and backend. Environment variables contain information that may be different between different developers and development vs. production environments, and/or may be sensitive information we don't want to put in our public GitHub repos (e.g. Firebase keys, email account password).
There is a .env.example
file in both the frontend and backend directories - note that these files are different. They contain a list of the environment variables you need to configure, and is currently populated with dummy values. The actual values are stored in our Google Drive folder (TODO: put path to where env variables are stored). You can download the files and place them in the appropriate directory depending on if if is for frontend or backend, and then rename to just .env
. The renaming is key because the code looks for a file named .env
.
IMPORTANT: make sure you do NOT remove anything from .gitignore
. The .gitignore
file tells git to not track files that we don't want to push to the repo. This includes .env
, as pushing .env
to the repo would cause security issues.
- Psyches-Of-Color-App
- backend
- .env
- ...other files/directories
- frontend
- .env
- ...other files/directories
- ...other files/directories
- backend
This section describes various CLI commands to run parts of the project, such as the backend, frontend, linting, etc. In general, you will be running the backend and frontend together from two separate terminal windows while developing/testing. All of these commands assume that you are currently in the root directory of the project.
cd backend
to enter the backend directorynpm install
to install any dependencies (i.e. node_modules)npm run start
to run the backend
cd frontend
to enter the frontend directorynpm install
to install any dependencies- There are two options to run the frontend
npm run start
to run on Expo Go, which you can think of as compiling and running the code.npm run ios
ornpm run android
to create a build and run on a simulator. This is necessary for anything requiring custom native code, including libraries such as React Native Firebase.
Upon running the frontend (with npm run start
), you should see a screen with a QR code and a few keyboard options below. You can scan the QR code on your phone to see the app there, or use keyboard options to open Android, iOS, the debugger, etc.
Note: You may have to run npm run [ios/android]
if facing errors after making changes, even to use npm run start
. This will regenerate the build (stored in the /ios
and /android
folders).
This project has ESLint and Prettier set up to run linting and code formatting, respectively, whenever you run git commit
. All of the following scripts are available for both the frontend and backend. Make sure to cd
into either the frontend or backend directory, depending on which you are linting.
npm run lint-check
runs lint checks on your codenpm run lint-fix
fixes any automatically fixable lint errorsnpm run format
runs code formatting checks and fixes any formatting errors
TODO