Metadata-Version: 2.1
Name: linguappt
Version: 0.1.11
Summary: PPT generator for language learning
Home-page: https://github.com/qishe-nlp/linguappt
Keywords: ppt,language,auto
Author: Phoenix Grey
Author-email: phoenix.grey0108@gmail.com
Requires-Python: >=3.8,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Requires-Dist: click (>=8.0.0,<9.0.0)
Requires-Dist: pdf2image (>=1.12.1,<2.0.0)
Requires-Dist: python-pptx (>=0.6.18,<0.7.0)
Project-URL: Documentation, https://qishe-nlp.github.io/linguappt/
Project-URL: Repository, https://github.com/qishe-nlp/linguappt
Description-Content-Type: text/markdown

# Installation

```
pip3 install --verbose linguappt 
```

# Usage

Please refer to [api docs](https://qishe-nlp.github.io/linguappt/).

### Execute usage

* Validate ppt template
```
lingua_pptx_validate --pptx [pptx file]
```

* Convert vocabulary csv file into ppt file
```
lingua_vocabppt --sourcecsv [vocab csv file] --lang [language] --title [title shown in ppt] --destpptx [pptx file]
```

* Convert phrase csv file into ppt file
```
lingua_phraseppt --sourcecsv [phrase csv file] --lang [language] --title [title shown in ppt] --destpptx [pptx file]
```


* Convert ppt into pdf
```
lingua_pptx2pdf --sourcepptx [pptx file] --destdir [dest directory storing pdf and images]
```

### Package usage
```
from linguappt import SpanishVocabPPT, EnglishVocabPPT
from linguappt import EnglishPhrasePPT, SpanishPhrasePPT

def vocabppt(sourcecsv, title, lang, destpptx):
  _PPTS = {
    "en": EnglishVocabPPT,
    "es": SpanishVocabPPT
  }

  _PPT = _PPTS[lang]

  vp = _PPT(sourcecsv, title)
  vp.convert_to_ppt(destpptx)

def phraseppt(sourcecsv, title, lang, destpptx):
  _PPTS = {
    "en": EnglishPhrasePPT,
    "es": SpanishPhrasePPT
  }

  _PPT = _PPTS[lang]

  vp = _PPT(sourcecsv, title)
  vp.convert_to_ppt(destpptx)


```

# Development

### Clone project
```
git clone https://github.com/qishe-nlp/linguappt.git
```

### Install [poetry](https://python-poetry.org/docs/)

### Install dependencies
```
poetry update
```

### Test
```
poetry run pytest -rP --capture=sys
```
which run tests under `tests/*`


### Execute
```
poetry run lingua_pptx_validate --help
poetry run lingua_vocabppt --help
poetry run lingua_phraseppt --help

poetry run lingua_pptx2pdf2images --help
poetry run lingua_csv2media --help
```

### Create sphinx docs
```
poetry shell
cd apidocs
sphinx-apidoc -f -o source ../linguappt
make html
python -m http.server -d build/html
```

### Host docs on github pages
```
cp -rf apidocs/build/html/* docs/
```

### Build
* Change `version` in `pyproject.toml` and `linguappt/__init__.py`
* Build python package by `poetry build`

### Git commit and push

### Publish from local dev env
* Set pypi test environment variables in poetry, refer to [poetry doc](https://python-poetry.org/docs/repositories/)
* Publish to pypi test by `poetry publish -r test`

### Publish through CI 
* Github action build and publish package to [test pypi repo](https://test.pypi.org/)

```
git tag [x.x.x]
git push origin master
```

* Manually publish to [pypi repo](https://pypi.org/) through [github action](https://github.com/qishe-nlp/linguappt/actions/workflows/pypi.yml)


