Awesome
<h1 align="center"> Python Concur </h1> <p align="center"> <img src="https://raw.githubusercontent.com/ajnsit/purescript-concur/master/docs/logo.png" height="100"> </p>Concur is a Python GUI framework based on synchronous generators.
It is a port of Concur for Purescript, implemented on top of the Dear ImGui C++ UI library.
For introduction to core concepts, see the documentation. A more comprehensive introduction can be found in the Documentation for the Haskell/Purescript versions. This obviously uses Haskell/Purescript syntax and semantics, but many of the concepts will apply to the Python version.
Being an abstraction over ImGui, Concur is best used for debugging, prototyping and data analysis, rather than user-facing applications. ImGui functions can be used directly for any functionality that is not wrapped by Concur. See the PyImGui docs for additional widgets, or ImGui itself if you need to poke really deep.
Installation
The only dependencies are a C++ compiler, GLFW and Python >= 3.6. GLFW is included in major Linux distros, and there are pre-compiled binaries for Windows and OS X.
sudo apt install libglfw3-dev # Ubuntu
sudo pacman -S glfw # Arch
Concur can be installed using pip:
pip install concur
This command should produce a very simple GUI app:
python -c 'import concur as c; c.main(c.button("Close"))'
See the introductory tutorial to get started, or use any of the examples as a starting point for your app.
Development
For Concur development, clone the repo and install it using pip:
git clone https://github.com/potocpav/python-concur.git
cd python-concur
pip install -e.
examples/all.py # Run the examples to verify installation
To run the tests, you need PyTest and PyTest-benchmark:
pip install pytest pytest-benchmark
pytest # Run the tests
To build documentation, install pdoc3 (pip install pdoc3
), clone the submodules (git submodule update --init
), and run the script ./mkdocs.sh
.