Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
88 changes: 88 additions & 0 deletions pos_cash_control_extension/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
======================
Cash Control Extension
======================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:257dfad099e6f1fadd4c474d4439e3e9d0796260e56a0b0faff4d713a7998685
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
:target: https://odoo-community.org/page/development-status
:alt: Beta
.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
:alt: License: AGPL-3
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fpos-lightgray.png?logo=github
:target: https://github.com/OCA/pos/tree/18.0/pos_cash_control_extension
:alt: OCA/pos
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/pos-18-0/pos-18-0-pos_cash_control_extension
:alt: Translate me on Weblate
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
:target: https://runboat.odoo-community.org/builds?repo=OCA/pos&target_branch=18.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This module allows us to always keep a cash fund and ensure that there
are no differences when opening and closing a session.

**Table of contents**

.. contents::
:local:

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/pos/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/pos/issues/new?body=module:%20pos_cash_control_extension%0Aversion:%2018.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

Do not contact contributors directly about support or help with technical issues.

Credits
=======

Authors
-------

* Antoni Marroig Campomar
* APSL-Nagarro

Contributors
------------

- `APSL-Nagarro <https://apsl.tech>`__:

- Antoni Marroig <amarroig@apsl.net>

Maintainers
-----------

This module is maintained by the OCA.

.. image:: https://odoo-community.org/logo.png
:alt: Odoo Community Association
:target: https://odoo-community.org

OCA, or the Odoo Community Association, is a nonprofit organization whose
mission is to support the collaborative development of Odoo features and
promote its widespread use.

.. |maintainer-peluko00| image:: https://github.com/peluko00.png?size=40px
:target: https://github.com/peluko00
:alt: peluko00

Current `maintainer <https://odoo-community.org/page/maintainer-role>`__:

|maintainer-peluko00|

This module is part of the `OCA/pos <https://github.com/OCA/pos/tree/18.0/pos_cash_control_extension>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
3 changes: 3 additions & 0 deletions pos_cash_control_extension/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from . import models
17 changes: 17 additions & 0 deletions pos_cash_control_extension/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Copyright 2024 Antoni Marroig(APSL-Nagarro)<amarroig@apsl.net>
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
{
"name": "Cash Control Extension",
"summary": "This module extends the cash in/out control",
"version": "18.0.1.0.0",
"category": "POS",
"author": "Antoni Marroig Campomar, APSL-Nagarro, Odoo Community Association (OCA)",
"maintainers": ["peluko00"],
"website": "https://github.com/OCA/pos",
"license": "AGPL-3",
"application": False,
"installable": True,
"depends": [
"point_of_sale",
],
}
22 changes: 22 additions & 0 deletions pos_cash_control_extension/i18n/it.po
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * pos_cash_control_extension
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 17.0\n"
"Report-Msgid-Bugs-To: \n"
"PO-Revision-Date: 2024-12-28 14:06+0000\n"
"Last-Translator: mymage <stefano.consolaro@mymage.it>\n"
"Language-Team: none\n"
"Language: it\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: nplurals=2; plural=n != 1;\n"
"X-Generator: Weblate 5.6.2\n"

#. module: pos_cash_control_extension
#: model:ir.model,name:pos_cash_control_extension.model_pos_session
msgid "Point of Sale Session"
msgstr "Sessione punto vendita"
19 changes: 19 additions & 0 deletions pos_cash_control_extension/i18n/pos_cash_control_extension.pot
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
# Translation of Odoo Server.
# This file contains the translation of the following modules:
# * pos_cash_control_extension
#
msgid ""
msgstr ""
"Project-Id-Version: Odoo Server 17.0\n"
"Report-Msgid-Bugs-To: \n"
"Last-Translator: \n"
"Language-Team: \n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: \n"
"Plural-Forms: \n"

#. module: pos_cash_control_extension
#: model:ir.model,name:pos_cash_control_extension.model_pos_session
msgid "Point of Sale Session"
msgstr ""
3 changes: 3 additions & 0 deletions pos_cash_control_extension/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from . import pos_session
86 changes: 86 additions & 0 deletions pos_cash_control_extension/models/pos_session.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
# Copyright 2024 Antoni Marroig(APSL-Nagarro)<amarroig@apsl.net>
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo import fields, models
from odoo.tools import plaintext2html


class PosSession(models.Model):
_inherit = "pos.session"

def _set_opening_control_data(self, cashbox_value: int, notes: str):
self.state = "opened"
self.start_at = fields.Datetime.now()

cash_payment_method_ids = self.config_id.payment_method_ids.filtered(
lambda pm: pm.is_cash_count
)
if notes:
self.opening_notes = notes
if cash_payment_method_ids:
self._post_cash_details_message(
"Opening cash", self.cash_register_balance_start, 0.0, notes
)
self.cash_register_balance_start = cashbox_value
elif notes:
message = self.env._("Opening control message: ")
message += notes
self.message_post(body=plaintext2html(message))

def _post_cash_details_message(self, state, expected, difference, notes):
expected_formatted = self.currency_id.format(expected)
difference_formatted = self.currency_id.format(difference)
counted_formatted = self.currency_id.format(expected + difference)

if state == "Opening cash":
message = self.env._("Opening cash difference: %s \n", difference_formatted)
message += self.env._("Opening cash expected: %s \n", expected_formatted)
message += self.env._("Opening cash counted: %s \n", counted_formatted)
else:
message = self.env._("Closing difference: %s \n", 0.0)
message += self.env._("Closing expected: %s \n", counted_formatted)
message += self.env._("Closing counted: %s \n", counted_formatted)

if notes:
message += self.env._("Opening control message: ")
message += notes
if message:
self.message_post(body=plaintext2html(message))

def get_closing_control_data(self):
res = super().get_closing_control_data()
orders = self._get_closed_orders()
cash_payment_method_ids = self.payment_method_ids.filtered(
lambda pm: pm.type == "cash"
)
default_cash_payment_method_id = (
cash_payment_method_ids[0] if cash_payment_method_ids else None
)
payments = orders.payment_ids.filtered(
lambda p: p.payment_method_id.type != "pay_later"
)
total_default_cash_payment_amount = (
sum(
payments.filtered(
lambda p: p.payment_method_id == default_cash_payment_method_id
).mapped("amount")
)
if default_cash_payment_method_id
else 0
)
if "default_cash_details" in res and res["default_cash_details"]:
res["default_cash_details"]["opening"] = self.cash_register_balance_start
res["default_cash_details"]["amount"] = (
self.cash_register_balance_start
+ total_default_cash_payment_amount
+ sum(self.sudo().statement_line_ids.mapped("amount"))
)
return res

def _post_statement_difference(self, amount):
pass

def post_closing_cash_details(self, counted_cash):
res = super().post_closing_cash_details(counted_cash)
self.cash_register_balance_end_real = self.cash_register_balance_start or 0.0
return res
3 changes: 3 additions & 0 deletions pos_cash_control_extension/pyproject.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[build-system]
requires = ["whool"]
build-backend = "whool.buildapi"
2 changes: 2 additions & 0 deletions pos_cash_control_extension/readme/CONTRIBUTORS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
- [APSL-Nagarro](<https://apsl.tech>):
- Antoni Marroig \<<amarroig@apsl.net>\>
1 change: 1 addition & 0 deletions pos_cash_control_extension/readme/DESCRIPTION.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
This module allows us to always keep a cash fund and ensure that there are no differences when opening and closing a session.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading