Skip to content

Commit

Permalink
v0.7.1 (#235)
Browse files Browse the repository at this point in the history
* Relaxing Dependency Constraints

* Issue 208 ofx files (#209)

* fix: initial attempt

* Allow .qfx files in data_import form.

The accept attribute in the file-input field now includes .qfx files. This permits users to import data from files in .qfx format in addition to the previously supported .ofx format.

* remove debugging lines, remove debug code, add sample ofx for tests

---------

Co-authored-by: Miguel Sanda <[email protected]>

* v0.6.3 (#214)

* Add proxy functions to JournalEntry model

The commit introduces proxy functions to the JournalEntry model in the Django Ledger code. Specifically, it adds 'post', 'unpost', 'lock', and 'unlock' methods, each serving as a proxy to their counterpart methods 'mark_as_posted', 'mark_as_unposted', 'mark_as_locked', and 'mark_as_unlocked'. This simplifies the interface for interacting with JournalEntry objects.

* Minor code optimization & Django Ledger admin fields.

* access the queryset instance using .all() which returns a queryset. (#213)

* Correct urls for going back in entity and ledger balance sheet view (#215)

* Add signal handling for various models' statuses

Added signals for different status changes of Django Ledger models to enable real-time, event-driven system behavior. Signals are now sent each time an action is performed in the Ledger, Invoice, Bill, Journal Entry, Purchase Order, and Estimate. These changes will allow us to trigger specific actions depending on these changes.

* Update Python version and package versions in Pipfile

Updated the Python version from 3.11 to 3.12 in Pipfile and Pipfile.lock. Also, updated the package versions of 'django', 'faker' and 'pillow' in Pipfile.lock for improved functionality and security.

* Update Django Ledger version to 0.6.3

This commit updates the version number of the Django Ledger project in both __init__.py and pyproject.toml files. The version has been incremented from 0.6.2 to 0.6.3.

* Update signal comments in models

Updated the comments in the signals.py file to clearly specify that the signals correspond to Journal Entry Models. Additional context was also included for the signals module to enhance clarity for developers in understanding the importance of events or states in the models.

* Update documentation structure

Rearrange sections in documentation, focusing on IO and models. For docs/source/models.rst, the automodule section for django_ledger.models.signals was added. Meanwhile, in docs/source/io.rst, sections were reshuffled and terms updated for better clarity. These steps aim to enhance documentation readability and accuracy.

---------

Co-authored-by: Eric paul <[email protected]>
Co-authored-by: Ubaid ur Rehman <[email protected]>

* Update dependencies versions in Pipfile.lock

Upgraded several packages to their latest versions, including Faker, Alabaster, and SQLParse, among others. Added new dependencies appnope and backports.tarfile, and adjusted Python version markers for some packages. Removed cryptography and jeepney from the list of dependencies.

* Updated Logos

* comment out attribute that doesn't exist (#220)

* Docker Fix (#218)

* Update version to 0.6.4

Bump the version number in `__init__.py` and `pyproject.toml`. This update ensures consistency and readiness for the next release cycle.

* API authentication (#217)

* access the queryset instance using .all() which returns a queryset.

* fixed invalid client

* changes in API authentication usage

* API Authentication usage

* Add DjangoCon2024 Jupyter notebook example

Introduced a detailed Jupyter notebook for DjangoCon 2024. This notebook demonstrates various functionalities including setting up Django, creating a UserModel, defining an EntityModel, and creating and populating a Chart of Accounts.

* Update entity model CoA handling and streamline notebook

Enhanced the entity model to handle various types for CoA (Chart of Accounts) input. Cleared execution counts and outputs from DjangoCon2024 notebook for better clarity.

* Add support for validating parent roles in accounts

Implemented `VALID_PARENTS` to allow filtering accounts based on hierarchical roles. This ensures that parent-child relationships between account roles are correctly validated and managed.

* Pipfile Update

* Refactor and improve docs for AccountModel and QuerySets

Refactored and enhanced documentation for AccountModel and its related query sets to ensure clarity and consistency. Introduced detailed attribute descriptions and method explanations while maintaining code functionality.

* Add net income computation to IO middleware

Introduced a new `net_income` method to calculate and store net income as part of the IO_DATA digest process. Updated the `digest` method to include the net income calculation step. This enhances the financial reporting capabilities of the middleware.

* v0.7.0 (#226)

* v0.6.4 (#223)

* Relaxing Dependency Constraints

* Issue 208 ofx files (#209)

* fix: initial attempt

* Allow .qfx files in data_import form.

The accept attribute in the file-input field now includes .qfx files. This permits users to import data from files in .qfx format in addition to the previously supported .ofx format.

* remove debugging lines, remove debug code, add sample ofx for tests

---------

Co-authored-by: Miguel Sanda <[email protected]>

* v0.6.3 (#214)

* Add proxy functions to JournalEntry model

The commit introduces proxy functions to the JournalEntry model in the Django Ledger code. Specifically, it adds 'post', 'unpost', 'lock', and 'unlock' methods, each serving as a proxy to their counterpart methods 'mark_as_posted', 'mark_as_unposted', 'mark_as_locked', and 'mark_as_unlocked'. This simplifies the interface for interacting with JournalEntry objects.

* Minor code optimization & Django Ledger admin fields.

* access the queryset instance using .all() which returns a queryset. (#213)

* Correct urls for going back in entity and ledger balance sheet view (#215)

* Add signal handling for various models' statuses

Added signals for different status changes of Django Ledger models to enable real-time, event-driven system behavior. Signals are now sent each time an action is performed in the Ledger, Invoice, Bill, Journal Entry, Purchase Order, and Estimate. These changes will allow us to trigger specific actions depending on these changes.

* Update Python version and package versions in Pipfile

Updated the Python version from 3.11 to 3.12 in Pipfile and Pipfile.lock. Also, updated the package versions of 'django', 'faker' and 'pillow' in Pipfile.lock for improved functionality and security.

* Update Django Ledger version to 0.6.3

This commit updates the version number of the Django Ledger project in both __init__.py and pyproject.toml files. The version has been incremented from 0.6.2 to 0.6.3.

* Update signal comments in models

Updated the comments in the signals.py file to clearly specify that the signals correspond to Journal Entry Models. Additional context was also included for the signals module to enhance clarity for developers in understanding the importance of events or states in the models.

* Update documentation structure

Rearrange sections in documentation, focusing on IO and models. For docs/source/models.rst, the automodule section for django_ledger.models.signals was added. Meanwhile, in docs/source/io.rst, sections were reshuffled and terms updated for better clarity. These steps aim to enhance documentation readability and accuracy.

---------

Co-authored-by: Eric paul <[email protected]>
Co-authored-by: Ubaid ur Rehman <[email protected]>

* Update dependencies versions in Pipfile.lock

Upgraded several packages to their latest versions, including Faker, Alabaster, and SQLParse, among others. Added new dependencies appnope and backports.tarfile, and adjusted Python version markers for some packages. Removed cryptography and jeepney from the list of dependencies.

* Updated Logos

* comment out attribute that doesn't exist (#220)

* Docker Fix (#218)

* Update version to 0.6.4

Bump the version number in `__init__.py` and `pyproject.toml`. This update ensures consistency and readiness for the next release cycle.

* API authentication (#217)

* access the queryset instance using .all() which returns a queryset.

* fixed invalid client

* changes in API authentication usage

* API Authentication usage

* Add DjangoCon2024 Jupyter notebook example

Introduced a detailed Jupyter notebook for DjangoCon 2024. This notebook demonstrates various functionalities including setting up Django, creating a UserModel, defining an EntityModel, and creating and populating a Chart of Accounts.

* Update entity model CoA handling and streamline notebook

Enhanced the entity model to handle various types for CoA (Chart of Accounts) input. Cleared execution counts and outputs from DjangoCon2024 notebook for better clarity.

* Add support for validating parent roles in accounts

Implemented `VALID_PARENTS` to allow filtering accounts based on hierarchical roles. This ensures that parent-child relationships between account roles are correctly validated and managed.

* Pipfile Update

* Refactor and improve docs for AccountModel and QuerySets

Refactored and enhanced documentation for AccountModel and its related query sets to ensure clarity and consistency. Introduced detailed attribute descriptions and method explanations while maintaining code functionality.

---------

Co-authored-by: Tom Hodder <[email protected]>
Co-authored-by: Eric paul <[email protected]>
Co-authored-by: Ubaid ur Rehman <[email protected]>
Co-authored-by: Krzysztof Czapla <[email protected]>

* Add logo and update documentation for Django Ledger CoA

This commit adds the Django Ledger logo to the Jupyter notebook and reworks the documentation for the Chart of Accounts (CoA) section. It also updates type imports, adjusts outputs, and includes explanations for handling multiple CoA and sample data population.

* Ui Icons Fix
Subscription ID on UI
Wallet Create Mutation
Sidebar Simplification

* Update to version 0.6.5 and add account lock/unlock methods

Bumped the project version to 0.6.5 and added Django 5.0 framework classifier. Enhanced AccountModel by introducing methods to lock and unlock accounts with validation. Simplified the get_queryset method for item views.

* Update to version 0.6.5 and add account lock/unlock methods

Bumped the project version to 0.6.5 and added Django 5.0 framework classifier. Enhanced AccountModel by introducing methods to lock and unlock accounts with validation. Simplified the get_queryset method for item views.

* Add `allow_empty` attribute and fix sales tax rate help text

Enable empty ledger list handling in LedgerModelListView by setting `allow_empty` to True. Additionally, update the help text for the sales tax rate field to correct the example conversion factor.

* Refactor queryset initialization in item views

Updated the get_queryset methods to use the AUTHORIZED_ENTITY_MODEL attribute for fetching related models instead of directly invoking model managers. This change improves code consistency and leverages the new entity model for querying related objects. Removed an outdated comment from the items.py model file.

* Add 'active' filter to queries and reorganize docstrings

Enhanced vendor and customer queries with an 'active' filter for better data accuracy. Also, standardized contribution docstrings across multiple files and updated the EstimateModel queryset to use the `AUTHORIZED_ENTITY_MODEL`.

* Update view mixins and clean up docstrings

Replaced security mixins with specific view mixins across multiple views to streamline authorization logic. Additionally, cleaned up and standardized docstrings in several modules.

* Rename model view mixins for better consistency

Replaced *ModelViewQuerySetMixIn class names with *ModelBaseView across multiple modules. This change improves naming clarity and consistency in the project's codebase.

* Add entity-based filtering and queryset improvements

Refactor multiple classes to enhance entity-based filtering and queryset handling. Streamline vendor and account queries, improve code readability, and consolidate security checks.

- Optimize AccountModel forms and remove unnecessary arguments
- Enhance AccountModel views to inherit from a base view and add select_related fields to view querysets, minimizing database queries during template rendering
- Implement AccountModel navigation URLs as model methods and annotate default AccountModel queryset with necessary relevant information
- Replace unique_together Meta option with constraints option on the AccountModel to conform with new API
- Add coa_slug as mandatory kwarg on all AccountModel-related views.

* Format code for readability and remove redundant methods

Reformatted various parts of the code for better readability by breaking long lines and ensuring consistent indentation. Additionally, removed redundant methods `with_roles` and `with_roles_available` from `models/accounts.py` to clean up unnecessary code.

* Simplify and format README.md for better readability

Condensed the README by removing verbose descriptions and reformatting key sections. Enhanced navigation with clear links to Discord, documentation, and the QuickStart Notebook, and streamlined the list of features for clarity.

* Update invoice detail URLs to include coa_slug parameter

Added the 'coa_slug' parameter to account-detail URLs in the invoice detail template to ensure proper linkage to the chart of accounts model. Updated the view to prefetch related coa_model fields for cash, prepaid, and unearned accounts.

* Reformat `with_roles` method calls for readability

Improve readability by reformatting `with_roles` method calls to use multiline styling consistently. This change enhances code maintainability without affecting functionality. It should make the nested roles easier to read and modify in the future.

* Refactor initialization logic in Bill forms

Replace individual entity and user model parameters with a single entity model parameter in BillModelCreateForm and BaseBillItemTransactionFormset. This simplifies querysets and improves code readability by leveraging direct relationships.

* Refactor bill views and forms with new base view

Refactored multiple components in `bill.py` to streamline and simplify the code by introducing `BillModelModelBaseView`. Replaced repeated logic for querying BillModel instances and standardized the creation and updating of forms.

* Add "Is Active" column to expense table and update account URLs

Added an "Is Active" column to the expense item table to indicate the status of expense items. Updated account detail URLs in bill detail template to include the chart of accounts slug for accurate link resolution.

* Account Model QuerySets optimization.

Update entity_slug to entity_model in various files

Replaces 'entity_slug' with 'entity_model' for better consistency and clarity across forms, views, and notebooks. This change also introduces the handling of ObjectDoesNotExist within notebooks and improves the use of queryset filtering.

* Refactor account tests and form ID handling

Added account management tests, including view protection and creation. Introduce form ID generation in account creation forms and implement utility methods for URL pattern resolution in tests.

* Add account activation and locking tests

Implemented tests for account activation and locking functionalities, including the ability to lock, unlock, activate, and deactivate accounts. Also updated the `get_coa_accounts` method to filter by locked status.

* Update `get_random_account` to filter by active and locked status

Add parameters to filter accounts based on their active and locked status. This enhances the function's flexibility and ensures more precise query results.

* Update execution timestamps in DjangoCon2024 notebook

Updated metadata execution timestamps throughout the DjangoCon2024 notebook to reflect the current date. Also added a note emphasizing a limitation in executing a particular code snippet within a Jupyter notebook.

* Add lock/unlock actions and COA active check in accounts

Introduced methods to generate lock/unlock URLs in the Account model, along with corresponding URL patterns. Added `is_coa_active` to check the COA active status, updating `can_activate` to utilize this check.

* Add lock status and actions to accounts table

Added a new column to display the lock status of each account and incorporated conditional icons to visually indicate if an account is locked or unlocked. Additionally, added actions in the dropdown menu to lock and unlock accounts based on the account's current state.

* Documentation Update

* Add new account model tests and refactor imports

Introduce tests for account annotations and transaction capabilities to ensure accurate entity associations and transaction status checks. Refactor import statements to remove unused `DEBIT` import and improve code readability with minor reformatting.

* Refactor AUTHORS.md for better organization

Reorganize sections in AUTHORS.md to separate Developers, Contributors, and Documentation Contributors for better clarity.

* Update README and contribution guidelines

Expanded the contact section in README for better clarity. Revised the Contribute.md file to include detailed guidelines, ensuring clarity on contribution processes and standards.

* v0.7.0

---------

Co-authored-by: Tom Hodder <[email protected]>
Co-authored-by: Eric paul <[email protected]>
Co-authored-by: Ubaid ur Rehman <[email protected]>
Co-authored-by: Krzysztof Czapla <[email protected]>

* V0.7.1 (#234)

* v0.7.1
Chart of Accounts Model create views and forms.
New inactive Chart of Accounts views.
Balance Sheet Report bugfixes and template organizations.
Chart of Accounts Model default queryset optimization.
Entity Model Chart of Accounts list/create URLs.
Footer information update.
DjangoLedgerSecurityMixIn context now incorporates Authorized Entity Model.

* v0.7.1
Django Ledger Model extension capabilities and customization using django settings.

* v0.7.1
Implementing Swappable Model base functionality.

* Add COA validation and annotate `coa_id` for transactions

Ensure transactions belong to a single Chart of Accounts (COA) in `is_txs_qs_coa_valid`. Extend queryset with `coa_id` annotation for better query performance and add a corresponding property to the transaction model. These changes enhance consistency and validation when handling journal entries and transactions.

---------

Co-authored-by: Tom Hodder <[email protected]>
Co-authored-by: Eric paul <[email protected]>
Co-authored-by: Ubaid ur Rehman <[email protected]>
Co-authored-by: Krzysztof Czapla <[email protected]>
  • Loading branch information
5 people authored Dec 26, 2024
1 parent 93ba724 commit e162284
Show file tree
Hide file tree
Showing 44 changed files with 671 additions and 270 deletions.
2 changes: 1 addition & 1 deletion django_ledger/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
default_app_config = 'django_ledger.apps.DjangoLedgerConfig'

"""Django Ledger"""
__version__ = '0.7.0'
__version__ = '0.7.1'
__license__ = 'GPLv3 License'

__author__ = 'Miguel Sanda'
Expand Down
2 changes: 1 addition & 1 deletion django_ledger/admin/__init__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from django.contrib import admin

from django_ledger.admin.coa import ChartOfAccountsModelAdmin
from django_ledger.admin.chart_of_accounts import ChartOfAccountsModelAdmin
from django_ledger.admin.entity import EntityModelAdmin
from django_ledger.admin.ledger import LedgerModelAdmin
from django_ledger.models import EntityModel, ChartOfAccountModel, LedgerModel
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
from django.forms import ModelForm, BooleanField, BaseInlineFormSet

from django_ledger.models.accounts import AccountModel
from django_ledger.models.coa import ChartOfAccountModel
from django_ledger.models.chart_of_accounts import ChartOfAccountModel
from django_ledger.models.entity import EntityModel


Expand Down
2 changes: 1 addition & 1 deletion django_ledger/admin/entity.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
from django.urls import reverse
from django.utils.html import format_html

from django_ledger.admin.coa import ChartOfAccountsInLine
from django_ledger.admin.chart_of_accounts import ChartOfAccountsInLine
from django_ledger.io.io_core import get_localtime
from django_ledger.models import EntityUnitModel
from django_ledger.models.entity import EntityModel, EntityManagementModel
Expand Down
2 changes: 1 addition & 1 deletion django_ledger/forms/account.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def __init__(self, coa_model: ChartOfAccountModel, *args, **kwargs):
self.fields['role'].choices = ACCOUNT_CHOICES_NO_ROOT
self.fields['code'].required = False
self.fields['coa_model'].disabled = True
self.fields['coa_model'].required = False
self.fields['coa_model'].required = True

self.form_id: str = self.get_form_id()

Expand Down
2 changes: 2 additions & 0 deletions django_ledger/forms/bank_account.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ def __init__(self, *args, entity_slug, user_model, **kwargs):
super().__init__(*args, **kwargs)
self.ENTITY_SLUG = entity_slug
self.USER_MODEL = user_model

# todo: only the accounts that do not hava an associated bank account should be available to pick from...
account_qs = AccountModel.objects.for_entity(
user_model=self.USER_MODEL,
entity_model=self.ENTITY_SLUG
Expand Down
82 changes: 82 additions & 0 deletions django_ledger/forms/chart_of_accounts.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
from random import randint

from django.forms import ModelForm, TextInput, Textarea, HiddenInput
from django.utils.translation import gettext_lazy as _

from django_ledger.models.chart_of_accounts import ChartOfAccountModel
from django_ledger.models.entity import EntityModel
from django_ledger.settings import DJANGO_LEDGER_FORM_INPUT_CLASSES


class ChartOfAccountsModelCreateForm(ModelForm):
FORM_ID_SEP = '___'

def __init__(self, entity_model: EntityModel, *args, **kwargs):
self.ENTITY_MODEL = entity_model
super().__init__(*args, **kwargs)
self.fields['entity'].disabled = True
self.fields['entity'].required = True
self.form_id: str = self.get_form_id()

def clean_entity(self):
return self.ENTITY_MODEL

def get_form_id(self) -> str:
return f'coa-model-create-form-{self.ENTITY_MODEL.slug}{self.FORM_ID_SEP}{randint(100000, 999999)}'

class Meta:
model = ChartOfAccountModel
fields = [
'entity',
'name',
'description'
]
labels = {
'name': _('Name'),
'description': _('Description'),
}
widgets = {
'entity': HiddenInput(),
'name': TextInput(
attrs={
'class': DJANGO_LEDGER_FORM_INPUT_CLASSES
}),
'description': Textarea(
attrs={
'class': DJANGO_LEDGER_FORM_INPUT_CLASSES
}
),
}


class ChartOfAccountsModelUpdateForm(ModelForm):

FORM_ID_SEP = '___'

def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.form_id: str = self.get_form_id()


def get_form_id(self) -> str:
instance: ChartOfAccountModel = self.instance
return f'coa-model-update-form-{instance.slug}{self.FORM_ID_SEP}{randint(100000, 999999)}'

class Meta:
model = ChartOfAccountModel
fields = [
'name',
'active'
]
labels = {
'name': _('Name'),
'description': _('Description'),
}
widgets = {
'name': TextInput(attrs={
'class': DJANGO_LEDGER_FORM_INPUT_CLASSES
}),
'description': Textarea(attrs={
'class': DJANGO_LEDGER_FORM_INPUT_CLASSES
}),
}
47 changes: 0 additions & 47 deletions django_ledger/forms/coa.py

This file was deleted.

2 changes: 1 addition & 1 deletion django_ledger/io/io_library.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@

from django_ledger.io.io_core import get_localtime
from django_ledger.models.accounts import AccountModel, AccountModelQuerySet, CREDIT, DEBIT
from django_ledger.models.coa import ChartOfAccountModel
from django_ledger.models.chart_of_accounts import ChartOfAccountModel
from django_ledger.models.entity import EntityModel
from django_ledger.models.ledger import LedgerModel, LedgerModelQuerySet

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Generated by Django 5.1.2 on 2024-11-20 22:26

import django.db.models.deletion
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('django_ledger', '0017_alter_accountmodel_unique_together_and_more'),
]

operations = [
migrations.AddField(
model_name='transactionmodel',
name='cleared',
field=models.BooleanField(default=False, verbose_name='Cleared'),
),
migrations.AddField(
model_name='transactionmodel',
name='reconciled',
field=models.BooleanField(default=False, verbose_name='Reconciled'),
),
migrations.AlterField(
model_name='chartofaccountmodel',
name='entity',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='django_ledger.entitymodel', verbose_name='Entity'),
),
migrations.AddIndex(
model_name='transactionmodel',
index=models.Index(fields=['cleared'], name='django_ledg_cleared_335c0b_idx'),
),
migrations.AddIndex(
model_name='transactionmodel',
index=models.Index(fields=['reconciled'], name='django_ledg_reconci_75dbc7_idx'),
),
]
2 changes: 1 addition & 1 deletion django_ledger/models/__init__.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
from django_ledger.models.mixins import *
from django_ledger.models.bank_account import *
from django_ledger.models.coa import *
from django_ledger.models.chart_of_accounts import *
from django_ledger.models.bill import *
from django_ledger.models.invoice import *
from django_ledger.models.items import *
Expand Down
4 changes: 4 additions & 0 deletions django_ledger/models/accounts.py
Original file line number Diff line number Diff line change
Expand Up @@ -1058,6 +1058,10 @@ class AccountModel(AccountModelAbstract):
Base Account Model from Account Model Abstract Class
"""

class Meta(AccountModelAbstract.Meta):
swappable = 'DJANGO_LEDGER_ACCOUNT_MODEL'
abstract = False


def accountmodel_presave(instance: AccountModel, **kwargs):
if instance.role_default is False:
Expand Down
8 changes: 6 additions & 2 deletions django_ledger/models/bank_account.py
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ def for_entity(self, entity_slug, user_model) -> BankAccountModelQuerySet:
)


class BackAccountModelAbstract(BankAccountInfoMixIn, CreateUpdateMixIn):
class BankAccountModelAbstract(BankAccountInfoMixIn, CreateUpdateMixIn):
"""
This is the main abstract class which the BankAccountModel database will inherit from.
The BankAccountModel inherits functionality from the following MixIns:
Expand Down Expand Up @@ -204,7 +204,11 @@ def mark_as_inactive(self, commit: bool = False, raise_exception: bool = True, *
])


class BankAccountModel(BackAccountModelAbstract):
class BankAccountModel(BankAccountModelAbstract):
"""
Base Bank Account Model Implementation
"""

class Meta(BankAccountModelAbstract.Meta):
swappable = 'DJANGO_LEDGER_BANK_ACCOUNT_MODEL'
abstract = False
10 changes: 7 additions & 3 deletions django_ledger/models/bill.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
from django.contrib.auth import get_user_model
from django.core.exceptions import ValidationError, ObjectDoesNotExist
from django.db import models, transaction, IntegrityError
from django.db.models import Q, Sum, F, Count
from django.db.models import Q, Sum, F, Count, QuerySet, Manager
from django.db.models.signals import pre_save
from django.shortcuts import get_object_or_404
from django.urls import reverse
Expand Down Expand Up @@ -53,7 +53,7 @@ class BillModelValidationError(ValidationError):
pass


class BillModelQuerySet(models.QuerySet):
class BillModelQuerySet(QuerySet):
"""
A custom defined QuerySet for the BillModel. This implements multiple methods or queries needed to get a filtered
QuerySet based on the BillModel status. For example, we might want to have list of bills which are paid, unpaid,
Expand Down Expand Up @@ -170,7 +170,7 @@ def unpaid(self):
return self.filter(bill_status__exact=BillModel.BILL_STATUS_APPROVED)


class BillModelManager(models.Manager):
class BillModelManager(Manager):
"""
A custom defined BillModelManager that will act as an interface to handling the initial DB queries
to the BillModel. The default "get_queryset" has been overridden to refer the custom defined
Expand Down Expand Up @@ -1904,6 +1904,10 @@ class BillModel(BillModelAbstract):
Base BillModel from Abstract.
"""

class Meta(BillModelAbstract.Meta):
swappable = 'DJANGO_LEDGER_BILL_MODEL'
abstract = False


def billmodel_presave(instance: BillModel, **kwargs):
if instance.can_generate_bill_number():
Expand Down
Loading

0 comments on commit e162284

Please sign in to comment.