Metadata-Version: 2.1
Name: valuta
Version: 0.2
Summary: Currencies done right.
Home-page: https://github.com/barseghyanartur/valuta/
Author: Artur Barseghyan
Author-email: artur.barseghyan@gmail.com
License: GPL-2.0-only OR LGPL-2.1-or-later
Project-URL: Bug Tracker, https://github.com/barseghyanartur/valuta/issues
Project-URL: Documentation, https://valuta.readthedocs.io/
Project-URL: Source Code, https://github.com/barseghyanartur/valuta
Project-URL: Changelog, https://valuta.readthedocs.io/en/latest/changelog.html
Keywords: currency
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Environment :: Web Environment
Classifier: License :: OSI Approved :: GNU General Public License v2 (GPLv2)
Classifier: License :: OSI Approved :: GNU Lesser General Public License v2 or later (LGPLv2+)
Classifier: Framework :: Django
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Financial and Insurance Industry
Classifier: Operating System :: OS Independent
Classifier: Development Status :: 4 - Beta
Description-Content-Type: text/x-rst
Requires-Dist: Babel (>=2.1.1)

======
valuta
======
**Currencies done right**

.. _List of circulating currencies: https://en.wikipedia.org/wiki/List_of_circulating_currencies

In most payment systems that went international, amounts are represented in
integers, instead of decimals, as they are represented in minor currency units
(smallest units possible).

For `EUR` it is `cent <https://en.wikipedia.org/wiki/Cent_(currency)>`__,
which is 1/100 of a single `Euro <https://en.wikipedia.org/wiki/Euro>`__.
For `MRU` it is `khoums <https://en.wikipedia.org/wiki/Khoums>`__,
which is 1/5 of a single `Ouguiya <https://en.wikipedia.org/wiki/Mauritanian_ouguiya>`__.

List of currencies is generated from a single CSV dump obtained from the
`list of circulating currencies`_ Wikipedia page using the awesome
`wikitable2csv <https://github.com/gambolputty/wikitable2csv>`__.

.. image:: https://img.shields.io/pypi/v/valuta.svg
   :target: https://pypi.python.org/pypi/valuta
   :alt: PyPI Version

.. image:: https://img.shields.io/pypi/pyversions/valuta.svg
    :target: https://pypi.python.org/pypi/valuta/
    :alt: Supported Python versions

.. image:: https://github.com/barseghyanartur/valuta/workflows/test/badge.svg
   :target: https://github.com/barseghyanartur/valuta/actions
   :alt: Build Status

.. image:: https://readthedocs.org/projects/valuta/badge/?version=latest
    :target: http://valuta.readthedocs.io/en/latest/?badge=latest
    :alt: Documentation Status

.. image:: https://img.shields.io/badge/license-GPL--2.0--only%20OR%20LGPL--2.1--or--later-blue.svg
   :target: https://github.com/barseghyanartur/valuta/#License
   :alt: GPL-2.0-only OR LGPL-2.1-or-later

.. image:: https://coveralls.io/repos/github/barseghyanartur/valuta/badge.svg?branch=master&service=github
    :target: https://coveralls.io/github/barseghyanartur/valuta?branch=master
    :alt: Coverage

Prerequisites
=============
- Core package requires Python 3.6, 3.7, 3.8 or 3.9.
- Django integration package (``valuta.contrib.django_integration``) requires
  Django 2.2, 3.0, 3.1 or 3.2.

Documentation
=============
Documentation is available on `Read the Docs
<http://valuta.readthedocs.io/>`_.

Installation
============
Latest stable version on PyPI:

.. code-block:: sh

    pip install valuta

Or development version from GitHub:

.. code-block:: sh

    pip install https://github.com/barseghyanartur/valuta/archive/master.tar.gz

Usage examples
==============
Pure Python
-----------
Using currency classes directly
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
If you need numbers back for further calculations
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. code-block:: python

    import valuta

    valuta.EUR.convert_to_currency_units(1_000)
    # 10.0

    valuta.UGX.convert_to_currency_units(1_000)
    # 1000.0

    valuta.MRU.convert_to_currency_units(1_000)
    # 200.0

    valuta.VND.convert_to_currency_units(1_000)
    # 100.0

    valuta.TND.convert_to_currency_units(1_000)
    # 1.0

    valuta.JPY.convert_to_currency_units(1_000)
    # 10.0

