@api.multi
def onchange_partner_id(self, part):
res = super(SaleOrder, self).onchange_partner_id(part)
domain = [('active', '=', True), ('sale_ok', '=', True)]
if part:
partner = self.env['res.partner'].browse(part)
if partner and partner.sales_channel_id:
domain.append(('sales_channel_ids', '=',
partner.sales_channel_id.id))
product_ids = self.env['product.product'].search(domain)
res.update(domain={
'order_line.product_id': ['id', 'in', [rec.id for rec in product_ids]]
})
return res
我尝试了另一种解决方案,所以我在product.product模型中重写了search\u name和search方法,并且它是有效的。
这里是我的代码,
1) 继承sale_view.xml
('sales_channel_ids', '=', parent.partner_channel_id),
('sale_ok', '=', True),
('active', '=', True)
]
'partner_channel_id': parent.partner_channel_id,
'partner_id': parent.partner_id,
'quantity': product_uom_qty,
'pricelist': parent.pricelist_id,
'uom': product_uom,
'company_id': parent.company_id
}
以及覆盖方法
2) 搜索名称方法:@api.model
def name_search(self, name, args=None, operator='ilike', limit=100):
if 'partner_channel_id' in self._context:
target_domain = findDomain(args, 'sales_channel_ids')
if len(target_domain) == 1:
idx = target_domain.keys()[0]
domain = target_domain.values()[0]
if False in domain:
args.pop(idx)
return super(ProductProduct, self).name_search(name=name,
args=args,
operator=operator,
limit=limit)
3)搜索方法:@api.model
def search(self, args, offset=0, limit=None, order=None, count=False):
if 'partner_channel_id' in self._context:
target_domain = findDomain(args, 'sales_channel_ids')
if len(target_domain) == 1:
idx = target_domain.keys()[0]
domain = target_domain.values()[0]
if False in domain:
args.pop(idx)
return super(ProductProduct, self).search(args=args,
offset=offset,
limit=limit,
order=order,
count=count)
我在这里要做的是,当他们在上下文和域中检测到“partner_channel_id”时,例如[“sales_channel_id”、“=”、False],我删除了该域并保留其余的域(客户没有channel可以看到所有产品,没有从中筛选产品)。
赞踩评论- 2020年3月31日 14:47