-
Notifications
You must be signed in to change notification settings - Fork 0
Architecture
Our project will use the following:
-
React Native
Used to create the user interface. -
React-navigation
Used for navigation between pages within the app. -
React-native-firebase
Interface between the app and Firebase. -
Firebase
Data hosting and user authentication. -
npm
Package manager. -
Expo
Building and testing the application. -
USDA FoodData Central API
Used to retrieve nutritional data.
- Brent Hopkins: #22, #25
- Mostafa Mohamed Ali: #17, #18, #19
- User(username, password, age, dietary_restrictions, height, weight, calorie_goal, first_name, last_name)
- SleepEntry(UUID, date, hours)
- FoodDiary(UUID, date, breakfast, lunch, dinner, snacks)
- Recipe(UUID, author, title, instructions, description, ingredients, servings)
- hasSleepEntry(User.username, SleepEntry.UUID, SleepEntry.date)
- hasFoodDiary((User.username, FoodDiary.UUID, FoodDiary.date)
- savedRecipe(User.username, Recipe.UUID)
- getFoodDiary(username, date)
- getSleepDiary(username, date)
- getUserDetails(username)
- getSavedRecipes(username)
Background: contains the background color and welcome text.
Buttons: contains the buttons used to sign in or create a new account
Background: Contains the background color
Sign in menu: contains the email and password fields along with the sign in button
Background: contains the background color
New user menu: contains the create account button, text fields , and drop down menus needed for account creation
Background: contains the background color
Goal: shows the user their macro nutrient and calorie stats for the current date
Trending: contains trending recipes and their nutritional info
Sleep: contains the users sleep data for the past week
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Date: contains the currently selected date and the buttons to change it
Calories: contains the users calorie information for the specified date and an ellipsis used to navigate to the nutrient page
Food: contains each meal and its entries along with the buttons needed to add a new entry to each meal
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Header: contains the selected date along with the buttons to change it and a button to return to the food diary
Nutrients: contains nutrient information for the selected date displayed as %DV
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Search: contains the text field and button used to search for food
results: displays the results of the last search and the buttons needed to add each result
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Details: contains the name of the food, an image (if available), serving size, nutritional information for the food and a button to save the food to the users diary
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Search: contains the text field and button used to search for recipes
Results: contains the recipes that were found by the search
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Details: contains information about the recipe such as name, ingredients, instructions, nutritional information, and a photo (if available)
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Header: Contains the name of the screen and a button to return to the home screen
Options: contains the buttons for each of the options within the settings menu
Navigation: contains the buttons used to navigate to other pages within the app
Background: contains the background color
Header: contains the title of the page and a button to return to the home page
Info: contains the text fields for the users information
User Goals: contains the users selected goals used for tailoring the app to their needs
Activity Level: contains buttons used to specify the users activity level which is used in calculating calorie goals
Save: contains the button to confirm and save the users changes
Background: contains the background color
Header: contains the title of the page and a button to return to the home screen
Restrictions: contains a list of dietary restrictions and the buttons to add or remove them from the users account
Save: contains the button to confirm and save the users changes
"
Background: contains the background color
Sleep History: contains a dynamic chart that the displays the last seven days of the current user’s sleep data. Has a “Show History” button that allows the user to change the date range of the sleep chart.
Trends: Displays trends that are calculated based on the data collected on the current user’s sleep patterns. In the event there are more trends that are not displayed, the user can tap the “View more…” button to view additional trends.
Navigation: contains the buttons used to navigate to other pages within the app
Background: Contains the background color
Filters: Contains toggleable buttons the user can use to refine the results in the results component
Results: Displays all recipes the user has saved, unless filters have been applied in the Filters component
Navigation: contains the buttons used to navigate to other pages within the app
Our code base will be built and distributed as a .apk file