GUI for flinventory for viewing and editing inventory
Project description
flinventory GUI
A GUI for the flinventory project/ data format.
Run
Getting code:
git clone https://codeberg.org/flukx/flinventory-gui.git
Getting prerequisites:
-
cd flinventory-gui nix-shell
- conda (not sure if that still works)
sudo apt install pdf2svg texlive-full # or sudo dnf install texlive-scheme-full pdf2svg # for actually needed LaTeX packages see shell.nix # or whatever package manager you use conda create -f environment.yml conda activate bikeparts-gui pip install flinventory-gui
- or virtualenv:
sudo apt install pdf2svg texlive-full # or sudo dnf install texlive-scheme-full pdf2svg # for actually needed LaTeX packages see shell.nix # or whatever package manager you use python -m venv .venv source .venv/bin/activate pip install -r flinventory-gui
Getting data: git clone -b harzgerode-main https://codeberg.org/flukx/flings.git
Run it:
flinventory-webgui flings
It should open a browser with the search page. Otherwise, open localhost:11111 in your browser.
To see all options run python flinventory_gui/search.py --help but note that many of them are inherited
from the underlying module flinventory and are not used.
Rebuild during development
In the nix-shell, you can replace the flinventory-gui with the current version if you've changed something:
pdm build
pip install dist/flinventory_gui-...py3-none-any.whl --upgrade
# run again
flinventory-webgui flings
or just (and get changes pick-uped immediately)
python flinventory_gui/search.py flings
Making website accessible in local network
It's nice to use the thing search on the computer where it is run but often it's more helpful to
use it on other mobile devices. Therefore, you can make the search page available in the local network
by opening the port (by default 11111 in the firewall.)
In Fedora KDE I opened "Firewall" and in the Configuration "Runtime" in Tab "Zones" in zone "public" in tab "Ports"
added 11111 for protocol tcp.
In NixOS KDE I typed (for temporary access):
sudo iptables -A INPUT -p tcp --dport 11111 -j ACCEPT
sudo systemctl reload firewall
For permanent usage, use the configuration.nix with the line
networking.firewall.allowedTCPPorts = [ 11111 ];.
Data
The data directory is given as a mandatory command-line argument. Most of the content and structure of this data directory is described in the documentation of flinventory. Optional data that is not used by flinventory itself and therefore not described there, is:
- a directory
website_resources- with a favicon named
favicon.ico - and a directory
translatiowith translation files for the terms that are defined in the inventory and appear in the GUI, namely the level names in the schema. The file structure is that for the package i18nice, that is:thing_editor.de.yml(and withenor other languages):de: room: Raum from-left: von links level: Regalbrett workshop: Werkstatt
- with a favicon named
Development setup
with nix-shell
Run nix-shell and a nix-shell with the necessary python packages is created based on the shell.nix file.
Note that NiceGUI is unfortunately not available via nix-packages and therefore installed in a virtual environment with pip.
This virtual environment has the advantage that you can use it as a local interpreter for your IDE.
At least in pycharm it can be used.
Ideas for the future
- Somehow really make the search async. Since filtering the correct parts and displaying them
has no waiting periods (with
await) it cannot really be cancelled.- Also helpful: show only 10 best results.
- Add filter for search that shows a bike where you can click on parts. And then only parts that are
"part_of" this are shown. When clicked on the brakes, it shows a list of brake types (sub categories)
that you can click on again. Interactive image
could be helpful.
- Make this filter keyboard accessible. Ctrl+F activates choice, then letter chooses something which is marked in the text on the bike picture.
- Figure out why sometimes the page reloads completely.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file flinventory_gui-0.10.0.tar.gz.
File metadata
- Download URL: flinventory_gui-0.10.0.tar.gz
- Upload date:
- Size: 23.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.24.1 CPython/3.12.10 Linux/6.12.32
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
363a1d43960c3540d8d6c73e2282e682966c04ea84dd3f425555ebfbc477e298
|
|
| MD5 |
853c004ec50795a848e589c868a6e60e
|
|
| BLAKE2b-256 |
7d31eac9ae81df5c8fc4eda73af2939fefc8f527d97c44b9202252a203e7ce71
|
File details
Details for the file flinventory_gui-0.10.0-py3-none-any.whl.
File metadata
- Download URL: flinventory_gui-0.10.0-py3-none-any.whl
- Upload date:
- Size: 25.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.24.1 CPython/3.12.10 Linux/6.12.32
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d073c9809116e73fbee158061f01e4de871b943f136e24e5019bd95a4ff14383
|
|
| MD5 |
4c65e2d31ea3f8638e90bf1c6734681b
|
|
| BLAKE2b-256 |
6bccbd68466a84f50239c7ce819c9a6df7856fa3e24b467d7d1a7ecfaee66e71
|