mirror of
https://github.com/bringout/oca-ocb-mrp.git
synced 2026-04-26 23:12:06 +02:00
19.0 vanilla
This commit is contained in:
parent
accf5918df
commit
6e65e8c877
688 changed files with 225434 additions and 199401 deletions
|
|
@ -1,7 +1,7 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from odoo import api, fields, models
|
||||
from odoo import fields, models
|
||||
|
||||
|
||||
class ResPartner(models.Model):
|
||||
|
|
@ -18,48 +18,46 @@ class ResPartner(models.Model):
|
|||
picking_ids = fields.Many2many('stock.picking', compute='_compute_picking_ids', string="Stock Pickings for which the Partner is the subcontractor")
|
||||
|
||||
def _compute_bom_ids(self):
|
||||
results = self.env['mrp.bom'].read_group([('subcontractor_ids.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['ids:array_agg(id)', 'subcontractor_ids'], ['subcontractor_ids'])
|
||||
results = self.env['mrp.bom']._read_group([('subcontractor_ids.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['subcontractor_ids'], ['id:array_agg'])
|
||||
for partner in self:
|
||||
bom_ids = []
|
||||
for res in results:
|
||||
if partner.id == res['subcontractor_ids'][0] or res['subcontractor_ids'][0] in partner.child_ids.ids:
|
||||
bom_ids += res['ids']
|
||||
for subcontractor, ids in results:
|
||||
if partner.id == subcontractor.id or subcontractor.id in partner.child_ids.ids:
|
||||
bom_ids += ids
|
||||
partner.bom_ids = bom_ids
|
||||
|
||||
def _compute_production_ids(self):
|
||||
results = self.env['mrp.production'].read_group([('subcontractor_id.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['ids:array_agg(id)'], ['subcontractor_id'])
|
||||
results = self.env['mrp.production']._read_group([('subcontractor_id.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['subcontractor_id'], ['id:array_agg'])
|
||||
for partner in self:
|
||||
production_ids = []
|
||||
for res in results:
|
||||
if partner.id == res['subcontractor_id'][0] or res['subcontractor_id'][0] in partner.child_ids.ids:
|
||||
production_ids += res['ids']
|
||||
for subcontractor, ids in results:
|
||||
if partner.id == subcontractor.id or subcontractor.id in partner.child_ids.ids:
|
||||
production_ids += ids
|
||||
partner.production_ids = production_ids
|
||||
|
||||
def _compute_picking_ids(self):
|
||||
results = self.env['stock.picking'].read_group([('partner_id.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['ids:array_agg(id)'], ['partner_id'])
|
||||
results = self.env['stock.picking']._read_group([('partner_id.commercial_partner_id', 'in', self.commercial_partner_id.ids)], ['partner_id'], ['id:array_agg'])
|
||||
for partner in self:
|
||||
picking_ids = []
|
||||
for res in results:
|
||||
if partner.id == res['partner_id'][0] or res['partner_id'][0] in partner.child_ids.ids:
|
||||
picking_ids += res['ids']
|
||||
for partner_rg, ids in results:
|
||||
if partner_rg.id == partner.id or partner_rg.id in partner.child_ids.ids:
|
||||
picking_ids += ids
|
||||
partner.picking_ids = picking_ids
|
||||
|
||||
def _search_is_subcontractor(self, operator, value):
|
||||
assert operator in ('=', '!=', '<>') and value in (True, False), 'Operation not supported'
|
||||
if operator != 'in':
|
||||
return NotImplemented
|
||||
subcontractor_ids = self.env['mrp.bom'].search(
|
||||
[('type', '=', 'subcontract')]).subcontractor_ids.ids
|
||||
if (operator == '=' and value is True) or (operator in ('<>', '!=') and value is False):
|
||||
search_operator = 'in'
|
||||
else:
|
||||
search_operator = 'not in'
|
||||
return [('id', search_operator, subcontractor_ids)]
|
||||
return [('id', 'in', subcontractor_ids)]
|
||||
|
||||
@api.depends_context('uid')
|
||||
def _compute_is_subcontractor(self):
|
||||
""" Check if the user is a subcontractor before giving sudo access
|
||||
"""
|
||||
""" Determine whether the partner is a subcontractor (for giving sudo access) """
|
||||
for partner in self:
|
||||
partner.is_subcontractor = (partner.user_has_groups('base.group_portal') and partner.env['mrp.bom'].search_count([
|
||||
('type', '=', 'subcontract'),
|
||||
('subcontractor_ids', 'in', (partner.env.user.partner_id | partner.env.user.partner_id.commercial_partner_id).ids),
|
||||
]))
|
||||
partner.is_subcontractor = (
|
||||
any(user._is_portal() for user in partner.user_ids)
|
||||
and partner.env['mrp.bom'].search_count([
|
||||
('type', '=', 'subcontract'),
|
||||
('subcontractor_ids', 'in', (partner | partner.commercial_partner_id).ids),
|
||||
], limit=1)
|
||||
)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue