-
-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[16.0][Add] sale_order_blanket_order #3436
base: 16.0
Are you sure you want to change the base?
Changes from 5 commits
b92d9b5
141b981
9c9f61b
74955c7
14eb068
1dcd4f6
23bf11d
022a7b6
aef0093
967750c
4ee5987
2977f3d
2ffc23f
ec8284e
f9706fa
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,206 @@ | ||
============== | ||
Sale Framework | ||
============== | ||
|
||
.. | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
!! This file is generated by oca-gen-addon-readme !! | ||
!! changes will be overwritten. !! | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
!! source digest: sha256:d0b6a096d18178fbd15da557bf07466d1ff491c59a2b56a17781a6d020da21dd | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
|
||
.. |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%2Fsale--workflow-lightgray.png?logo=github | ||
:target: https://github.com/OCA/sale-workflow/tree/16.0/sale_framework | ||
:alt: OCA/sale-workflow | ||
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png | ||
:target: https://translation.odoo-community.org/projects/sale-workflow-16-0/sale-workflow-16-0-sale_framework | ||
: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/sale-workflow&target_branch=16.0 | ||
:alt: Try me on Runboat | ||
|
||
|badge1| |badge2| |badge3| |badge4| |badge5| | ||
|
||
This module extends the functionality of Sale Order to support Blanket | ||
Order and Call of Order. | ||
|
||
Blanket Order | ||
============= | ||
|
||
A Blanket Order is a standard sales order with the following specific | ||
features: | ||
|
||
- Type: Classified as "Blanket Order". | ||
- Defined Duration: Includes a validity period (end date). | ||
- Payment Terms: Allows selection of preferred terms (e.g., 90 days end | ||
of month, upon delivery, etc.). | ||
- Invoicing Policy: Can be based on product settings or the order | ||
itself. | ||
- Stock Reservation: Allows advance reservation of sold quantities. | ||
- Handling Unfulfilled Quantities: Provides options for dealing with | ||
undelivered quantities upon order expiration. | ||
- Prices are calculated based on existing rules since it is a standard | ||
sales order type. | ||
|
||
The blanket order serves as the central element triggering stock | ||
management and invoicing mechanisms. | ||
|
||
Stock Management | ||
---------------- | ||
|
||
Delivered quantities are tracked on the sales order lines as with | ||
regular sales orders. The goods are not delivered upon confirmation of | ||
the blanket order, but stock can be reserved for the customer using OCA | ||
modules: | ||
|
||
- **sale_manual_delivery:** Marks sales orders as "manual delivery," | ||
preventing stock reservation or delivery preparation. | ||
- **sale_stock_prebook:** Marks sales orders as "to reserve," triggering | ||
stock reservation but blocking delivery preparation for such cases. | ||
|
||
Invoicing | ||
--------- | ||
|
||
Standard invoicing policies apply (e.g., invoice on order or on | ||
delivery). Payment terms are configurable per order. Prepayment can be | ||
enforced by configuring the invoicing policy at the order level using | ||
the OCA module | ||
(sale_invoice_policy)[`https://pypi.org/project/odoo-addon-sale-invoice-policy/] <https://pypi.org/project/odoo-addon-sale-invoice-policy/]>`__. | ||
|
||
Consumption Management | ||
---------------------- | ||
|
||
A wizard will be available on the blanket order to initiate a delivery. | ||
It allows users to select products and quantities for delivery. This | ||
action creates a Call-off Order linked to the blanket order. | ||
|
||
Call-off Order | ||
============== | ||
|
||
A Call-off Order is a standard sales order with these specific | ||
characteristics: | ||
|
||
- Type: Classified as "Call-off Order". | ||
- Linked to Blanket Order: Only includes products from the blanket | ||
order. | ||
- Delivery Release: Enables the release of reserved stock for delivery. | ||
- No Invoicing or Stock Management: These are handled via the linked | ||
blanket order. | ||
|
||
Stock Management | ||
---------------- | ||
|
||
No delivery is generated directly from the call-off order. | ||
|
||
It triggers: | ||
|
||
- Release of the reserved quantity in the blanket order. | ||
- Adjustment of stock reservations for the remaining quantities. | ||
|
||
Standard Sales Orders | ||
===================== | ||
|
||
To support existing workflows (e.g., e-commerce), call-off orders can be | ||
generated transparently from standard sales orders based on product and | ||
availability: | ||
|
||
Entire orders may be converted into call-off orders if all products are | ||
linked to a blanket order. Mixed orders split call-off items into a new | ||
call-off order, with both confirmed within the available quantities of | ||
the blanket order. | ||
|
||
**Table of contents** | ||
|
||
.. contents:: | ||
:local: | ||
|
||
Use Cases / Context | ||
=================== | ||
|
||
When a company sells the same products to the same customers on a | ||
regular basis, it's a common business practice to create a sale | ||
framework that defines the terms and conditions of the sales. | ||
|
||
If you need a way to define: | ||
|
||
- the terms and conditions of the sales, | ||
- the payment terms, | ||
- the delivery terms, | ||
|
||
and also secure the quantities of the products to be delivered, the sale | ||
framework module is the right choice. | ||
|
||
This module introduces 2 new kinkds of sale orders: | ||
|
||
1. Sale Blanket Order: This is a sale order that defines the terms and | ||
conditions of the sales, the payment terms, the delivery terms, and | ||
secures the quantities of the products to be delivered. It is used to | ||
create sale orders that will be delivered in the future. | ||
|
||
2. Call of order: This is a sale order that is created to consume the | ||
quantities of the products secured in the sale blanket order. | ||
|
||
Others modules can be used to provide the same kind of features. For | ||
example, the module | ||
(sale_blanket_order)[`https://pypi.org/project/odoo-addon-sale-blanket-order] <https://pypi.org/project/odoo-addon-sale-blanket-order]>`__ | ||
also defines the concept of sale blanket order. The main difference | ||
between the two modules is that the sale framework module extends the | ||
sale order model to add the sale blanket order and the call of order. | ||
This allows to keep the benefits of all the extensions made on the sale | ||
order model by other modules without having to adapt them to the sale | ||
blanket order model (discount, invoicing; inventory process, ...). | ||
|
||
Bug Tracker | ||
=========== | ||
|
||
Bugs are tracked on `GitHub Issues <https://github.com/OCA/sale-workflow/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/sale-workflow/issues/new?body=module:%20sale_framework%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 | ||
------- | ||
|
||
* ACSONE SA/NV | ||
|
||
Contributors | ||
------------ | ||
|
||
- Laurent Mignon\ [email protected] (https://www.acsone.eu) | ||
- Jacques-Etienne Baudoux (BCIM) [email protected] | ||
|
||
Other credits | ||
------------- | ||
|
||
The development of this module has been financially supported by: | ||
|
||
- ALCYON Belux | ||
|
||
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. | ||
|
||
This module is part of the `OCA/sale-workflow <https://github.com/OCA/sale-workflow/tree/16.0/sale_framework>`_ project on GitHub. | ||
|
||
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
from . import models | ||
from .hooks import pre_init_hook |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# Copyright 2024 ACSONE SA/NV | ||
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). | ||
|
||
{ | ||
"name": "Sale Framework", | ||
"summary": """Manage blanket order and call of ordr""", | ||
"version": "16.0.1.0.0", | ||
"license": "AGPL-3", | ||
"author": "ACSONE SA/NV,Odoo Community Association (OCA)", | ||
"website": "https://github.com/OCA/sale-workflow", | ||
"depends": [ | ||
"sale_manual_delivery", | ||
"sale_stock_prebook", | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. These dependencies seem too much for a "framework". There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's probably not the best name. I have no other idea as the name “sale_blanket_order” is already in use. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, but it's not only a question of the name, but to require such dependencies, that I think they should be extension modules: There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. rename this module to There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. also remove the dependency to stock from this module and make another one for the glue with stock |
||
], | ||
"data": [ | ||
#'views/sale_order.xml', | ||
], | ||
"demo": [], | ||
"pre_init_hook": "pre_init_hook", | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
import logging | ||
|
||
_logger = logging.getLogger(__name__) | ||
|
||
|
||
def pre_init_hook(cr): | ||
_logger.info("Create column order_type in sale_order wiht default value 'normal'") | ||
cr.execute( | ||
"ALTER TABLE sale_order ADD COLUMN order_type varchar(255) DEFAULT 'normal'" | ||
) | ||
# drop the default value since it was only used to fill the column in existing records | ||
cr.execute("ALTER TABLE sale_order ALTER COLUMN order_type DROP DEFAULT") |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
from . import sale_order | ||
from . import sale_order_line | ||
from . import stock_move |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
:O