mirror of
https://github.com/OCA/stock-logistics-reporting.git
synced 2025-02-16 17:13:21 +02:00
stock_average_daily_sale: Config adjustment - add from view and company_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
This commit is contained in:
@@ -13,6 +13,8 @@
|
|||||||
<field name="safety_factor">0.3</field>
|
<field name="safety_factor">0.3</field>
|
||||||
<field name="number_days_qty_in_stock">2</field>
|
<field name="number_days_qty_in_stock">2</field>
|
||||||
<field name="exclude_weekends">1</field>
|
<field name="exclude_weekends">1</field>
|
||||||
|
<field name="warehouse_id" ref="stock.warehouse0" />
|
||||||
|
<field name="company_id" ref="base.main_company" />
|
||||||
</record>
|
</record>
|
||||||
<record
|
<record
|
||||||
model="stock.average.daily.sale.config"
|
model="stock.average.daily.sale.config"
|
||||||
@@ -25,6 +27,8 @@
|
|||||||
<field name="safety_factor">0.3</field>
|
<field name="safety_factor">0.3</field>
|
||||||
<field name="number_days_qty_in_stock">2</field>
|
<field name="number_days_qty_in_stock">2</field>
|
||||||
<field name="exclude_weekends">1</field>
|
<field name="exclude_weekends">1</field>
|
||||||
|
<field name="warehouse_id" ref="stock.warehouse0" />
|
||||||
|
<field name="company_id" ref="base.main_company" />
|
||||||
</record>
|
</record>
|
||||||
<record
|
<record
|
||||||
model="stock.average.daily.sale.config"
|
model="stock.average.daily.sale.config"
|
||||||
@@ -37,5 +41,7 @@
|
|||||||
<field name="safety_factor">0.3</field>
|
<field name="safety_factor">0.3</field>
|
||||||
<field name="number_days_qty_in_stock">2</field>
|
<field name="number_days_qty_in_stock">2</field>
|
||||||
<field name="exclude_weekends">1</field>
|
<field name="exclude_weekends">1</field>
|
||||||
|
<field name="warehouse_id" ref="stock.warehouse0" />
|
||||||
|
<field name="company_id" ref="base.main_company" />
|
||||||
</record>
|
</record>
|
||||||
</odoo>
|
</odoo>
|
||||||
|
|||||||
@@ -228,6 +228,7 @@ class StockAverageDailySale(models.Model):
|
|||||||
AND sl_dest.usage in ('customer', 'production')
|
AND sl_dest.usage in ('customer', 'production')
|
||||||
AND sm.date BETWEEN cfg.date_from AND cfg.date_to
|
AND sm.date BETWEEN cfg.date_from AND cfg.date_to
|
||||||
AND sm.state = 'done'
|
AND sm.state = 'done'
|
||||||
|
AND sm.warehouse_id = cfg.warehouse_id
|
||||||
WINDOW pid AS (PARTITION BY sm.product_id, sm.warehouse_id)
|
WINDOW pid AS (PARTITION BY sm.product_id, sm.warehouse_id)
|
||||||
),
|
),
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
# Copyright 2021 ACSONE SA/NV
|
# Copyright 2021 ACSONE SA/NV
|
||||||
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
|
# 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 (
|
from odoo.addons.stock_storage_type_putaway_abc.models.stock_location import (
|
||||||
ABC_SELECTION,
|
ABC_SELECTION,
|
||||||
@@ -9,17 +9,18 @@ from odoo.addons.stock_storage_type_putaway_abc.models.stock_location import (
|
|||||||
|
|
||||||
|
|
||||||
class StockAverageDailySaleConfig(models.Model):
|
class StockAverageDailySaleConfig(models.Model):
|
||||||
|
|
||||||
_name = "stock.average.daily.sale.config"
|
_name = "stock.average.daily.sale.config"
|
||||||
_description = "Average daily sales computation parameters"
|
_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(
|
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))
|
standard_deviation_exclude_factor = fields.Float(required=True, digits=(2, 2))
|
||||||
warehouse_id = fields.Many2one(
|
warehouse_id = fields.Many2one(
|
||||||
@@ -30,10 +31,8 @@ class StockAverageDailySaleConfig(models.Model):
|
|||||||
default=lambda self: self.env["stock.warehouse"].search(
|
default=lambda self: self.env["stock.warehouse"].search(
|
||||||
[("company_id", "=", self.env.company.id)], limit=1
|
[("company_id", "=", self.env.company.id)], limit=1
|
||||||
),
|
),
|
||||||
readonly=True,
|
|
||||||
)
|
)
|
||||||
exclude_weekends = fields.Boolean(
|
exclude_weekends = fields.Boolean(
|
||||||
string="Exclude Weekends",
|
|
||||||
help="Set to True only if you do not expect any orders/deliveries during "
|
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 "
|
"the weekends. If set to True, stock moves done on weekends won't be "
|
||||||
"taken into account to calculate the average daily usage",
|
"taken into account to calculate the average daily usage",
|
||||||
@@ -53,3 +52,11 @@ class StockAverageDailySaleConfig(models.Model):
|
|||||||
string="Number of days of quantities in stock", required=True, default=2
|
string="Number of days of quantities in stock", required=True, default=2
|
||||||
)
|
)
|
||||||
safety_factor = fields.Float(digits=(2, 2), required=True)
|
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"),
|
||||||
|
)
|
||||||
|
]
|
||||||
|
|||||||
@@ -87,12 +87,13 @@ class CommonAverageSaleTest:
|
|||||||
"product_id": product.id,
|
"product_id": product.id,
|
||||||
"name": product.name,
|
"name": product.name,
|
||||||
"location_id": origin_location.id,
|
"location_id": origin_location.id,
|
||||||
|
"warehouse_id": origin_location.warehouse_id.id,
|
||||||
"location_dest_id": cls.customers.id,
|
"location_dest_id": cls.customers.id,
|
||||||
"product_uom_qty": qty,
|
"product_uom_qty": qty,
|
||||||
"priority": "1",
|
"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"
|
move.priority = "1"
|
||||||
return move
|
return move
|
||||||
|
|
||||||
|
|||||||
@@ -189,7 +189,8 @@ class TestAverageSale(CommonAverageSaleTest, TransactionCase):
|
|||||||
def test_view_refreshed(self):
|
def test_view_refreshed(self):
|
||||||
self._refresh()
|
self._refresh()
|
||||||
with self.assertNoLogs(
|
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(
|
self.env["stock.average.daily.sale"].search_read(
|
||||||
[("product_id", "=", self.product_1.id)]
|
[("product_id", "=", self.product_1.id)]
|
||||||
|
|||||||
@@ -2,13 +2,14 @@
|
|||||||
<!-- Copyright 2021 ACSONE SA/NV
|
<!-- Copyright 2021 ACSONE SA/NV
|
||||||
License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
|
License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -->
|
||||||
<odoo>
|
<odoo>
|
||||||
|
|
||||||
<record model="ir.ui.view" id="stock_average_daily_sale_config_tree_view">
|
<record model="ir.ui.view" id="stock_average_daily_sale_config_tree_view">
|
||||||
<field
|
<field name="name">stock.average.daily.sale.config.tree</field>
|
||||||
name="name"
|
|
||||||
>stock.average.daily.sale.config.tree (in stock_average_daily_sale)</field>
|
|
||||||
<field name="model">stock.average.daily.sale.config</field>
|
<field name="model">stock.average.daily.sale.config</field>
|
||||||
<field name="arch" type="xml">
|
<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="abc_classification_level" />
|
||||||
<field name="exclude_weekends" />
|
<field name="exclude_weekends" />
|
||||||
<field name="period_value" />
|
<field name="period_value" />
|
||||||
@@ -16,24 +17,54 @@
|
|||||||
<field name="number_days_qty_in_stock" />
|
<field name="number_days_qty_in_stock" />
|
||||||
<field name="standard_deviation_exclude_factor" />
|
<field name="standard_deviation_exclude_factor" />
|
||||||
<field name="safety_factor" />
|
<field name="safety_factor" />
|
||||||
<field name="warehouse_id" />
|
|
||||||
</tree>
|
</tree>
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</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
|
<record
|
||||||
model="ir.actions.act_window"
|
model="ir.actions.act_window"
|
||||||
id="stock_average_daily_sale_config_act_window"
|
id="stock_average_daily_sale_config_act_window"
|
||||||
>
|
>
|
||||||
<field name="name">Average daily sales computation parameters</field>
|
<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="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="domain">[]</field>
|
||||||
<field name="context">{}</field>
|
<field name="context">{}</field>
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
<record model="ir.ui.menu" id="stock_average_daily_sale_config_menu">
|
<record model="ir.ui.menu" id="stock_average_daily_sale_config_menu">
|
||||||
<field name="name">Average daily sales computation parameters</field>
|
<field name="name">Average daily sales computation parameters</field>
|
||||||
<field name="parent_id" ref="stock.menu_product_in_config_stock" />
|
<field name="parent_id" ref="stock.menu_product_in_config_stock" />
|
||||||
<field name="action" ref="stock_average_daily_sale_config_act_window" />
|
<field name="action" ref="stock_average_daily_sale_config_act_window" />
|
||||||
<field name="sequence" eval="99" />
|
<field name="sequence" eval="99" />
|
||||||
</record>
|
</record>
|
||||||
|
|
||||||
</odoo>
|
</odoo>
|
||||||
|
|||||||
Reference in New Issue
Block a user