Compare commits

7 Commits

Author SHA1 Message Date
c7faed0597 formatting and snackbar 2025-11-26 23:19:29 -05:00
290bed8198 formatting adjustments 2025-11-26 23:18:48 -05:00
3f10d8049a hamburger 2025-11-25 23:21:11 -05:00
8e9d57c5cb formatting changes 2025-11-25 23:20:57 -05:00
ff32de4ac0 formatting changes 2025-11-25 23:20:46 -05:00
b137fcb0f9 minor filepath changes 2025-11-25 23:20:25 -05:00
dfca9bf2ed Updated project name 2025-11-25 23:19:56 -05:00
7 changed files with 79 additions and 44 deletions

View File

@@ -1,5 +1,5 @@
[project] [project]
name = "Meal Picker" name = "NoteNook"
version = "0.1.0" version = "0.1.0"
description = "An app designed to build, store, and select meals for shopping purposes." description = "An app designed to build, store, and select meals for shopping purposes."
readme = "README.md" readme = "README.md"
@@ -18,7 +18,7 @@ org = "codes.kalar"
# project display name that is used as an app title on Android and iOS home screens, # project display name that is used as an app title on Android and iOS home screens,
# shown in window titles and about app dialogs on desktop. # shown in window titles and about app dialogs on desktop.
product = "Meal Picker" product = "NoteNook"
# company name to display in about app dialogs # company name to display in about app dialogs
company = "Nick Kalar" company = "Nick Kalar"

View File

@@ -5,11 +5,13 @@ from dotenv import load_dotenv
load_dotenv() load_dotenv()
file_path = os.getenv("FILE_PATH") + "/checklist.md" if os.getenv("FILE_PATH") else "./checklist.md" checklist_file_path = os.getenv("FILE_PATH") + "/checklist.md" if os.getenv("FILE_PATH") else "./checklist.md"
ingredients_file_path = "./src/json/ingredients.json"
def read_json() -> dict: def read_json() -> dict:
try: try:
with open("./src/json/ingredients.json", "rt") as file: with open(ingredients_file_path, "rt") as file:
return json.load(file) return json.load(file)
except: except:
print("Could not find or read file.") print("Could not find or read file.")
@@ -17,7 +19,7 @@ def read_json() -> dict:
def update_json(meals: dict) -> None: def update_json(meals: dict) -> None:
try: try:
with open("./src/json/ingredients.json", "w") as file: with open(ingredients_file_path, "w") as file:
json.dump(meals, file, indent=4) json.dump(meals, file, indent=4)
except Exception as e: except Exception as e:
print(f"Unable to write data to file. {e}") print(f"Unable to write data to file. {e}")
@@ -44,7 +46,7 @@ def combine_ingredients(meals: dict) -> dict:
def write_checklist(data: dict) -> None: def write_checklist(data: dict) -> None:
try: try:
with open(file_path, 'w') as checklist: with open(checklist_file_path, 'w') as checklist:
for ingredient, details in data.items(): for ingredient, details in data.items():
s = ingredient + " - " + str(details['quantity']) s = ingredient + " - " + str(details['quantity'])
if details['units'] != None: if details['units'] != None:

View File

