您好,登錄后才能下訂單哦!
這篇文章主要介紹“odoo怎么為可編輯列表視圖字段搜索添加查詢過濾條件”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“odoo怎么為可編輯列表視圖字段搜索添加查詢過濾條件”文章能幫助大家解決問題。
Odoo 是基于 Python 寫的一系列開源商業應用程序套裝,前身是 OpenERP。
此套裝可滿足中小型企業的一切應用需求,例如,企業基本的進銷存、采購、銷售、MRP 生產制造、品保質量保障、企業招聘、員工合同、休假、午餐管理、內部論壇、車隊管理、內部聊天 IM 溝通、客訴追溯管理、CRM 客戶關系管理、VOIP、E-Shop 電子商務、網店、企業官方網站,財務會計、銀行對賬、資產管理、HR 工資管理、預算管理、WMS 倉庫庫存管理、POS 街邊小攤、社區商店、項目管理、條碼、PLM 等等
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)
關于“odoo怎么為可編輯列表視圖字段搜索添加查詢過濾條件”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。