If you need to display the values and want a nice string back
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. code-block:: python

    import valuta

    valuta.EUR.display_in_currency_units(1_000)
    # '10.00'

    valuta.UGX.display_in_currency_units(1_000)
    # '1000'

    valuta.MRU.display_in_currency_units(1_000)
    # '200.00'

    valuta.VND.display_in_currency_units(1_000)
    # '100'

    valuta.TND.display_in_currency_units(1_000)
    # '1.000'

    valuta.JPY.display_in_currency_units(1_000)
    # '10'

The ``display_in_currency_units`` method accepts optional ``format``
argument. Most common values are listed in the ``valuta.constants``:

- ``DISPLAY_FORMAT_NUMBER``: (default)
- ``DISPLAY_FORMAT_HUMAN_READABLE``
- ``DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_CODE``
- ``DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_SYMBOL``

A couple of examples:

.. code-block:: python

    from valuta.constants import *

    valuta.JPY.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE
    )
    # '10,000'

    valuta.JPY.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_CODE
    )
    # 'JPY 10,000'

    valuta.JPY.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_SYMBOL
    )
    # '¥ 10,000'

    valuta.EUR.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE
    )
    # '10,000.00'

    valuta.EUR.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_CODE
    )
    # 'EUR 10,000.00'

    valuta.EUR.display_in_currency_units(
        1_000_000,
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_SYMBOL
    )
    # '€ 10,000.00'

Working with string representations of the (ISO-4217) currency codes
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
If you need numbers back for further calculations
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. code-block:: python

    from valuta.shortcuts import convert_to_currency_units

    convert_to_currency_units("EUR", 1_000)
    # 10.0

    convert_to_currency_units("UGX", 1_000)
    # 1000.0

    convert_to_currency_units("MRU", 1_000)
    # 200.0

    convert_to_currency_units("VND", 1_000)
    # 100.0

    convert_to_currency_units("TND", 1_000)
    # 1.0

    convert_to_currency_units("JPY", 1_000)
    # 10.0

If you need to display the values and want a nice string back
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
.. code-block:: python

    from valuta.shortcuts import display_in_currency_units

    display_in_currency_units("EUR", 1_000)
    # '10.00'

    display_in_currency_units("UGX", 1_000)
    # '1000'

    display_in_currency_units("MRU", 1_000)
    # '200.00'

    display_in_currency_units("VND", 1_000)
    # '100'

    display_in_currency_units("TND", 1_000)
    # '1.000'

    display_in_currency_units("JPY", 1_000)
    # '10'

By default, exceptions arising from invalid currency codes are
suppressed (``None`` will be returned on invalid currency codes).

If you want to throw exception on invalid currency codes, set ``fail_silently``
to ``False``. The following example will throw a
``valuta.exceptions.InvalidCurrency`` exception.

.. code-block:: python

    convert_to_currency_units("i-dont-exist", 1_000, fail_silently=False)

The ``display_in_currency_units`` shortcut function also optional ``format``
argument.

Django integration
------------------
In its basis, Django integration package is a ``CurrencyField`` representing
the ISO-4217 codes of the currencies. If bound to certain number fields
(``SmallIntegerField``, ``IntegerField``, ``BigIntegerField``) holding the
amount in minor currency units, it adds up (magic) methods to the model class
for converting field amounts to major currency units (often simply called
``currency units``).

There are also `template tags and filters`_ for when you need to render
non-model data (for instance, JSON) in templates without prior pre-processing.

Model field
~~~~~~~~~~~
Model definition
^^^^^^^^^^^^^^^^
**Sample model**

*product/models.py*

.. code-block:: python

    from django.db import models
    from valuta.contrib.django_integration.models import CurrencyField

    class Product(models.Model):

        name = models.CharField(max_length=255)
        price = models.IntegerField()  # Amount in minor currency units
        price_with_tax = models.IntegerField()  # Amount in minor currency units
        currency = CurrencyField(amount_fields=["price", "price_with_tax"])

**Sample data**

.. code-block:: python

    import valuta
    from product.models import Product
    product = Product.objects.create(
        name="My test product",
        price=100,
        price_with_tax=120,
        currency=valuta.AMD.uid,
    )

Converting amounts using `magic methods`
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
You could then refer to the `price` and `price_with_tax` as follows:

