diff options
Diffstat (limited to 'gui-project')
-rw-r--r-- | gui-project/cards.py | 8 | ||||
-rw-r--r-- | gui-project/main_ui.py | 23 |
2 files changed, 23 insertions, 8 deletions
diff --git a/gui-project/cards.py b/gui-project/cards.py index 42a08b0..1bb4320 100644 --- a/gui-project/cards.py +++ b/gui-project/cards.py @@ -29,6 +29,7 @@ class CardUI(): self.card = card self.is_resolved = asyncio.Event() self.init_card() + self.correctly_answered = False def init_card(self): with self.parent_ui: @@ -38,7 +39,7 @@ class CardUI(): def init_front(self): with self.row_parent: - with ui.card().classes('bg-frontc') as self.front: + with ui.card().classes('bg-frontc w-[600px] h-[200px] mx-auto') as self.front: ui.markdown("**Front**") ui.separator() ui.markdown(self.card.get_front()) @@ -47,7 +48,7 @@ class CardUI(): def init_back(self): with self.row_parent: - with ui.card().classes('bg-back') as self.back: + with ui.card().classes('bg-back w-[600px] h-[200px] mx-auto') as self.back: ui.markdown("_Back_") ui.separator() ui.markdown(self.card.get_back()) @@ -65,15 +66,14 @@ class CardUI(): self.back.set_visibility(True) def revert_card(self): - ui.notify("Showing back") self.show_back() def user_clicked_correct(self): ui.notify("You got this") + self.correctly_answered = True self.is_resolved.set() def user_clicked_incorrect(self): - ui.notify("Keep at it!") self.is_resolved.set() async def is_answered(self): diff --git a/gui-project/main_ui.py b/gui-project/main_ui.py index f6351b0..8f3371c 100644 --- a/gui-project/main_ui.py +++ b/gui-project/main_ui.py @@ -1,3 +1,5 @@ +from typing import final + from nicegui import ui import os import random @@ -16,7 +18,7 @@ class MainUI(): # ========= start initializing UI =========== with ui.header() as self.header: - self.header_element = ui.label("Session Configuration") + self.header_element = ui.markdown("Session Configuration") self.root_ui = ui.row().classes("fixed-center") with self.root_ui: with ui.card(align_items="baseline") as self.session_configuration: @@ -51,8 +53,7 @@ class MainUI(): self.header.classes("bg-negative") with self.header: - self.header_element = ui.markdown(f"Currently in **{run_mode}** mode") - + self.header_element = ui.markdown(f"Currently in **{run_mode}** mode\nQuestion 1/{self.nb_questions_ui.value}") self.run_mode = run_mode # read values from UI and set session configuration self.nb_questions = int(self.nb_questions_ui.value) @@ -73,8 +74,11 @@ class MainUI(): session = Session("brutal", cards_paths, "/home/andreear/git/flashcards/state.txt") - ui.colors(frontc='#bcdbc6', back="#c4bcdb") + final_score = 0 + ui.colors(frontc='#bcdbc6', back="#c4bcdb", final="#9cfcfc") for i, card in enumerate(session.practice(self.nb_questions)): + self.header_element.set_content(f"Currently in **practice** mode\n\nQuestion {i+1}/{int(self.nb_questions_ui.value)}") + # print(self.header_element.content) prompt_type_binary = self.prompt_type.lower() if self.prompt_type.lower() == "random": random_nb = random.randint(0, sys.maxsize) @@ -92,5 +96,16 @@ class MainUI(): card_ui.show_front() await card_ui.is_answered() + if card_ui.correctly_answered: + final_score += 1 card_ui.hide_card() + with self.root_ui: + with ui.card(align_items="center").classes("bg-final"): + ui.markdown("## Finished") + ui.label(f"Your final score is: {final_score}/{self.nb_questions}") + ui.label("To start again, refresh the page") + + + + |