diff --git a/pos_cash_control_extension/README.rst b/pos_cash_control_extension/README.rst new file mode 100644 index 0000000000..4fcce8bfe5 --- /dev/null +++ b/pos_cash_control_extension/README.rst @@ -0,0 +1,88 @@ +====================== +Cash Control Extension +====================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:2762afb29c852de29b8a1edbf0501a7dac017e1740ac9509f5b335dabbe51428 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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/17.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-17-0/pos-17-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=17.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 `_. +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 `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* Antoni Marroig Campomar +* APSL-Nagarro + +Contributors +------------ + +- `APSL-Nagarro `__: + + - Antoni Marroig + +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 `__: + +|maintainer-peluko00| + +This module is part of the `OCA/pos `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/pos_cash_control_extension/__init__.py b/pos_cash_control_extension/__init__.py new file mode 100644 index 0000000000..31660d6a96 --- /dev/null +++ b/pos_cash_control_extension/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import models diff --git a/pos_cash_control_extension/__manifest__.py b/pos_cash_control_extension/__manifest__.py new file mode 100644 index 0000000000..9eec3465bd --- /dev/null +++ b/pos_cash_control_extension/__manifest__.py @@ -0,0 +1,17 @@ +# Copyright 2024 Antoni Marroig(APSL-Nagarro) +# 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": "17.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", + ], +} diff --git a/pos_cash_control_extension/models/__init__.py b/pos_cash_control_extension/models/__init__.py new file mode 100644 index 0000000000..4a2e7f3dbf --- /dev/null +++ b/pos_cash_control_extension/models/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import pos_session diff --git a/pos_cash_control_extension/models/pos_session.py b/pos_cash_control_extension/models/pos_session.py new file mode 100644 index 0000000000..e7a58a0ba5 --- /dev/null +++ b/pos_cash_control_extension/models/pos_session.py @@ -0,0 +1,52 @@ +# Copyright 2024 Antoni Marroig(APSL-Nagarro) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import models + + +class PosSession(models.Model): + _inherit = "pos.session" + + def set_cashbox_pos(self, cashbox_value: int, notes: str): + self.state = "opened" + self.opening_notes = notes + self.cash_register_balance_start = cashbox_value + self._post_cash_details_message("Opening", 0.0, notes) + + 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, is_opening): + 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 diff --git a/pos_cash_control_extension/pyproject.toml b/pos_cash_control_extension/pyproject.toml new file mode 100644 index 0000000000..4231d0cccb --- /dev/null +++ b/pos_cash_control_extension/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/pos_cash_control_extension/readme/CONTRIBUTORS.md b/pos_cash_control_extension/readme/CONTRIBUTORS.md new file mode 100644 index 0000000000..4f7cf9ae4b --- /dev/null +++ b/pos_cash_control_extension/readme/CONTRIBUTORS.md @@ -0,0 +1,2 @@ +- [APSL-Nagarro](): + - Antoni Marroig \<\> diff --git a/pos_cash_control_extension/readme/DESCRIPTION.md b/pos_cash_control_extension/readme/DESCRIPTION.md new file mode 100644 index 0000000000..a80f3d0dbf --- /dev/null +++ b/pos_cash_control_extension/readme/DESCRIPTION.md @@ -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. diff --git a/pos_cash_control_extension/static/description/icon.png b/pos_cash_control_extension/static/description/icon.png new file mode 100644 index 0000000000..3a0328b516 Binary files /dev/null and b/pos_cash_control_extension/static/description/icon.png differ diff --git a/pos_cash_control_extension/static/description/icon.svg b/pos_cash_control_extension/static/description/icon.svg new file mode 100644 index 0000000000..a7a26d0932 --- /dev/null +++ b/pos_cash_control_extension/static/description/icon.svg @@ -0,0 +1,79 @@ + + + + + + + + image/svg+xml + + + + + + + + + + + diff --git a/pos_cash_control_extension/static/description/index.html b/pos_cash_control_extension/static/description/index.html new file mode 100644 index 0000000000..f92d18ab8d --- /dev/null +++ b/pos_cash_control_extension/static/description/index.html @@ -0,0 +1,124 @@ +
+
+
+

Module name

+

This module was written to extend the functionality of ... to support ... and allow you to ...

+
+
+
+ +
+
+
+

Installation

+
+
+

To install this module, you need to: +

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Configuration

+
+
+

To configure this module, you need to: +

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Usage

+
+
+

To use this module, you need to: +

    +
  • ...
  • +
+

+

For further information, please visit: +

+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Known issues / Roadmap

+
+
+

+

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Credits

+
+
+

Contributors

+ +
+
+

Maintainer

+

+ This module is maintained by the OCA.
+ 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.
+ To contribute to this module, please visit http://odoo-community.org.
+ +

+
+
+
diff --git a/pos_cash_control_extension/tests/__init__.py b/pos_cash_control_extension/tests/__init__.py new file mode 100644 index 0000000000..4b64b959dc --- /dev/null +++ b/pos_cash_control_extension/tests/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import test_cash_control diff --git a/pos_cash_control_extension/tests/test_cash_control.py b/pos_cash_control_extension/tests/test_cash_control.py new file mode 100644 index 0000000000..53c8b7a52b --- /dev/null +++ b/pos_cash_control_extension/tests/test_cash_control.py @@ -0,0 +1,37 @@ +# Copyright 2024 Antoni Marroig(APSL-Nagarro) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo.tests.common import TransactionCase + + +class SomethingCase(TransactionCase): + @classmethod + def setUpClass(cls): + super().setUpClass() + cls.config_id = cls.env.ref("point_of_sale.pos_config_main") + cls.session_id = cls.env["pos.session"].create( + { + "config_id": cls.config_id.id, + "user_id": cls.env.ref("base.user_admin").id, + } + ) + cls.session_id.set_cashbox_pos(150.0, "") + cls.session_id.try_cash_in_out("in", 20.0, "In", {"translatedType": "in"}) + + def test_pos_session_closing_control(self): + self.session_id.action_pos_session_closing_control(False, 170.0, None) + self.assertEqual( + self.session_id.get_closing_control_data()["default_cash_details"][ + "amount" + ], + 170.0, + ) + self.assertEqual( + self.session_id.get_closing_control_data()["default_cash_details"][ + "opening" + ], + 150.0, + ) + self.session_id.post_closing_cash_details(170.0) + self.assertEqual(self.session_id.cash_register_balance_end_real, 150.0) + self.assertEqual(self.session_id.cash_register_balance_start, 150.0)