.. code-block:: python

    product.price_in_currency_units()
    # 1
    product.price_with_tax_in_currency_units()
    # 1.2

Note, that every field listed in the ``amount_fields`` gets a correspondent
model method with suffix ``_in_currency_units`` for converting the field
amounts to (major) currency units.

Converting amounts for display using `magic methods`
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
You could then refer to the `price` and `price_with_tax` as follows:

.. code-block:: python

    product.price_display_in_currency_units()
    # '1.00'
    product.price_with_tax_display_in_currency_units()
    # '1.2'

Note, that every field listed in the ``amount_fields`` gets a correspondent
model method with suffix ``_display_in_currency_units`` for converting the field
amounts to (major) currency units.

Magic methods also accept optional ``format`` argument.

.. code-block:: python

    product.price_display_in_currency_units(
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_SYMBOL
    )
    # '€ 1.00'
    product.price_with_tax_display_in_currency_units(
        format=DISPLAY_FORMAT_HUMAN_READABLE_WITH_CURRENCY_CODE
    )
    # 'EUR 1.00'

Limiting the currency choices
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
On the field level
++++++++++++++++++
You could limit the currency choices as follows:

.. code-block:: python

    currency = CurrencyField(
        amount_fields=["price", "price_with_tax"],
        limit_choices_to=[valuta.AMD.uid, valuta.EUR.uid],
    )

Globally
++++++++
You could also override the ``CurrencyField`` choices in the Django settings:

*settings.py*

.. code-block:: python

    VALUTA_FIELD_LIMIT_CHOICES_TO=(
        valuta.AMD.uid,
        valuta.EUR.uid,
    )

Casting the converted values
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
If you want to explicitly cast the result value to a certain type, provide a
callable ``cast_to`` for the ``CurrencyField``.

For `int` it would be
+++++++++++++++++++++

.. code-block:: python

    currency = CurrencyField(
        amount_fields=("price", "price_with_tax",),
        cast_to=int,
    )

For `float` it would be
+++++++++++++++++++++++

.. code-block:: python

    currency = CurrencyField(
        amount_fields=("price", "price_with_tax",),
        cast_to=float,
    )

For `decimal.Decimal` it would be
+++++++++++++++++++++++++++++++++

.. code-block:: python

    currency = CurrencyField(
        amount_fields=("price", "price_with_tax",),
        cast_to=lambda __v: Decimal(str(__v)),
    )

Customize the choices display format
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
By default, the following format is used
(``valuta.utils.get_currency_choices_with_code``):

.. code-block:: python

        [
            ("AMD", "Armenian Dram (AMD)"),
            ("EUR", "Euro (EUR)"),
        ]

If you want to customize that, provide a callable ``get_choices_func`` along:

.. code-block:: python

    from valuta.utils import get_currency_choices

    currency = CurrencyField(
        amount_fields=("price", "price_with_tax",),
        get_choices_func=get_currency_choices,
    )

It would then have the following format:

.. code-block:: python

        [
            ("AMD", "Armenian Dram"),
            ("EUR", "Euro"),
        ]

Take both ``valuta.utils.get_currency_choices`` and
``valuta.utils.get_currency_choices_with_code`` as a good example of how
to customize. You could for instance do something like this:

.. code-block:: python

    import operator
    from typing import List, Tuple, Set, Union

    from babel.numbers import get_currency_symbol
    from valuta.base import Registry

    def get_currency_choices_with_sign(
            limit_choices_to: Union[Tuple[str, ...], List[str], Set[str]] = None,
            sort_by_key: bool = False,
    ) -> List[Tuple[str, str]]:
        """Get currency choices with code.

        List of choices in the following format::

            [
                ("AMD", "AMD - Armenian Dram"),
                ("EUR", "€ - Euro"),
                ("USD", "$ - US Dollar"),
            ]
        """
        if limit_choices_to is None:
            values = [
                (__key, f"{get_currency_symbol(__key)} - {__value.name}")
                for __key, __value in Registry.REGISTRY.items()
            ]
        else:
            values = [
                (__key, f"{get_currency_symbol(__key)} - {__value.name}")
                for __key, __value in Registry.REGISTRY.items()
                if __key in limit_choices_to
            ]
        if sort_by_key:
            values.sort(key=operator.itemgetter(0))
        else:
            values.sort(key=operator.itemgetter(1))
        return values

And then use it as follows:

