|
| 1 | +import random |
| 2 | + |
| 3 | +import gradio as gr |
| 4 | + |
| 5 | +demo = gr.Blocks() |
| 6 | + |
| 7 | +with demo: |
| 8 | + gr.Markdown( |
| 9 | + "Load the flashcards in the table below, then use the Practice tab to practice." |
| 10 | + ) |
| 11 | + |
| 12 | + with gr.Tabs(): |
| 13 | + with gr.TabItem("Word Bank"): |
| 14 | + flashcards_table = gr.Dataframe(headers=["front", "back"], type="array") |
| 15 | + with gr.TabItem("Practice"): |
| 16 | + with gr.Row(): |
| 17 | + front = gr.Textbox() |
| 18 | + answer_row = gr.Row(visible=False) |
| 19 | + with answer_row: |
| 20 | + back = gr.Textbox() |
| 21 | + with gr.Row(): |
| 22 | + new_btn = gr.Button("New Card") |
| 23 | + flip_btn = gr.Button("Flip Card") |
| 24 | + selected_card = gr.Variable() |
| 25 | + feedback_row = gr.Row(visible=False) |
| 26 | + with feedback_row: |
| 27 | + correct_btn = gr.Button( |
| 28 | + "Correct", |
| 29 | + css={"background-color": "lightgreen", "color": "green"}, |
| 30 | + ) |
| 31 | + incorrect_btn = gr.Button( |
| 32 | + "Incorrect", css={"background-color": "pink", "color": "red"} |
| 33 | + ) |
| 34 | + with gr.TabItem("Results"): |
| 35 | + results = gr.Variable(default_value={}) |
| 36 | + correct_field = gr.Markdown("# Correct: 0") |
| 37 | + incorrect_field = gr.Markdown("# Incorrect: 0") |
| 38 | + gr.Markdown("Card Statistics: ") |
| 39 | + results_table = gr.Dataframe(headers=["Card", "Correct", "Incorrect"]) |
| 40 | + |
| 41 | + def load_new_card(flashcards): |
| 42 | + card = random.choice(flashcards) |
| 43 | + return card, card[0], False, False |
| 44 | + |
| 45 | + new_btn.click( |
| 46 | + load_new_card, |
| 47 | + [flashcards_table], |
| 48 | + [selected_card, front, answer_row, feedback_row], |
| 49 | + ) |
| 50 | + |
| 51 | + def flip_card(card): |
| 52 | + return card[1], True, True |
| 53 | + |
| 54 | + flip_btn.click(flip_card, [selected_card], [back, answer_row, feedback_row]) |
| 55 | + |
| 56 | + def mark_correct(card, results): |
| 57 | + if card[0] not in results: |
| 58 | + results[card[0]] = [0, 0] |
| 59 | + results[card[0]][0] += 1 |
| 60 | + correct_count = sum(result[0] for result in results.values()) |
| 61 | + return ( |
| 62 | + results, |
| 63 | + f"# Correct: {correct_count}", |
| 64 | + [[front, scores[0], scores[1]] for front, scores in results.items()], |
| 65 | + ) |
| 66 | + |
| 67 | + def mark_incorrect(card, results): |
| 68 | + if card[0] not in results: |
| 69 | + results[card[0]] = [0, 0] |
| 70 | + results[card[0]][1] += 1 |
| 71 | + incorrect_count = sum(result[1] for result in results.values()) |
| 72 | + return ( |
| 73 | + results, |
| 74 | + f"# Inorrect: {incorrect_count}", |
| 75 | + [[front, scores[0], scores[1]] for front, scores in results.items()], |
| 76 | + ) |
| 77 | + |
| 78 | + correct_btn.click( |
| 79 | + mark_correct, |
| 80 | + [selected_card, results], |
| 81 | + [results, correct_field, results_table], |
| 82 | + ) |
| 83 | + |
| 84 | + incorrect_btn.click( |
| 85 | + mark_incorrect, |
| 86 | + [selected_card, results], |
| 87 | + [results, incorrect_field, results_table], |
| 88 | + ) |
| 89 | + |
| 90 | +if __name__ == "__main__": |
| 91 | + demo.launch() |
0 commit comments