mirror of
https://github.com/bringout/oca-ocb-sale.git
synced 2026-04-26 23:12:09 +02:00
38 lines
1.6 KiB
Python
38 lines
1.6 KiB
Python
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
|
|
|
from odoo import api, fields, models
|
|
from odoo.fields import Domain
|
|
|
|
|
|
class SaleOrder(models.Model):
|
|
_inherit = 'sale.order'
|
|
|
|
expense_ids = fields.One2many(
|
|
comodel_name='hr.expense',
|
|
inverse_name='sale_order_id',
|
|
string='Expenses',
|
|
domain=[('state', 'in', ('posted', 'in_payment', 'paid'))],
|
|
readonly=True,
|
|
)
|
|
expense_count = fields.Integer("# of Expenses", compute='_compute_expense_count', compute_sudo=True)
|
|
|
|
@api.model
|
|
def _search_display_name(self, operator, value):
|
|
""" For expense, we want to show all sales order but only their display_name (no ir.rule applied), this is the only way to do it. """
|
|
if (
|
|
self.env.context.get('sale_expense_all_order')
|
|
and self.env.user.has_group('sales_team.group_sale_salesman')
|
|
and not self.env.user.has_group('sales_team.group_sale_salesman_all_leads')
|
|
):
|
|
if operator in Domain.NEGATIVE_OPERATORS:
|
|
return NotImplemented
|
|
domain = super()._search_display_name(operator, value)
|
|
company_domain = Domain('state', '=', 'sale') & ('company_id', 'in', self.env.companies.ids)
|
|
query = self.sudo()._search(domain & company_domain)
|
|
return Domain('id', 'in', query)
|
|
return super()._search_display_name(operator, value)
|
|
|
|
@api.depends('expense_ids')
|
|
def _compute_expense_count(self):
|
|
for sale_order in self:
|
|
sale_order.expense_count = len(sale_order.order_line.expense_ids)
|