.. code-block:: python

    currency = CurrencyField(
        amount_fields=("price", "price_with_tax",),
        get_choices_func=get_currency_choices_with_sign,
    )

Template tags and filters
~~~~~~~~~~~~~~~~~~~~~~~~~
Most of the cases would be covered by the `Model field`_, but it could be
that you will have non-model data (for instance, JSON) that you need to
properly render in the templates (without prior pre-processing). In that case
``valuta_tags`` template tags/filters library might help.

Template tags prerequisites
^^^^^^^^^^^^^^^^^^^^^^^^^^^
If you want to use templatetags library, you need to add
``valuta.contrib.django_integration`` to your ``INSTALLED_APPS``:

.. code-block:: python

    INSTALLED_APPS = (
        # ...
        "valuta.contrib.django_integration",
        # ...
    )

Sample data
^^^^^^^^^^^
.. code-block:: python

    instance = {
        "price": 1_000,
        "price_with_tax": 1_200,
        "currency_code": "EUR",
    }

Without formatting
^^^^^^^^^^^^^^^^^^

Sample template filters template
++++++++++++++++++++++++++++++++
*template_filter_price_in_currency_units.html*

.. code-block:: html

    {% load valuta_tags %}

    {{ instance.price|convert_to_currency_units:instance.currency_code }}

Sample template filters renderer
++++++++++++++++++++++++++++++++
.. code-block:: python

    from django.template.loader import render_to_string

    render_to_string(
        "template_filter_price_in_currency_units.html", {"instance": instance}
    )

Sample template tags template
+++++++++++++++++++++++++++++
*template_tag_price_in_currency_units.html*

.. code-block:: html

    {% load valuta_tags %}

    {% convert_to_currency_units instance.price instance.currency_code %}

Sample template tags renderer
+++++++++++++++++++++++++++++
.. code-block:: python

    from django.template.loader import render_to_string

    render_to_string(
        "template_tag_price_in_currency_units.html", {"instance": instance}
    )


With formatting
^^^^^^^^^^^^^^^

Sample template filters template
++++++++++++++++++++++++++++++++
*template_filter_price_display_in_currency_units.html*

.. code-block:: html

    {% load valuta_tags %}

    {{ instance.price|display_in_currency_units:instance.currency_code }}

Sample template filters renderer
++++++++++++++++++++++++++++++++
.. code-block:: python

    from django.template.loader import render_to_string

    render_to_string(
        "template_filter_price_display_in_currency_units.html", {"instance": instance}
    )

Sample template tags template
+++++++++++++++++++++++++++++
*template_tag_price_display_in_currency_units.html*

.. code-block:: html

    {% load valuta_tags %}

    {% display_in_currency_units instance.price instance.currency_code %}

Sample template tags renderer
+++++++++++++++++++++++++++++
.. code-block:: python

    from django.template.loader import render_to_string

    render_to_string(
        "template_tag_price_display_in_currency_units.html", {"instance": instance}
    )

Supported currencies
====================
Currencies marked with `(*)` are custom (added manually). The rest is obtained
from the already mentioned `list of circulating currencies`_.

.. code-block:: text

    ┌───────────┬──────────────────────────────────────────┐
    │ ISO code  │ Currency                                 │
    ├───────────┼──────────────────────────────────────────┤
    │ AED       │ United Arab Emirates Dirham              │
    ├───────────┼──────────────────────────────────────────┤
    │ AFN       │ Afghan Afghani                           │
    ├───────────┼──────────────────────────────────────────┤
    │ ALL       │ Albanian Lek                             │
    ├───────────┼──────────────────────────────────────────┤
    │ AMD       │ Armenian Dram                            │
    ├───────────┼──────────────────────────────────────────┤
    │ ANG       │ Netherlands Antillean Guilder            │
    ├───────────┼──────────────────────────────────────────┤
    │ AOA       │ Angolan Kwanza                           │
    ├───────────┼──────────────────────────────────────────┤
    │ ARS       │ Argentine Peso                           │
    ├───────────┼──────────────────────────────────────────┤
    │ AUD       │ Australian Dollar                        │
    ├───────────┼──────────────────────────────────────────┤
    │ AWG       │ Aruban Florin                            │
    ├───────────┼──────────────────────────────────────────┤
    │ AZN       │ Azerbaijani Manat                        │
    ├───────────┼──────────────────────────────────────────┤
    │ BAM       │ Bosnia-Herzegovina Convertible Mark      │
    ├───────────┼──────────────────────────────────────────┤
    │ BBD       │ Barbadian Dollar                         │
    ├───────────┼──────────────────────────────────────────┤
    │ BDT       │ Bangladeshi Taka                         │
    ├───────────┼──────────────────────────────────────────┤
    │ BGN       │ Bulgarian Lev                            │
    ├───────────┼──────────────────────────────────────────┤
    │ BHD       │ Bahraini Dinar                           │
    ├───────────┼──────────────────────────────────────────┤
    │ BIF       │ Burundian Franc                          │
    ├───────────┼──────────────────────────────────────────┤
    │ BMD       │ Bermudan Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ BND       │ Brunei Dollar                            │
    ├───────────┼──────────────────────────────────────────┤
    │ BOB       │ Bolivian Boliviano                       │
    ├───────────┼──────────────────────────────────────────┤
    │ BRL       │ Brazilian Real                           │
    ├───────────┼──────────────────────────────────────────┤
    │ BSD       │ Bahamian Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ BTC       │ Bitcoin (*)                              │
    ├───────────┼──────────────────────────────────────────┤
    │ BTN       │ Bhutanese Ngultrum                       │
    ├───────────┼──────────────────────────────────────────┤
    │ BWP       │ Botswanan Pula                           │
    ├───────────┼──────────────────────────────────────────┤
    │ BYN       │ Belarusian Ruble                         │
    ├───────────┼──────────────────────────────────────────┤
    │ BZD       │ Belize Dollar                            │
    ├───────────┼──────────────────────────────────────────┤
    │ CAD       │ Canadian Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ CDF       │ Congolese Franc                          │
    ├───────────┼──────────────────────────────────────────┤
    │ CHF       │ Swiss Franc                              │
    ├───────────┼──────────────────────────────────────────┤
    │ CKD       │ CKD                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ CLP       │ Chilean Peso                             │
    ├───────────┼──────────────────────────────────────────┤
    │ CNY       │ Chinese Yuan                             │
    ├───────────┼──────────────────────────────────────────┤
    │ COP       │ Colombian Peso                           │
    ├───────────┼──────────────────────────────────────────┤
    │ CRC       │ Costa Rican Colón                        │
    ├───────────┼──────────────────────────────────────────┤
    │ CUP       │ Cuban Peso                               │
    ├───────────┼──────────────────────────────────────────┤
    │ CVE       │ Cape Verdean Escudo                      │
    ├───────────┼──────────────────────────────────────────┤
    │ CZK       │ Czech Koruna                             │
    ├───────────┼──────────────────────────────────────────┤
    │ DJF       │ Djiboutian Franc                         │
    ├───────────┼──────────────────────────────────────────┤
    │ DKK       │ Danish Krone                             │
    ├───────────┼──────────────────────────────────────────┤
    │ DOP       │ Dominican Peso                           │
    ├───────────┼──────────────────────────────────────────┤
    │ DZD       │ Algerian Dinar                           │
    ├───────────┼──────────────────────────────────────────┤
    │ EGP       │ Egyptian Pound                           │
    ├───────────┼──────────────────────────────────────────┤
    │ ERN       │ Eritrean Nakfa                           │
    ├───────────┼──────────────────────────────────────────┤
    │ ETB       │ Ethiopian Birr                           │
    ├───────────┼──────────────────────────────────────────┤
    │ EUR       │ Euro                                     │
    ├───────────┼──────────────────────────────────────────┤
    │ FJD       │ Fijian Dollar                            │
    ├───────────┼──────────────────────────────────────────┤
    │ FKP       │ Falkland Islands Pound                   │
    ├───────────┼──────────────────────────────────────────┤
    │ FOK       │ FOK                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ GBP       │ British Pound                            │
    ├───────────┼──────────────────────────────────────────┤
    │ GEL       │ Georgian Lari                            │
    ├───────────┼──────────────────────────────────────────┤
    │ GGP       │ GGP                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ GHS       │ Ghanaian Cedi                            │
    ├───────────┼──────────────────────────────────────────┤
    │ GIP       │ Gibraltar Pound                          │
    ├───────────┼──────────────────────────────────────────┤
    │ GMD       │ Gambian Dalasi                           │
    ├───────────┼──────────────────────────────────────────┤
    │ GNF       │ Guinean Franc                            │
    ├───────────┼──────────────────────────────────────────┤
    │ GTQ       │ Guatemalan Quetzal                       │
    ├───────────┼──────────────────────────────────────────┤
    │ GYD       │ Guyanaese Dollar                         │
    ├───────────┼──────────────────────────────────────────┤
    │ HKD       │ Hong Kong Dollar                         │
    ├───────────┼──────────────────────────────────────────┤
    │ HNL       │ Honduran Lempira                         │
    ├───────────┼──────────────────────────────────────────┤
    │ HRK       │ Croatian Kuna                            │
    ├───────────┼──────────────────────────────────────────┤
    │ HTG       │ Haitian Gourde                           │
    ├───────────┼──────────────────────────────────────────┤
    │ HUF       │ Hungarian Forint                         │
    ├───────────┼──────────────────────────────────────────┤
    │ IDR       │ Indonesian Rupiah                        │
    ├───────────┼──────────────────────────────────────────┤
    │ ILS       │ Israeli New Shekel                       │
    ├───────────┼──────────────────────────────────────────┤
    │ IMP       │ IMP                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ INR       │ Indian Rupee                             │
    ├───────────┼──────────────────────────────────────────┤
    │ IQD       │ Iraqi Dinar                              │
    ├───────────┼──────────────────────────────────────────┤
    │ IRR       │ Iranian Rial                             │
    ├───────────┼──────────────────────────────────────────┤
    │ ISK       │ Icelandic Króna                          │
    ├───────────┼──────────────────────────────────────────┤
    │ JEP       │ JEP                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ JMD       │ Jamaican Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ JOD       │ Jordanian Dinar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ JPY       │ Japanese Yen                             │
    ├───────────┼──────────────────────────────────────────┤
    │ KES       │ Kenyan Shilling                          │
    ├───────────┼──────────────────────────────────────────┤
    │ KGS       │ Kyrgystani Som                           │
    ├───────────┼──────────────────────────────────────────┤
    │ KHR       │ Cambodian Riel                           │
    ├───────────┼──────────────────────────────────────────┤
    │ KID       │ KID                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ KMF       │ Comorian Franc                           │
    ├───────────┼──────────────────────────────────────────┤
    │ KPW       │ North Korean Won                         │
    ├───────────┼──────────────────────────────────────────┤
    │ KRW       │ South Korean Won                         │
    ├───────────┼──────────────────────────────────────────┤
    │ KWD       │ Kuwaiti Dinar                            │
    ├───────────┼──────────────────────────────────────────┤
    │ KYD       │ Cayman Islands Dollar                    │
    ├───────────┼──────────────────────────────────────────┤
    │ KZT       │ Kazakhstani Tenge                        │
    ├───────────┼──────────────────────────────────────────┤
    │ LAK       │ Laotian Kip                              │
    ├───────────┼──────────────────────────────────────────┤
    │ LBP       │ Lebanese Pound                           │
    ├───────────┼──────────────────────────────────────────┤
    │ LKR       │ Sri Lankan Rupee                         │
    ├───────────┼──────────────────────────────────────────┤
    │ LRD       │ Liberian Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ LSL       │ Lesotho Loti                             │
    ├───────────┼──────────────────────────────────────────┤
    │ LYD       │ Libyan Dinar                             │
    ├───────────┼──────────────────────────────────────────┤
    │ MAD       │ Moroccan Dirham                          │
    ├───────────┼──────────────────────────────────────────┤
    │ MDL       │ Moldovan Leu                             │
    ├───────────┼──────────────────────────────────────────┤
    │ MGA       │ Malagasy Ariary                          │
    ├───────────┼──────────────────────────────────────────┤
    │ MKD       │ Macedonian Denar                         │
    ├───────────┼──────────────────────────────────────────┤
    │ MMK       │ Myanmar Kyat                             │
    ├───────────┼──────────────────────────────────────────┤
    │ MNT       │ Mongolian Tugrik                         │
    ├───────────┼──────────────────────────────────────────┤
    │ MOP       │ Macanese Pataca                          │
    ├───────────┼──────────────────────────────────────────┤
    │ MRU       │ Mauritanian Ouguiya                      │
    ├───────────┼──────────────────────────────────────────┤
    │ MUR       │ Mauritian Rupee                          │
    ├───────────┼──────────────────────────────────────────┤
    │ MVR       │ Maldivian Rufiyaa                        │
    ├───────────┼──────────────────────────────────────────┤
    │ MWK       │ Malawian Kwacha                          │
    ├───────────┼──────────────────────────────────────────┤
    │ MXN       │ Mexican Peso                             │
    ├───────────┼──────────────────────────────────────────┤
    │ MYR       │ Malaysian Ringgit                        │
    ├───────────┼──────────────────────────────────────────┤
    │ MZN       │ Mozambican Metical                       │
    ├───────────┼──────────────────────────────────────────┤
    │ NAD       │ Namibian Dollar                          │
    ├───────────┼──────────────────────────────────────────┤
    │ NGN       │ Nigerian Naira                           │
    ├───────────┼──────────────────────────────────────────┤
    │ NIO       │ Nicaraguan Córdoba                       │
    ├───────────┼──────────────────────────────────────────┤
    │ NOK       │ Norwegian Krone                          │
    ├───────────┼──────────────────────────────────────────┤
    │ NPR       │ Nepalese Rupee                           │
    ├───────────┼──────────────────────────────────────────┤
    │ NZD       │ New Zealand Dollar                       │
    ├───────────┼──────────────────────────────────────────┤
    │ OMR       │ Omani Rial                               │
    ├───────────┼──────────────────────────────────────────┤
    │ PAB       │ Panamanian Balboa                        │
    ├───────────┼──────────────────────────────────────────┤
    │ PEN       │ Peruvian Sol                             │
    ├───────────┼──────────────────────────────────────────┤
    │ PGK       │ Papua New Guinean Kina                   │
    ├───────────┼──────────────────────────────────────────┤
    │ PHP       │ Philippine Piso                          │
    ├───────────┼──────────────────────────────────────────┤
    │ PKR       │ Pakistani Rupee                          │
    ├───────────┼──────────────────────────────────────────┤
    │ PLN       │ Polish Zloty                             │
    ├───────────┼──────────────────────────────────────────┤
    │ PND       │ PND                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ PRB       │ PRB                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ PYG       │ Paraguayan Guarani                       │
    ├───────────┼──────────────────────────────────────────┤
    │ QAR       │ Qatari Rial                              │
    ├───────────┼──────────────────────────────────────────┤
    │ RON       │ Romanian Leu                             │
    ├───────────┼──────────────────────────────────────────┤
    │ RSD       │ Serbian Dinar                            │
    ├───────────┼──────────────────────────────────────────┤
    │ RUB       │ Russian Ruble                            │
    ├───────────┼──────────────────────────────────────────┤
    │ RWF       │ Rwandan Franc                            │
    ├───────────┼──────────────────────────────────────────┤
    │ SAR       │ Saudi Riyal                              │
    ├───────────┼──────────────────────────────────────────┤
    │ SBD       │ Solomon Islands Dollar                   │
    ├───────────┼──────────────────────────────────────────┤
    │ SCR       │ Seychellois Rupee                        │
    ├───────────┼──────────────────────────────────────────┤
    │ SDG       │ Sudanese Pound                           │
    ├───────────┼──────────────────────────────────────────┤
    │ SEK       │ Swedish Krona                            │
    ├───────────┼──────────────────────────────────────────┤
    │ SGD       │ Singapore Dollar                         │
    ├───────────┼──────────────────────────────────────────┤
    │ SHP       │ St. Helena Pound                         │
    ├───────────┼──────────────────────────────────────────┤
    │ SLL       │ Sierra Leonean Leone                     │
    ├───────────┼──────────────────────────────────────────┤
    │ SLS       │ SLS                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ SOS       │ Somali Shilling                          │
    ├───────────┼──────────────────────────────────────────┤
    │ SRD       │ Surinamese Dollar                        │
    ├───────────┼──────────────────────────────────────────┤
    │ SSP       │ South Sudanese Pound                     │
    ├───────────┼──────────────────────────────────────────┤
    │ STN       │ São Tomé & Príncipe Dobra                │
    ├───────────┼──────────────────────────────────────────┤
    │ SYP       │ Syrian Pound                             │
    ├───────────┼──────────────────────────────────────────┤
    │ SZL       │ Swazi Lilangeni                          │
    ├───────────┼──────────────────────────────────────────┤
    │ THB       │ Thai Baht                                │
    ├───────────┼──────────────────────────────────────────┤
    │ TJS       │ Tajikistani Somoni                       │
    ├───────────┼──────────────────────────────────────────┤
    │ TMT       │ Turkmenistani Manat                      │
    ├───────────┼──────────────────────────────────────────┤
    │ TND       │ Tunisian Dinar                           │
    ├───────────┼──────────────────────────────────────────┤
    │ TOP       │ Tongan Paʻanga                           │
    ├───────────┼──────────────────────────────────────────┤
    │ TRY       │ Turkish Lira                             │
    ├───────────┼──────────────────────────────────────────┤
    │ TTD       │ Trinidad & Tobago Dollar                 │
    ├───────────┼──────────────────────────────────────────┤
    │ TVD       │ TVD                                      │
    ├───────────┼──────────────────────────────────────────┤
    │ TWD       │ New Taiwan Dollar                        │
    ├───────────┼──────────────────────────────────────────┤
    │ TZS       │ Tanzanian Shilling                       │
    ├───────────┼──────────────────────────────────────────┤
    │ UAH       │ Ukrainian Hryvnia                        │
    ├───────────┼──────────────────────────────────────────┤
    │ UGX       │ Ugandan Shilling                         │
    ├───────────┼──────────────────────────────────────────┤
    │ USD       │ US Dollar                                │
    ├───────────┼──────────────────────────────────────────┤
    │ UYU       │ Uruguayan Peso                           │
    ├───────────┼──────────────────────────────────────────┤
    │ UZS       │ Uzbekistani Som                          │
    ├───────────┼──────────────────────────────────────────┤
    │ VES       │ Venezuelan Bolívar                       │
    ├───────────┼──────────────────────────────────────────┤
    │ VND       │ Vietnamese Dong                          │
    ├───────────┼──────────────────────────────────────────┤
    │ VUV       │ Vanuatu Vatu                             │
    ├───────────┼──────────────────────────────────────────┤
    │ WST       │ Samoan Tala                              │
    ├───────────┼──────────────────────────────────────────┤
    │ XAF       │ Central African CFA Franc                │
    ├───────────┼──────────────────────────────────────────┤
    │ XCD       │ East Caribbean Dollar                    │
    ├───────────┼──────────────────────────────────────────┤
    │ XOF       │ West African CFA Franc                   │
    ├───────────┼──────────────────────────────────────────┤
    │ XPF       │ CFP Franc                                │
    ├───────────┼──────────────────────────────────────────┤
    │ YER       │ Yemeni Rial                              │
    ├───────────┼──────────────────────────────────────────┤
    │ ZAR       │ South African Rand                       │
    ├───────────┼──────────────────────────────────────────┤
    │ ZMW       │ Zambian Kwacha                           │
    ├───────────┼──────────────────────────────────────────┤
    │ ZWB       │ ZWB                                      │
    └───────────┴──────────────────────────────────────────┘

