Skip to content

Commit

Permalink
[ADD] pos_close_draft_order: new module
Browse files Browse the repository at this point in the history
  • Loading branch information
FrankC013 committed Mar 28, 2024
1 parent 3f1b28c commit 0493013
Show file tree
Hide file tree
Showing 11 changed files with 536 additions and 0 deletions.
62 changes: 62 additions & 0 deletions pos_close_draft_order/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
=====================
POS Close Draft Order
=====================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:cc5a8acabeea0c6e46d230f54335d30125a810ec05fee02ebb5d623b78fd142a
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
.. |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-nuobit%2Fodoo--addons-lightgray.png?logo=github
:target: https://github.com/nuobit/odoo-addons/tree/16.0/pos_close_draft_order
:alt: nuobit/odoo-addons

|badge1| |badge2| |badge3|

This module allows you to close session in POS when you have orders still open

**Table of contents**

.. contents::
:local:

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

Bugs are tracked on `GitHub Issues <https://github.com/nuobit/odoo-addons/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/nuobit/odoo-addons/issues/new?body=module:%20pos_close_draft_order%0Aversion:%2016.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
~~~~~~~

* NuoBiT Solutions SL

Contributors
~~~~~~~~~~~~

* `NuoBiT <https://www.nuobit.com>`__:

* Frank Cespedes <[email protected]>

Maintainers
~~~~~~~~~~~

This module is part of the `nuobit/odoo-addons <https://github.com/nuobit/odoo-addons/tree/16.0/pos_close_draft_order>`_ project on GitHub.

You are welcome to contribute.
1 change: 1 addition & 0 deletions pos_close_draft_order/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
12 changes: 12 additions & 0 deletions pos_close_draft_order/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
# Copyright NuoBiT Solutions - Frank Cespedes <[email protected]>
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html).
{
"name": "POS Close Draft Order",
"version": "16.0.1.0.0",
"summary": "This module allows you to close session in POS when you have orders still open",
"category": "Sales/Point of Sale",
"author": "NuoBiT Solutions SL",
"website": "https://github.com/nuobit/odoo-addons",
"license": "AGPL-3",
"depends": ["point_of_sale"],
}
1 change: 1 addition & 0 deletions pos_close_draft_order/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import pos_session
30 changes: 30 additions & 0 deletions pos_close_draft_order/models/pos_session.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Copyright NuoBiT Solutions - Frank Cespedes <[email protected]>
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl)

from odoo import api, models


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

def post_closing_cash_details(self, counted_cash):
orders = self.order_ids.filtered(lambda x: x.state == "draft")
if orders:
session = (

Check warning on line 13 in pos_close_draft_order/models/pos_session.py

View check run for this annotation

Codecov / codecov/patch

pos_close_draft_order/models/pos_session.py#L13

Added line #L13 was not covered by tests
self.env["pos.session"]
.with_context(allow_multiple_session=True)
.create(
{
"user_id": self.env.uid,
"config_id": self.config_id.id,
"state": "opened",
}
)
)
orders.write({"session_id": session.id})
return super(PosSession, self).post_closing_cash_details(counted_cash)

Check warning on line 25 in pos_close_draft_order/models/pos_session.py

View check run for this annotation

Codecov / codecov/patch

pos_close_draft_order/models/pos_session.py#L24-L25

Added lines #L24 - L25 were not covered by tests

@api.constrains("config_id")
def _check_pos_config(self):
if not self.env.context.get("allow_multiple_session", False):
return super(PosSession, self)._check_pos_config()

Check warning on line 30 in pos_close_draft_order/models/pos_session.py

View check run for this annotation

Codecov / codecov/patch

pos_close_draft_order/models/pos_session.py#L30

Added line #L30 was not covered by tests
3 changes: 3 additions & 0 deletions pos_close_draft_order/readme/CONTRIBUTORS.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
* `NuoBiT <https://www.nuobit.com>`__:

* Frank Cespedes <[email protected]>
1 change: 1 addition & 0 deletions pos_close_draft_order/readme/DESCRIPTION.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
This module allows you to close session in POS when you have orders still open
Binary file added pos_close_draft_order/static/description/icon.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit 0493013

Please sign in to comment.