@@ -45,16 +45,16 @@ def builder(page):
def create_ingredient_row(self, ingredient, details): def create_ingredient_row(self, ingredient, details):
row = [] row = []
row.append(ft.TextField(label="Ingredient", value=ingredient, on_change=self.update_ingredient)) row.append(ft.TextField(label="Ingredient", value=ingredient, on_change=self.update_ingredient, width=300))
row.append(ft.TextField(label="Quantity", value=details['quantity'], on_change=self.update_quantity)) row.append(ft.TextField(label="Quantity", value=details['quantity'], on_change=self.update_quantity, width=200))
row.append(ft.TextField(label="Units (optional)", value=details['units'], on_change=self.update_units)) row.append(ft.TextField(label="Units (optional)", value=details['units'], on_change=self.update_units, width=200))
return row return row
def create_new_ingredient_row(self): def create_new_ingredient_row(self):
row = [] row = []
row.append(ft.TextField(label="Ingredient", value="")) row.append(ft.TextField(label="Ingredient", value="", width=300))
row.append(ft.TextField(label="Quantity", value="")) row.append(ft.TextField(label="Quantity", value="", width=200))
row.append(ft.TextField(label="Units (optional)", value="")) row.append(ft.TextField(label="Units (optional)", value="", width=200))
return row return row
def update_ingredients(self, name): def update_ingredients(self, name):
@@ -78,26 +78,32 @@ def builder(page):
def show_new_meal(self): def show_new_meal(self):
self.new_meal = {} self.new_meal = {}
selector_body.controls = [ selector_body.controls = [
ft.TextField(label="Meal", value="", autofocus=True), ft.TextField(label="Meal", value="", autofocus=True, width=720),
ft.ListView(controls=[ft.Row(self.create_new_ingredient_row(), ft.ListView(controls=[ft.Row(self.create_new_ingredient_row(),
alignment=ft.MainAxisAlignment.SPACE_EVENLY, alignment=ft.MainAxisAlignment.START,
width=300,
height=100,
)], )],
expand=True, expand=True,
spacing=5,
padding=5,
auto_scroll=False, auto_scroll=False,
), ),
ft.Row(controls=[
ft.ElevatedButton(text="Add Ingredient", on_click=lambda e: self.append_new_ingredient_row(selector_body)), ft.ElevatedButton(text="Add Ingredient", on_click=lambda e: self.append_new_ingredient_row(selector_body)),
ft.ElevatedButton(text="Add Meal", on_click=lambda e: self.add_new_meal(selector_body)), ft.ElevatedButton(text="Add Meal", on_click=lambda e: self.add_new_meal(selector_body)),
ft.ElevatedButton(text="Back", on_click=lambda e: self.show_meal_selection(selector_body, page)) ft.ElevatedButton(text="Back", on_click=lambda e: self.show_meal_selection(selector_body, page))
] ]
)
]
page.title = "Add New Meal" page.title = "Add New Meal"
page.update() page.update()
def append_new_ingredient_row(self, selector_body): def append_new_ingredient_row(self, selector_body):
# Don't add a new row if the last one is blank
if selector_body.controls[1].controls[-1].controls[0].value == "" or \
selector_body.controls[1].controls[-1].controls[1].value == "":
page.open(ft.SnackBar(ft.Text("Please fill in the current ingredient before adding a new one.")))
return
selector_body.controls[1].controls.append(ft.Row(self.create_new_ingredient_row(), selector_body.controls[1].controls.append(ft.Row(self.create_new_ingredient_row(),
alignment=ft.MainAxisAlignment.SPACE_EVENLY, alignment=ft.MainAxisAlignment.SPACE_EVENLY,
width=300, width=300,
@@ -109,6 +115,12 @@ def builder(page):
meal = selector_body.controls[0].value meal = selector_body.controls[0].value
ing, qua, uni = [], [], [] ing, qua, uni = [], [], []
if meal == "" or \
selector_body.controls[1].controls.controls[0].value == "" or \
selector_body.controls[1].controls.controls[1].value == "":
page.open(ft.SnackBar(ft.Text("Please fill out the meal information.")))
return
for row in selector_body.controls[1].controls: for row in selector_body.controls[1].controls:
#skip blank row #skip blank row
if row.controls[0].value == "" or row.controls[1].value == "": if row.controls[0].value == "" or row.controls[1].value == "":
@@ -128,14 +140,16 @@ def builder(page):
def show_meal_details(self, selector_body, page): def show_meal_details(self, selector_body, page):
expanded_meal = [] expanded_meal = []
if (selector_body.controls[0].controls[0].value == None):
page.open(ft.SnackBar(ft.Text("Please select a meal to update.")))
return
meal_name = selector_body.controls[0].controls[0].value meal_name = selector_body.controls[0].controls[0].value
for details in meal_json[meal_name].items(): for details in meal_json[meal_name].items():
expanded_meal.append( expanded_meal.append(
ft.Row(self.create_ingredient_row(details[0], details[1]), ft.Row(self.create_ingredient_row(details[0], details[1]),
alignment=ft.MainAxisAlignment.SPACE_EVENLY, alignment=ft.MainAxisAlignment.SPACE_EVENLY,
width=300,
height=100,
) )
) )
@@ -144,13 +158,16 @@ def builder(page):
ft.ListView( ft.ListView(
controls=expanded_meal, controls=expanded_meal,
expand=True, expand=True,
spacing=5, spacing=10,
padding=5, padding=10,
auto_scroll=False, auto_scroll=False,
), ),
ft.ElevatedButton(text="Update Meal", on_click=lambda e: self.update_ingredients(selector_body.controls[0].value)), ft.Row(controls=[
ft.ElevatedButton(text="Save Changes", on_click=lambda e: self.update_ingredients(selector_body.controls[0].value)),
ft.ElevatedButton(text="Back", on_click=lambda e: self.show_meal_selection(selector_body, page)), ft.ElevatedButton(text="Back", on_click=lambda e: self.show_meal_selection(selector_body, page)),
] ]
)
]
if page.title == "Create and Edit Meals!": if page.title == "Create and Edit Meals!":
page.title = f"Editing {meal_name}" page.title = f"Editing {meal_name}"
page.update() page.update()
@@ -164,14 +181,18 @@ def builder(page):
self.get_meal_radios_group(), self.get_meal_radios_group(),
], ],
expand=True, expand=True,
spacing=5, spacing=10,
padding=5, padding=10,
auto_scroll=False, auto_scroll=False,
), ),
ft.Row(
controls=[
ft.ElevatedButton(text="Update Meal", ft.ElevatedButton(text="Update Meal",
on_click=lambda e: self.show_meal_details(selector_body, page)), on_click=lambda e: self.show_meal_details(selector_body, page)),
ft.ElevatedButton(text="Add Meal", on_click=lambda e: self.show_new_meal()) ft.ElevatedButton(text="Add Meal", on_click=lambda e: self.show_new_meal())
] ]
)
]
if page.title != "Create and Edit Meals!": if page.title != "Create and Edit Meals!":
page.title = f"Create and Edit Meals!" page.title = f"Create and Edit Meals!"
@@ -186,7 +207,7 @@ def builder(page):
selector_body = ft.Column( selector_body = ft.Column(
controls = [], controls = [],
height = 500, height = 700,
expand = False, expand = False,
) )