Run the following command in terminal to list all available currencies:

.. code-block:: shell

    valuta-list-currencies

Custom currencies
=================
To register a new custom currency, do as follows:

.. code-block:: python

    from valuta.base import BaseCurrency

    class XYZ(BaseCurrency):
        """XYZ - The XYZ currency."""

        uid: str = "XYZ"
        rate: int = 100_000_000

Generating currencies from a CSV dump
=====================================
If `list of circulating currencies`_ is ever updated, grab it the same way,
save as `list_of_circulating_currencies.csv` in the source and run the
following command:

.. code-block:: shell

    valuta-generate-currencies --skip-first-line

Testing
=======
Simply type:

.. code-block:: sh

    pytest -vvv

Or use tox:

.. code-block:: sh

    tox

Or use tox to check specific env:

.. code-block:: sh

    tox -e py39-django32

Writing documentation
=====================

Keep the following hierarchy.

.. code-block:: text

    =====
    title
    =====

    header
    ======

    sub-header
    ----------

    sub-sub-header
    ~~~~~~~~~~~~~~

    sub-sub-sub-header
    ^^^^^^^^^^^^^^^^^^

    sub-sub-sub-sub-header
    ++++++++++++++++++++++

    sub-sub-sub-sub-sub-header
    **************************

License
=======
GPL-2.0-only OR LGPL-2.1-or-later

Support
=======
For any issues contact me at the e-mail given in the `Author`_ section.

Author
======
Artur Barseghyan <artur.barseghyan@gmail.com>


