Skip to content

Commit

Permalink
Config adjustment: multi WH, company
Browse files Browse the repository at this point in the history
Add form view for config; add company_id to config; allow selecting multiple WHs to one config
  • Loading branch information
twalter-c2c committed Aug 28, 2024
1 parent 9103e76 commit 21524fd
Show file tree
Hide file tree
Showing 3 changed files with 55 additions and 18 deletions.
2 changes: 1 addition & 1 deletion stock_average_daily_sale/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
"name": "Stock Average Daily Sale",
"summary": """
Allows to gather delivered products average on daily basis""",
"version": "16.0.1.0.0",
"version": "16.0.2.0.0",
"license": "AGPL-3",
"author": "ACSONE SA/NV,BCIM,Odoo Community Association (OCA)",
"website": "https://github.com/OCA/stock-logistics-reporting",
Expand Down
25 changes: 14 additions & 11 deletions stock_average_daily_sale/models/stock_average_daily_sale_config.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,28 +9,31 @@


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"
)
name = fields.Char(string="Name", required=True)
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(
standard_deviation_exclude_factor = fields.Float(
required=True, default=0, digits=(2, 2)
) # TODO check if 0 is correct as default
warehouse_ids = fields.Many2many(
string="Warehouse",
comodel_name="stock.warehouse",
required=True,
ondelete="cascade",
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",
Expand All @@ -52,4 +55,4 @@ class StockAverageDailySaleConfig(models.Model):
number_days_qty_in_stock = fields.Integer(
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, default=0)
46 changes: 40 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,72 @@
<!-- 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="name" />
<field name="warehouse_ids" widget="many2many_tags" />
<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>
<label for="name" />
<h1><field name="name" placeholder="e.g. High prio products" /></h1>
<group>
<group>
<field name="warehouse_ids" widget="many2many_tags" />
<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 21524fd

Please sign in to comment.