Skip to main content

GUI sdk for Ubo Pod

Project description

Ubo GUI

GUI sdk for Ubo Pod

📋 Requirements

📦 Installation

You can install it using this handle: headless-kivy-pi@git+https://github.com/ubopod/ubo-gui.git

# pip:
pip install headless-kivy-pi@git+https://github.com/ubopod/ubo-gui.git
# poetry:
poetry add headless-kivy-pi@git+https://github.com/ubopod/ubo-gui.git

🛠 Usage

Checkout Ubo App to see a sample implementation.

🤝 Contributing

You need to have Poetry installed on your machine.

To install poetry in Raspbian you need to follow these instructions to install rust compiler, this is temporary until this issue is resolved:

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
sudo apt-get install pkg-config libssl-dev
curl -sSL https://install.python-poetry.org | python3 -

After having poetry, to install the required dependencies, run the following command:

poetry install --with dev

Also be aware of this issue and until it is resolved you can manually disable keyring by prefixing your poetry commands like this:

PYTHON_KEYRING_BACKEND=keyring.backends.null.Keyring poetry install

You can run linter over whole codebase by running this command:

poetry run poe lint

Subscriptions

The subscriptions are divided into three groups:

  • Screen subscriptions are those assigned to a particular stack item, but their handlers doesn't change anything in the StackItem itself. The handler just changes something on the rendered screen and if that stack item is not visible, the handler doesn't need to be called. Therefore these subscriptions are cleared when the current screen is changed. Samples:
    • items of the currently visible menu
    • title of the currently visible screen
  • Menu subscriptions are those assigned to a particular menu. Like screen subscriptions, they are cleared when the current screen is changed. They also get cleared when the menu is scrolled. Samples:
    • heading of a headed menu
    • sub_heading of a headed menu
    • placeholder of a menu
  • Stack item subscriptions are those assigned to a particular stack item. They are cleared when the stack item is popped. They stay alive as long as the stack item is in the stack, even if it is in the background. In other words, unlike the other two, they are not cleared when, for example, a sub-menu or an application is opened on top of the current stack item. Samples:
    • menu of an item

⚠️ Important Note

Make sure to run poetry run poe download_font to download Material Symbols font.

🔒 License

This project is released under the Apache-2.0 License. See the LICENSE file for more details.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

Built Distribution

File details

Details for the file ubo_gui-0.13.7.dev1241030103555355981015698.tar.gz.

File metadata

File hashes

Hashes for ubo_gui-0.13.7.dev1241030103555355981015698.tar.gz
Algorithm Hash digest
SHA256 d57dda63d3625848cd0dbb1b914f295dfb80ac24e2e867b9d1f3238dfb860beb
MD5 4c50cc2ed09b28bf59b65715e88516e5
BLAKE2b-256 98124ad6de138acfbbae68d527ce5861920c509fc1c2273b562e8dd34a29603d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ubo_gui-0.13.7.dev1241030103555355981015698.tar.gz:

Publisher: GitHub
  • Repository: ubopod/ubo-gui
  • Workflow: integration_delivery.yml
Attestations:
  • Statement type: https://in-toto.io/Statement/v1
    • Predicate type: https://docs.pypi.org/attestations/publish/v1
    • Subject name: ubo_gui-0.13.7.dev1241030103555355981015698.tar.gz
    • Subject digest: d57dda63d3625848cd0dbb1b914f295dfb80ac24e2e867b9d1f3238dfb860beb
    • Transparency log index: 145023891
    • Transparency log integration time:

File details

Details for the file ubo_gui-0.13.7.dev1241030103555355981015698-py3-none-any.whl.

File metadata

File hashes

Hashes for ubo_gui-0.13.7.dev1241030103555355981015698-py3-none-any.whl
Algorithm Hash digest
SHA256 2a84bedf091112487ced4f62a2665420da2b7d246e50c812f6d682dac884a571
MD5 cc204999319f40dc2102682680281f95
BLAKE2b-256 c552a05319c9fb5fab89bca853e7504094daca05958673ba4759fe926f9cb422

See more details on using hashes here.

Provenance

The following attestation bundles were made for ubo_gui-0.13.7.dev1241030103555355981015698-py3-none-any.whl:

Publisher: GitHub
  • Repository: ubopod/ubo-gui
  • Workflow: integration_delivery.yml
Attestations:
  • Statement type: https://in-toto.io/Statement/v1
    • Predicate type: https://docs.pypi.org/attestations/publish/v1
    • Subject name: ubo_gui-0.13.7.dev1241030103555355981015698-py3-none-any.whl
    • Subject digest: 2a84bedf091112487ced4f62a2665420da2b7d246e50c812f6d682dac884a571
    • Transparency log index: 145023892
    • Transparency log integration time:

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page