欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

odoo?為可編輯列表視圖字段搜索添加查詢過濾條件的詳細過程

 更新時間:2023年02月20日 08:28:40   作者:授客  
Odoo 是基于 Python 寫的一系列開源商業(yè)應(yīng)用程序套裝,前身是 OpenERP,這篇文章主要介紹了odoo?為可編輯列表視圖字段搜索添加查詢過濾條件,需要的朋友可以參考下

Odoo 是基于 Python 寫的一系列開源商業(yè)應(yīng)用程序套裝,前身是 OpenERP。

此套裝可滿足中小型企業(yè)的一切應(yīng)用需求,例如,企業(yè)基本的進銷存、采購、銷售、MRP 生產(chǎn)制造、品保質(zhì)量保障、企業(yè)招聘、員工合同、休假、午餐管理、內(nèi)部論壇、車隊管理、內(nèi)部聊天 IM 溝通、客訴追溯管理、CRM 客戶關(guān)系管理、VOIP、E-Shop 電子商務(wù)、網(wǎng)店、企業(yè)官方網(wǎng)站,財務(wù)會計、銀行對賬、資產(chǎn)管理、HR 工資管理、預(yù)算管理、WMS 倉庫庫存管理、POS 街邊小攤、社區(qū)商店、項目管理、條碼、PLM 等等

實踐環(huán)境

Odoo 14.0-20221212 (Community Edition)

需求描述

如下圖,列表網(wǎng)倉記錄詳情頁面(form視圖),編輯內(nèi)聯(lián)視圖中的貨主記錄,為貨主和倉庫字段搜索,添加過濾條件,具體如下:

  • 添加、編輯貨主時,下拉列表中只展示選取和當(dāng)網(wǎng)倉記錄所屬公司關(guān)聯(lián)的貨主,點擊搜索更多,僅展示和當(dāng)前網(wǎng)倉記錄所屬公司關(guān)聯(lián)的貨主
  • 添加、編輯貨主時,下拉列表中只展示選取和當(dāng)網(wǎng)倉記錄關(guān)聯(lián)的倉庫(到 “倉庫” Tab頁中添加的倉庫),點擊搜索更多,僅展示和當(dāng)前網(wǎng)倉記錄關(guān)聯(lián)的倉庫。

模型設(shè)計

說明:為了更好的體現(xiàn)本文主題,部分非關(guān)鍵代碼已省略,即做了適當(dāng)?shù)哪P秃喕幚?/p>

# 網(wǎ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="倉庫")
    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='倉網(wǎng)', 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關(guān)聯(lián)了相同模型,所以下文可用這個字段進行搜索過濾
        '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字段

視圖設(shè)計

<?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>

添加過濾條件代碼實現(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,重寫模型name_search(編輯貨主字段,彈出下拉列表時,會請求該模型函數(shù)),search_read(編輯貨主字段,點擊下拉列表時 搜索更多打開界面時,會請求該模型函數(shù))

提示:分析OmsNetworkLine模型定義可知道,貨主字段(partner_id)為多對一字段,關(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,重寫模型name_search,search_read

提示:分析OmsNetworkLine模型定義可知道,倉庫字段(warehouse_id)為多對多字段,關(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 為可編輯列表視圖字段搜索添加查詢過濾條件的文章就介紹到這了,更多相關(guān)odoo視圖字段搜索添加查詢過濾條件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • Python類定義和類繼承詳解

    Python類定義和類繼承詳解

    這篇文章主要介紹了Python類定義和類繼承詳解,本文講解了類的私有屬性、類的方法、私有的類方法、類的專有方法、類的定義、類的單繼承、類的多繼承等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • python字符串的拼接方法總結(jié)

    python字符串的拼接方法總結(jié)

    這篇文章主要介紹了python字符串的拼接方法總結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-11-11
  • python雙向隊列deque的使用

    python雙向隊列deque的使用

    本文主要介紹了python雙向隊列deque的使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Python編寫一個多線程的12306搶票程序的示例

    Python編寫一個多線程的12306搶票程序的示例

    對于很多人來說,搶購火車票人們成了一個令人頭疼的問題,本文主要介紹了Python編寫一個多線程的12306搶票程序的示例,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • python安裝mysql-python簡明筆記(ubuntu環(huán)境)

    python安裝mysql-python簡明筆記(ubuntu環(huán)境)

    這篇文章主要介紹了python安裝mysql-python的方法,測試環(huán)境為ubuntu,較為詳細的記錄了安裝mysql-python過程中遇到的問題與解決方法,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • 如何使用OpenCV進行視頻讀取與處理的完整指南

    如何使用OpenCV進行視頻讀取與處理的完整指南

    OpenCV是一個開源的計算機視覺和機器學(xué)習(xí)軟件庫,廣泛應(yīng)用于圖像和視頻的處理,本篇文章將詳細解析如何使用OpenCV讀取和處理視頻,并結(jié)合實際的代碼示例來展示操作的全過程,同時探討一些性能優(yōu)化的策略
    2024-08-08
  • pandas多層索引的創(chuàng)建和取值以及排序的實現(xiàn)

    pandas多層索引的創(chuàng)建和取值以及排序的實現(xiàn)

    這篇文章主要介紹了pandas多層索引的創(chuàng)建和取值以及排序的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • python端口掃描系統(tǒng)實現(xiàn)方法

    python端口掃描系統(tǒng)實現(xiàn)方法

    這篇文章主要介紹了python端口掃描系統(tǒng)實現(xiàn)方法,可實現(xiàn)簡單的外網(wǎng)IP掃描及寫入MySQL數(shù)據(jù)庫等功能,需要的朋友可以參考下
    2014-11-11
  • 如何使用 Python 讀取文件和照片的創(chuàng)建日期

    如何使用 Python 讀取文件和照片的創(chuàng)建日期

    這篇文章主要介紹了如何使用 Python 讀取文件和照片的創(chuàng)建日期,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Python標(biāo)準(zhǔn)模塊--ContextManager上下文管理器的具體用法

    Python標(biāo)準(zhǔn)模塊--ContextManager上下文管理器的具體用法

    本篇文章主要介紹了Python標(biāo)準(zhǔn)模塊--ContextManager的具體用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11

最新評論