Metadata-Version: 2.1
Name: memoria-gui
Version: 0.1.3
Summary: GUI for memorizing vocabulary, grammar, phrases of a foreign language
Home-page: https://github.com/jeffjennings/memoria
Author: Jeff Jennings
Author-email: jjennings1519@gmail.com
License: LGPLv3
Project-URL: Bug Tracker, https://github.com/jeffjennings/memoria/issues
Keywords: language,Italian
Classifier: Development Status :: 3 - Alpha
Classifier: License :: OSI Approved :: GNU Lesser General Public License v3 (LGPLv3)
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX :: Linux
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Requires-Python: >=3.9
Description-Content-Type: text/markdown
Provides-Extra: test
License-File: LICENSE.txt

<p align="center">
   <img width = "300" src="https://github.com/jeffjennings/memoria/blob/main/logo.jpg?raw=true"/>
 </p>

<p align="center">
A simple GUI to generate flashcards for memorizing vocabulary, grammar and phrases of a foreign language.
</p>

<p align="center">
  <!-- current release -->
  <a href="https://github.com/jeffjennings/memoria/releases">
      <img src="https://img.shields.io/github/release/jeffjennings/memoria/all.svg">
  </a>

  <!-- current version on pypi -->
  <a href="https://pypi.python.org/pypi/memoria-gui">
      <img src="https://img.shields.io/pypi/v/memoria-gui.svg">

</p>

Install
-------
`pip install memoria-gui`

Using _memoria_
---------------
`python gui.py` from the terminal produces a GUI with which you choose: 
- a book to draw entries from,
- which chapters in the book to draw from,
- which type of entry to draw (vocabulary, grammar or phrases), and
- in which language to display the entries on the flashcards (English or the foreign language).

Grids of flashcards are then generated, spanning all the entries of the chosen type from the chosen source, with the order randomized. Clicking on a flashcard shows its English/foreign language counterpart (or in the case of grammar, the relevant forms). 

_memoria_ is currently tailored to Italian, but it's easy to drop in another language (it might eventually support Ancient Greek and Latin) - just add new dictionaries with the English and foreign language counterparts.

Using _memoria_ for Italian
---------------------------
For Italian specifically:
- Clicking on a vocabulary flashcard a second time opens the [WordReference](https://www.wordreference.com/iten/) website with a search for the word to obtain its dictionary entry.
- Clicking on a verb flashcard a second time opens the [Virgilio](https://sapere.virgilio.it/parole/coniuga-verbi/) website with a search for the verb to obtain its conjugations in all tenses.
- Clicking on other grammar or phrase flashcards a second time opens google translate with the Italian version of the entry, so that you can hear it spoken by clicking on the speaker icon there.
- If you're interested in learning Italian, these are the books I'm using (and the source of flashcard entries in the code). Together I think they should provide a good teaching of [CEFR levels](https://www.coe.int/en/web/common-european-framework-reference-languages/table-1-cefr-3.3-common-reference-levels-global-scale) A1 - C2 of the language (i.e., from beginner to fluent), including a strong understanding of the grammar:
   * _New Italian Espresso - Beginner and Pre-intermediate_ (CEFR level A0 - A1.5) and _Intermediate and Advanced_ (CEFR level A1.5 - B1) - the textbooks and workbooks
   * _Nuovo Espresso 4, 5, 6_ (CEFR levels B2, C1, C2) - these books are only in Italian
   * _English Grammar for Students of Italian_ 
   * _Italian Grammar in Practice_ (covering CEFR levels A1 - B2)
   * _Pocket Italian Grammar_

Background
----------
This package is mostly me wanting a fast way to study Italian and learning how to make GUIs in Python with `tkinter`. I've only been using Mac OS, so the formatting of the GUIs might be off on Linux or Windows. If you want to use and/or customize the code for your own language and you'd like some help, or if you have any suggestions, feel free to open an issue!

_memoria_ is Latin (and Italian!) for 'memory, remembrance'. Hence the Latin phrase 'In memoriam' and the English derivatives 'memorial' and 'memoir'.

The logo is a Roman mosaic showing μνημοσύνη (Mnemosyne), the Greek Titan of memory and mother of the nine Muses. μνήμη	is Greek for 'memory, remembrance' and is the origin of the English derivative 'mnemonic'.
