Metadata-Version: 2.1
Name: cli-ui
Version: 0.10.3
Summary: Build Nice User Interfaces In The Terminal
Author: Dimitri Merejkowsky
Author-email: d.merej@gmail.com
Requires-Python: >=3.5,<4.0
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Requires-Dist: colorama (>=0.4.1,<0.5.0)
Requires-Dist: tabulate (>=0.8.3,<0.9.0)
Requires-Dist: unidecode (>=1.0.23,<2.0.0)
Description-Content-Type: text/x-rst

python-cli-ui
=============

Tools for nice user interfaces in the terminal.

.. image:: https://img.shields.io/travis/TankerHQ/python-cli-ui.svg?branch=master
  :target: https://travis-ci.org/TankerHQ/python-cli-ui

.. image:: https://img.shields.io/pypi/pyversions/cli-ui.svg
  :target: https://pypi.org/project/cli-ui

.. image:: https://img.shields.io/pypi/v/cli-ui.svg
  :target: https://pypi.org/project/cli-ui/

.. image:: https://img.shields.io/github/license/TankerHQ/python-cli-ui.svg
  :target: https://github.com/TankerHQ/python-cli-ui/blob/master/LICENSE


Documentation
-------------


See `python-cli-ui documentation <https://TankerHQ.github.io/python-cli-ui>`_.

Demo
----


Watch the `asciinema recording <https://asciinema.org/a/112368>`_.


Usage
-----

.. code-block:: console

    $ pip install cli-ui

Example:

.. code-block:: python

    import cli_ui

    # coloring:
    cli_ui.info(
      "This is",
      cli_ui.red, "red", cli_ui.reset,
      "and this is",
      cli_ui.bold, "bold"
    )

    # enumerating:
    list_of_things = ["foo", "bar", "baz"]
    for i, thing in enumerate(list_of_things):
        cli_ui.info_count(i, len(list_of_things), thing)

    # progress indication:
    cli_ui.info_progress("Done",  5, 20)
    cli_ui.info_progress("Done", 10, 20)
    cli_ui.info_progress("Done", 20, 20)

    # reading user input:
    with_sugar = cli_ui.ask_yes_no("With sugar?", default=False)

    fruits = ["apple", "orange", "banana"]
    selected_fruit = cli_ui.ask_choice("Choose a fruit", choices=fruits)

    #  ... and more!

