odoo?為可編輯列表視圖字段搜索添加查詢(xún)過(guò)濾條件的詳細(xì)過(guò)程
Odoo 是基于 Python 寫(xiě)的一系列開(kāi)源商業(yè)應(yīng)用程序套裝,前身是 OpenERP。
此套裝可滿(mǎn)足中小型企業(yè)的一切應(yīng)用需求,例如,企業(yè)基本的進(jìn)銷(xiāo)存、采購(gòu)、銷(xiāo)售、MRP 生產(chǎn)制造、品保質(zhì)量保障、企業(yè)招聘、員工合同、休假、午餐管理、內(nèi)部論壇、車(chē)隊(duì)管理、內(nèi)部聊天 IM 溝通、客訴追溯管理、CRM 客戶(hù)關(guān)系管理、VOIP、E-Shop 電子商務(wù)、網(wǎng)店、企業(yè)官方網(wǎng)站,財(cái)務(wù)會(huì)計(jì)、銀行對(duì)賬、資產(chǎn)管理、HR 工資管理、預(yù)算管理、WMS 倉(cāng)庫(kù)庫(kù)存管理、POS 街邊小攤、社區(qū)商店、項(xiàng)目管理、條碼、PLM 等等
實(shí)踐環(huán)境
Odoo 14.0-20221212 (Community Edition)
需求描述
如下圖,列表網(wǎng)倉(cāng)記錄詳情頁(yè)面(form視圖),編輯內(nèi)聯(lián)視圖中的貨主記錄,為貨主和倉(cāng)庫(kù)字段搜索,添加過(guò)濾條件,具體如下:
- 添加、編輯貨主時(shí),下拉列表中只展示選取和當(dāng)網(wǎng)倉(cāng)記錄所屬公司關(guān)聯(lián)的貨主,點(diǎn)擊搜索更多,僅展示和當(dāng)前網(wǎng)倉(cāng)記錄所屬公司關(guān)聯(lián)的貨主
- 添加、編輯貨主時(shí),下拉列表中只展示選取和當(dāng)網(wǎng)倉(cāng)記錄關(guān)聯(lián)的倉(cāng)庫(kù)(到 “倉(cāng)庫(kù)” Tab頁(yè)中添加的倉(cāng)庫(kù)),點(diǎn)擊搜索更多,僅展示和當(dāng)前網(wǎng)倉(cāng)記錄關(guān)聯(lián)的倉(cāng)庫(kù)。


模型設(shè)計(jì)
說(shuō)明:為了更好的體現(xiàn)本文主題,部分非關(guān)鍵代碼已省略,即做了適當(dāng)?shù)哪P秃?jiǎn)化處理
# 網(wǎng)倉(cāng)
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="倉(cāng)庫(kù)")
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='倉(cāng)網(wǎng)', required=True)
partner_id = fields.Many2one('res.partner', string='貨主', required=True)
warehouse_id = fields.Many2one('stock.warehouse', string="倉(cāng)庫(kù)", 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( # 注意,這個(gè)字段和OmsNetwork.company_id關(guān)聯(lián)了相同模型,所以下文可用這個(gè)字段進(jìn)行搜索過(guò)濾
'res.company', 'Company', index=True,
check_company=False, tracking=3,
default=lambda self: self._get_default_company_id())
# 倉(cāng)庫(kù)
class StockWarehouse(models.Model):
_inherit = 'stock.warehouse'
# ...略
# 注:沒(méi)有類(lèi)似ResPartner的company_id字段
視圖設(shè)計(jì)
<?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>
添加過(guò)濾條件代碼實(shí)現(xiàn)
修改視圖,給視圖添加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,重寫(xiě)模型name_search(編輯貨主字段,彈出下拉列表時(shí),會(huì)請(qǐng)求該模型函數(shù)),search_read(編輯貨主字段,點(diǎn)擊下拉列表時(shí) 搜索更多打開(kāi)界面時(shí),會(huì)請(qǐng)求該模型函數(shù))
提示:分析OmsNetworkLine模型定義可知道,貨主字段(partner_id)為多對(duì)一字段,關(guān)聯(lián)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,重寫(xiě)模型name_search,search_read
提示:分析OmsNetworkLine模型定義可知道,倉(cāng)庫(kù)字段(warehouse_id)為多對(duì)多字段,關(guān)聯(lián)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)到此這篇關(guān)于odoo 為可編輯列表視圖字段搜索添加查詢(xún)過(guò)濾條件的文章就介紹到這了,更多相關(guān)odoo視圖字段搜索添加查詢(xún)過(guò)濾條件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python編寫(xiě)一個(gè)多線(xiàn)程的12306搶票程序的示例
對(duì)于很多人來(lái)說(shuō),搶購(gòu)火車(chē)票人們成了一個(gè)令人頭疼的問(wèn)題,本文主要介紹了Python編寫(xiě)一個(gè)多線(xiàn)程的12306搶票程序的示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
python安裝mysql-python簡(jiǎn)明筆記(ubuntu環(huán)境)
這篇文章主要介紹了python安裝mysql-python的方法,測(cè)試環(huán)境為ubuntu,較為詳細(xì)的記錄了安裝mysql-python過(guò)程中遇到的問(wèn)題與解決方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
pandas多層索引的創(chuàng)建和取值以及排序的實(shí)現(xiàn)
這篇文章主要介紹了pandas多層索引的創(chuàng)建和取值以及排序的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
python端口掃描系統(tǒng)實(shí)現(xiàn)方法
這篇文章主要介紹了python端口掃描系統(tǒng)實(shí)現(xiàn)方法,可實(shí)現(xiàn)簡(jiǎn)單的外網(wǎng)IP掃描及寫(xiě)入MySQL數(shù)據(jù)庫(kù)等功能,需要的朋友可以參考下2014-11-11
如何使用 Python 讀取文件和照片的創(chuàng)建日期
這篇文章主要介紹了如何使用 Python 讀取文件和照片的創(chuàng)建日期,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
Python標(biāo)準(zhǔn)模塊--ContextManager上下文管理器的具體用法
本篇文章主要介紹了Python標(biāo)準(zhǔn)模塊--ContextManager的具體用法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11