View File

@@ -13,14 +13,22 @@ def selector(page: ft.Page):
selected_meals.pop(meal.label) selected_meals.pop(meal.label)
else: else:
selected_meals[meal.label] = meal_json[meal.label] selected_meals[meal.label] = meal_json[meal.label]
print(selected_meals) if selected_meals == {}:
page.open(ft.SnackBar(ft.Text("Please select at least one meal.")))
return
write_checklist(combine_ingredients(selected_meals)) write_checklist(combine_ingredients(selected_meals))
page.title = "Select Some Meals" page.title = "Select Some Meals"
meal_list = [] meal_list = []
for name, _ in meal_json.items(): for name, _ in meal_json.items():
meal_list.append(ft.Checkbox(label=name)) meal_list.append(ft.Checkbox(
label = name,
active_color = '#6da0cd',
)
)
submit_button = ft.ElevatedButton(text="Make Shopping List", on_click=update_meal_selection) submit_button = ft.ElevatedButton(text="Make Shopping List", on_click=update_meal_selection)
@@ -34,7 +42,7 @@ def selector(page: ft.Page):
), ),
submit_button, submit_button,
], ],
height = 500, height = 700,
expand = False, expand = False,
) )
page.update() page.update()

BIN
src/assets/hamburger.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

View File

@@ -5,12 +5,14 @@ from models.MenuBar import create_menubar
def main(page: ft.Page): def main(page: ft.Page):
page.window.width = 750
page.window.height = 900
page.window.top = 10
page.appbar = create_menubar(page, selector, builder) page.appbar = create_menubar(page, selector, builder)
page.bgcolor = '#013328'
page.add(ft.Pagelet( page.add(ft.Pagelet(content=ft.Text()))
content = ft.Text("Welcome to Meal Picker! Please select an option from the menu above to get started.") selector(page)
)
)
if __name__ == "__main__": if __name__ == "__main__":
ft.app(main) ft.app(main)

View File

@@ -2,15 +2,17 @@ import flet as ft
def create_menubar(page: ft.Page, selector, builder): def create_menubar(page: ft.Page, selector, builder):
menu = ft.AppBar( menu = ft.AppBar(
title=ft.Text("Meal Picker"), title=ft.Text("NoteNook"),
bgcolor=ft.Colors.GREEN_700, bgcolor='#CC8B65',
center_title=False, center_title=False,
actions=[ actions=[
ft.PopupMenuButton( ft.PopupMenuButton(
items=[ items=[
ft.PopupMenuItem(text="Meal Selector", on_click=lambda e: selector(page)), ft.PopupMenuItem(text="Meal Selector", on_click=lambda e: selector(page)),
ft.PopupMenuItem(text="Meal Builder", on_click=lambda e: builder(page)), ft.PopupMenuItem(text="Meal Builder", on_click=lambda e: builder(page)),
] ],
icon = ft.Icons.FASTFOOD_OUTLINED,
icon_color = '#E3DCD2'
) )
] ]
) )