實踐環境 Odoo 14.0-20221212 (Community Edition) 需求描述 如下圖,列表網倉記錄詳情頁面(form視圖),編輯內聯視圖中的貨主記錄,為貨主和倉庫欄位搜索,添加過濾條件,具體如下: 添加、編輯貨主時,下拉列表中只展示選取和當網倉記錄所屬公司關聯的貨主,點擊搜索更多 ...
實踐環境
Odoo 14.0-20221212 (Community Edition)
需求描述
如下圖,列表網倉記錄詳情頁面(form視圖),編輯內聯視圖中的貨主記錄,為貨主和倉庫欄位搜索,添加過濾條件,具體如下:
- 添加、編輯貨主時,下拉列表中只展示選取和當網倉記錄所屬公司關聯的貨主,點擊搜索更多,僅展示和當前網倉記錄所屬公司關聯的貨主
- 添加、編輯貨主時,下拉列表中只展示選取和當網倉記錄關聯的倉庫(到 “倉庫” Tab頁中添加的倉庫),點擊搜索更多,僅展示和當前網倉記錄關聯的倉庫。
模型設計
說明:為了更好的體現本文主題,部分非關鍵代碼已省略,即做了適當的模型簡化處理
# 網倉
class OmsNetwork(models.Model):
_name = 'oms.network'
_description = 'OMS Network'
company_id = fields.Many2one('res.company', '公司', index=True, tracking=3, readonly=True, default=lambda self: self.env.company)
warehouse_ids = fields.Many2many('stock.warehouse', string="倉庫")
line_ids = fields.One2many('oms.network.line', 'network_id', string='貨主')
# 貨主
class OmsNetworkLine(models.Model):
_name = 'oms.network.line'
_description = 'OMS Network Line'
network_id = fields.Many2one('oms.network', string='倉網', required=True)
partner_id = fields.Many2one('res.partner', string='貨主', required=True)
warehouse_id = fields.Many2one('stock.warehouse', string="倉庫", required=True)
company_id = fields.Many2one('res.company', '公司', store=True, related='network_id.company_id')
class ResPartner(models.Model):
_inherit = ['res.partner']
_name = 'res.partner'
#...略
def _get_default_company_id(self):
if self.env.context.get('set_default_company', False):
return self.env.company
return False
company_id = fields.Many2one( # 註意,這個欄位和OmsNetwork.company_id關聯了相同模型,所以下文可用這個欄位進行搜索過濾
'res.company', 'Company', index=True,
check_company=False, tracking=3,
default=lambda self: self._get_default_company_id())
# 倉庫
class StockWarehouse(models.Model):
_inherit = 'stock.warehouse'
# ...略
# 註:沒有類似ResPartner的company_id欄位
視圖設計
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<data>
<!--此處代碼已省略-->
<record id="view_oms_network_form" model="ir.ui.view">
<field name="name">oms.network.form</field>
<field name="model">oms.network</field>
<field name="priority" eval="0"/>
<field name="arch" type="xml">
<form string="OMS Network">
<!--此處代碼已省略-->
<sheet>
<group>
<group>
<!--此處代碼已省略-->
</group>
<group>
<field name="company_id"/>
</group>
</group>
<notebook>
<page string="貨主" name="line_ids" >
<field name="line_ids">
<tree editable="bottom">
<field name="partner_id"/>
<field name="partner_code"/>
<field name="warehouse_id"/>
<!--此處代碼已省略-->
</tree>
</field>
</page>
<!--此處代碼已省略-->
</notebook>
</sheet>
<!--此處代碼已省略-->
</form>
</field>
</record>
<!--此處代碼已省略-->
</data>
</odoo>
添加過濾條件代碼實現
修改視圖,給視圖添加context
<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
<data>
<!--此處代碼已省略-->
<record id="view_oms_network_form" model="ir.ui.view">
<field name="name">oms.network.form</field>
<field name="model">oms.network</field>
<field name="priority" eval="0"/>
<field name="arch" type="xml">
<form string="OMS Network">
<!--此處代碼已省略-->
<sheet>
<group>
<group>
<!--此處代碼已省略-->
</group>
<group>
<field name="company_id"/>
</group>
</group>
<notebook>
<page string="貨主" name="line_ids" >
<field name="line_ids" context="{'oms_network_id':active_id, 'oms_network_company_id': company_id}">
<tree editable="bottom">
<field name="partner_id" context="{'oms_network_company_id':context.get('oms_network_company_id')}"/>
<field name="partner_code"/>
<field name="warehouse_id" context="{'oms_network_id':context.get('oms_network_id')}"/>
<!--此處代碼已省略-->
</tree>
</field>
</page>
<!--此處代碼已省略-->
</notebook>
</sheet>
<!--此處代碼已省略-->
</form>
</field>
</record>
<!--此處代碼已省略-->
</data>
</odoo>
修改ResPartner
,重寫模型name_search
(編輯貨主欄位,彈出下拉列表時,會請求該模型函數),search_read
(編輯貨主欄位,點擊下拉列表時 搜索更多打開界面時,會請求該模型函數)
提示:分析OmsNetworkLine
模型定義可知道,貨主欄位(partner_id
)為多對一欄位,關聯ResPartner
模型
class ResPartner(models.Model):
_inherit = ['res.partner']
_name = 'res.partner'
@api.model
def name_search(self, name='', args=None, operator='ilike', limit=100):
company_id = self.env.context.get('oms_network_company_id')
if company_id:
args = args or []
args.append(('company_id', '=', company_id))
res = super(ResPartner, self).name_search(name, args, operator, limit)
return res
@api.model
def search_read(self, domain=None, fields=None, offset=0, limit=None, order=None):
company_id = self.env.context.get('oms_network_company_id')
if company_id:
domain = domain or []
domain.append(('company_id', '=', company_id))
return super(ResPartner, self).search_read(domain, fields, offset, limit, order)
修改StockWarehouse
,重寫模型name_search
,search_read
提示:分析OmsNetworkLine
模型定義可知道,倉庫欄位(warehouse_id
)為多對多欄位,關聯stock.warehouse
模型
class StockWarehouse(models.Model):
_inherit = 'stock.warehouse'
# ...略
def _check_multiwarehouse_group(self):
pass
@api.model
def name_search(self, name='', args=None, operator='ilike', limit=100):
oms_network_id = self.env.context.get('oms_network_id')
warehouse_ids = self.env['oms.network'].browse([oms_network_id]).warehouse_ids.ids
if oms_network_id:
args = args or []
args.append(('id', 'in', warehouse_ids))
res = super(StockWarehouse, self).name_search(name, args, operator, limit)
return res
@api.model
def search_read(self, domain=None, fields=None, offset=0, limit=None, order=None):
oms_network_id = self.env.context.get('oms_network_id')
warehouse_ids = self.env['oms.network'].browse([oms_network_id]).warehouse_ids.ids
if warehouse_ids:
domain = domain or []
domain.append(('id', 'in', warehouse_ids))
return super(StockWarehouse, self).search_read(domain, fields, offset, limit, order)
作者:授客
微信/QQ:1033553122
全國軟體測試QQ交流群:7156436
Git地址:https://gitee.com/ishouke
友情提示:限於時間倉促,文中可能存在錯誤,歡迎指正、評論!
作者五行缺錢,如果覺得文章對您有幫助,請掃描下邊的二維碼打賞作者,金額隨意,您的支持將是我繼續創作的源動力,打賞後如有任何疑問,請聯繫我!!!
微信打賞
支付寶打賞 全國軟體測試交流QQ群