Skip to content

Commit

Permalink
stock_average_daily_sale: Config adjustment - add from view and compa…
Browse files Browse the repository at this point in the history
…ny_id

stock_average_daily_sale:
- add form view for config
- add company_id to config
- allow editing ABC classification level and make sure
  the level is unique per warehouse
  • Loading branch information
twalter-c2c committed Sep 13, 2024
1 parent 296bc61 commit 448443f
Show file tree
Hide file tree
Showing 6 changed files with 65 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@
<field name="safety_factor">0.3</field>
<field name="number_days_qty_in_stock">2</field>
<field name="exclude_weekends">1</field>
<field name="warehouse_id" ref="stock.warehouse0" />
<field name="company_id" ref="base.main_company" />
</record>
<record
model="stock.average.daily.sale.config"
Expand All @@ -25,6 +27,8 @@
<field name="safety_factor">0.3</field>
<field name="number_days_qty_in_stock">2</field>
<field name="exclude_weekends">1</field>
<field name="warehouse_id" ref="stock.warehouse0" />
<field name="company_id" ref="base.main_company" />
</record>
<record
model="stock.average.daily.sale.config"
Expand All @@ -37,5 +41,7 @@
<field name="safety_factor">0.3</field>
<field name="number_days_qty_in_stock">2</field>
<field name="exclude_weekends">1</field>
<field name="warehouse_id" ref="stock.warehouse0" />
<field name="company_id" ref="base.main_company" />
</record>
</odoo>
Original file line number Diff line number Diff line change
Expand Up @@ -228,6 +228,7 @@ def _create_materialized_view(self):
AND sl_dest.usage in ('customer', 'production')
AND sm.date BETWEEN cfg.date_from AND cfg.date_to
AND sm.state = 'done'
AND sm.warehouse_id = cfg.warehouse_id
WINDOW pid AS (PARTITION BY sm.product_id, sm.warehouse_id)
),
Expand Down
27 changes: 17 additions & 10 deletions stock_average_daily_sale/models/stock_average_daily_sale_config.py
Original file line number Diff line number Diff line change
@@ -1,25 +1,26 @@
# Copyright 2021 ACSONE SA/NV
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo import fields, models
from odoo import _, fields, models

from odoo.addons.stock_storage_type_putaway_abc.models.stock_location import (
ABC_SELECTION,
)


class StockAverageDailySaleConfig(models.Model):

_name = "stock.average.daily.sale.config"
_description = "Average daily sales computation parameters"
check_company_auto = True

abc_classification_profile_id = fields.Many2one(
comodel_name="abc.classification.profile",
required=True,
ondelete="cascade",
)
abc_classification_level = fields.Selection(
selection=ABC_SELECTION, required=True, readonly=True
selection=ABC_SELECTION, required=True, default="b"
)
company_id = fields.Many2one(
string="Company",
comodel_name="res.company",
required=True,
default=lambda self: self.env.company,
)
standard_deviation_exclude_factor = fields.Float(required=True, digits=(2, 2))
warehouse_id = fields.Many2one(
Expand All @@ -30,10 +31,8 @@ class StockAverageDailySaleConfig(models.Model):
default=lambda self: self.env["stock.warehouse"].search(
[("company_id", "=", self.env.company.id)], limit=1
),
readonly=True,
)
exclude_weekends = fields.Boolean(
string="Exclude Weekends",
help="Set to True only if you do not expect any orders/deliveries during "
"the weekends. If set to True, stock moves done on weekends won't be "
"taken into account to calculate the average daily usage",
Expand All @@ -53,3 +52,11 @@ class StockAverageDailySaleConfig(models.Model):
string="Number of days of quantities in stock", required=True, default=2
)
safety_factor = fields.Float(digits=(2, 2), required=True)

_sql_constraints = [
(
"abc_classification_level_unique",
"UNIQUE(abc_classification_level, warehouse_id)",
_("Abc Classification Level must be unique per warehouse"),
)
]
3 changes: 2 additions & 1 deletion stock_average_daily_sale/tests/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,12 +87,13 @@ def _create_move(cls, product, origin_location, qty):
"product_id": product.id,
"name": product.name,
"location_id": origin_location.id,
"warehouse_id": origin_location.warehouse_id.id,
"location_dest_id": cls.customers.id,
"product_uom_qty": qty,
"priority": "1",
}
)
# TODO: Check why this is necessary - it's in materialzed view query
# TODO: Check why this is necessary - it's in materialized view query
move.priority = "1"
return move

Expand Down
3 changes: 2 additions & 1 deletion stock_average_daily_sale/tests/test_average_daily_sale.py
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,8 @@ def test_average_sale_profile_a(self):
def test_view_refreshed(self):
self._refresh()
with self.assertNoLogs(
"odoo.addons.stock_average_daily_sale.models.stock_average_daily_sale"
"odoo.addons.stock_average_daily_sale.models.stock_average_daily_sale",
level="DEBUG",
):
self.env["stock.average.daily.sale"].search_read(
[("product_id", "=", self.product_1.id)]
Expand Down
43 changes: 37 additions & 6 deletions stock_average_daily_sale/views/stock_average_daily_sale_config.xml
Original file line number Diff line number Diff line change
Expand Up @@ -2,38 +2,69 @@
<!-- Copyright 2021 ACSONE SA/NV
License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
<odoo>

<record model="ir.ui.view" id="stock_average_daily_sale_config_tree_view">
<field
name="name"
>stock.average.daily.sale.config.tree (in stock_average_daily_sale)</field>
<field name="name">stock.average.daily.sale.config.tree</field>
<field name="model">stock.average.daily.sale.config</field>
<field name="arch" type="xml">
<tree editable="top" create="false" delete="false">
<tree>
<field name="warehouse_id" />
<field name="company_id" />
<field name="abc_classification_level" />
<field name="exclude_weekends" />
<field name="period_value" />
<field name="period_name" />
<field name="number_days_qty_in_stock" />
<field name="standard_deviation_exclude_factor" />
<field name="safety_factor" />
<field name="warehouse_id" />
</tree>
</field>
</record>

<record model="ir.ui.view" id="stock_average_daily_sale_config_form_view">
<field name="name">stock.average.daily.sale.config.form</field>
<field name="model">stock.average.daily.sale.config</field>
<field name="arch" type="xml">
<form string="Average daily sales computation parameters">
<sheet>
<group>
<group>
<field name="warehouse_id" />
<field name="company_id" />
<field name="abc_classification_level" />
<field name="exclude_weekends" />
</group>
<group>
<field name="period_value" />
<field name="period_name" />
<field name="number_days_qty_in_stock" />
<field name="standard_deviation_exclude_factor" />
<field name="safety_factor" />
</group>
</group>
</sheet>
</form>
</field>
</record>

<record
model="ir.actions.act_window"
id="stock_average_daily_sale_config_act_window"
>
<field name="name">Average daily sales computation parameters</field>
<field name="type">ir.actions.act_window</field>
<field name="res_model">stock.average.daily.sale.config</field>
<field name="view_mode">tree</field>
<field name="view_mode">tree,form</field>
<field name="view_id" ref="stock_average_daily_sale_config_tree_view" />
<field name="domain">[]</field>
<field name="context">{}</field>
</record>

<record model="ir.ui.menu" id="stock_average_daily_sale_config_menu">
<field name="name">Average daily sales computation parameters</field>
<field name="parent_id" ref="stock.menu_product_in_config_stock" />
<field name="action" ref="stock_average_daily_sale_config_act_window" />
<field name="sequence" eval="99" />
</record>

</odoo>

0 comments on commit 448443f

Please sign in to comment.