Declarative Tkinter UI using makup language with reactive data binding.
TKVue bring familiar advantages in web development to traditional development. This project allow you to create modern graphical user interface written in Python using Tkinter library.
TKVue provide a declarative language to build user interface with Markup language.
<Label text="Hello world!" />
TKVue provide databinding to quickly make your graphical user interface dynamic.
<ComboBox pack-side="left" pack-expand="1" values="['zero', 'one', 'two', 'three']" textvariable="{{ myvariable }}" />
<Label text="{{ myvariable }}" />
TKVue provide a babel entry point to support internationalization.
babel.cfg
:
[tkvue: **/templates/**.tkml]
TKVue is available on pypi and can be installed using pip
.
pip install tkvue
Once installed you may take a look at various examples available:
https://gitlab.com/ikus-soft/tkvue/-/tree/master/doc/examples
Help is welcome to write proper documentation about how to use TKVue.
If you need help or experience problem while using TKvue, open a ticket in Gitlab.
Once you have customize the Tkinter themes, the result could be astonishing. Here the result of Minarca interface build using TKVue.
Tkvue provide a babel extention to extract static text from xml template.
You must configure babel to use the right plugin to extract the values from the templates.
babel.cfg:
[tkvue: **/templates/**.tkml]
Then You may use babel and other gettext tools to complete the translation using the .po
file.
python setup.py extract_messages
Other Tkinter-related projects worth mentioning:
- witkets: Create Tkinter interface using XML similar to TKVue
- ttkbootstrap: Theme extension for tkinter inspire by Bootstrap
- Define minimum height for ScrolledFrame.
- Fix display of scrollbar in ScrolledFrame when resize on Y axis.
- Fix display of scrollbar on initialization.
- Add many examples for self documentation
- Provide the
@tkvue.widget
annotation to register a new widget. - Provide the
@tkvue.attr
annotation to register the custom attributes of the widget.
- Support
resizable
attribute on TopLevel not_resizable.py - Support
theme
attribute on TopLevel theme.py
- Add example to demonstrate usage of variables dynamic.py
- Add example to demonstrate usage of
visible=
attribute to show or hide widget dynamic_visible.py - Add example to demonstrate usage of
for=
attribute to create list of widget dynamic_loop.py - Add example to demonstrate style customization color.py
- Support assignment of
None
to<Label image="..." >
to hide image animated_gif.py - Add example to demonstrate usage of
<Progressbar>
progressbar.py
- Implement mainloop using asyncio to avoid multi-threading #1
- Increase default offset when displaying
<Tooltip>
to avoid flikering when user hover a widget <ScrolledFrame>
inherit the background color from the style- Show or hide scroll bar of
<ScrolledFrame>
when needed - Pin version of black, isort and flake8
- Add support for
place
geometry manager
- Fix license badge
- Declare babel entry point for translation
- Add combobox example
- Use private gitlab runner for running test
- Initial version of TKVue writting for Minarca project