Any fitness goal is closely tied to the food you consume, so why should you have separate apps for tracking your progress in the gym and in the kitchen? The State of Health Tracking app offers an all-encompassing solution for tracking your macros and workouts.
At State of Health, we strive to simplify fitness. Our app is devoid of unnecessary features and is exceptionally user-friendly. It includes progressive overload tracking to ensure you add more reps or weight with each workout. Moreover, our app is seamlessly integrated with the USDA food database, enabling you to easily search for nearly any food item containing a label within the United States.
Our tracking app is loaded with comprehensive graphs, and charts to make sure you are on track every day to hit your goals. Each day you log a workout or meal, a diary entry will automatically be created for you to keep track of your progress.
This app assumes you are using Expo EAS and have a registered Apple Developer account.
To setup use with firebase:
- Create an iOS app in the Firebase console.
- Generate GoogleService-Info.plist file from Firebase.
- Generate an OAuth 2.0 Token and add to the GoogleServices-Info.plist file: https://developers.google.com/identity/protocols/oauth2#1.-obtain-oauth-2.0-credentials-from-the-dynamic_data.setvar.console_name-.
- Add GoogleService-Info.plist to root dir of project.
- copy
.env.dist
and paste it as.env
- Generate API Key for USDA API here: https://fdc.nal.usda.gov/api-key-signup.html or request key from project maintainer.
- Update
USDA_FOOD_API_KEY=
in the .env file with your API Key.
EAS builds will ignore files found in .gitignore. Because of this, you must remove .GoogleService-Info.plist
from the .gitignore to upload a build with EAS. Failing to do so will result in a failed build.
Run an iOS dev build on a simulator:
- Make sure all node modules are installed
npm i
- Open a simulator from XCode.
- Run
npm run ios
Run an iOS dev build on a physical device:
- Create a native build in EAS. Run
npm run build-ios-dev
to upload a dev build to EAS. - Run Expo
npm run start
To debug crashlytics on a dev build, add a firebase.json file with the following to the root dir of the project:
{
"react-native": {
"crashlytics_debug_enabled": true,
"crashlytics_disable_auto_disabler": true,
"crashlytics_auto_collection_enabled": true,
"crashlytics_is_error_generation_on_js_crash_enabled": true,
"crashlytics_javascript_exception_handler_chaining_enabled": true
}
}
- Make sure to increment
version
andbuildNumber
inside the app.json file. - Build a native iOS build with
npx expo run:ios
- Create an iOS Prod build via
eas build --platform ios
. Submit to appstore connect with:eas submit -p ios