3.6 KiB
Introduction
Mia! Accounting is an accounting module for Flask applications. It implements double-entry bookkeeping, and generates the following accounting reports:
- Trial balance
- Income statement
- Balance sheet
In addition, Mia! Accounting tracks offsets for unpaid payables and receivables.
Installation
Install Mia! Accounting with pip:
pip install mia-accounting
You may also download the from the PyPI project page or the release page on the Git repository.
Test Site and Live Demonstration
You may find a working example in the test site in the source distribution. It is the simplest website that works with Mia! Accounting. It is used in the automatic tests. It is the same code run for live demonstration.
If you do not have a running Flask application or do not know how to start one, you may start with the test site.
Prerequisites
You need a running Flask application with database user login. The primary key of the user data model must be integer. You also need at least one user.
The following front-end JavaScript libraries must be loaded. You may download it locally or use CDN.
- Bootstrap 5.2.3 or above
- FontAwesome 6.2.1 or above
- Decimal.js 6.4.3 or above
- Tempus-Dominus 6.4.3 or above
Configuration
You need to pass the Flask app and an implementation of :py:class:`accounting.utils.user.UserUtilityInterface` to the :py:func:`accounting.init_app` function. UserUtilityInterface contains everything Mia! Accounting needs.
System Message: ERROR/3 (<stdin>, line 60); backlink
Unknown interpreted text role "py:class".System Message: ERROR/3 (<stdin>, line 60); backlink
Unknown interpreted text role "py:func".See an example in :ref:`example-userutils`.
System Message: ERROR/3 (<stdin>, line 65); backlink
Unknown interpreted text role "ref".Database Initialization
After the configuration, run the accounting-init-db console command to initialize the accounting database. You need to specify the username of a user as the data creator.
% flask --app myapp accounting-init-db -u username
Documentation
Refer to the documentation on Read the Docs.