This tool is meant as a simple and naive way to manage invoices locally. It is not meant to be published online and used as an enterprise tool.
To run shiny-invoice
you need install it with:
pip install shiny-invoice
Once shiny-invoice
is installed you need to create configuration file.
A suitable default configuration can be generated with
shiny-invoice generate-default-config
Once everything is set up you can run shiny-invoice
with:
shiny-invoice run --config default_config.yaml
More information you can find with
shiny-invoice --help
shiny-invoice run --help
Execute the following line in a directory that has the config.yaml
file.
podman pull ghcr.io/dtrai2/shiny_invoice:latest
podman run -p 8000:8000 --volume .:/home/app -ti --rm shiny_invoice:latest run --config config.yaml
This application manages the invoices as plain html files, named by the invoice id.
To turn the html file into a pdf just use the browsers print functionality.
All the data corresponding to the invoices is stored inside a json file, which is configured with the key
paths.datastore
.
The json you can edit as you like, via the gui it is only possible to change the 'Paid At' value.
This value is also used to determine if in invoice is indeed 'Paid' or 'Unpaid'.