odoo 開發入門教程系列-準備一些操作(Action)?

来源:https://www.cnblogs.com/shouke/archive/2023/04/02/17253371.html
-Advertisement-
Play Games

準備一些操作(Action)? 到目前為止,我們主要通過聲明欄位和視圖來構建模塊。在任何真實的業務場景中,我們都希望將一些業務邏輯鏈接到操作按鈕。在我們的房地產示例中,我們希望能夠: 取消或將房產設置為已售出 接受或拒絕報價 有人可能會說,我們已經可以通過手動更改狀態來完成這些事情,但這並不太方便。 ...


準備一些操作(Action)?

到目前為止,我們主要通過聲明欄位和視圖來構建模塊。在任何真實的業務場景中,我們都希望將一些業務邏輯鏈接到操作按鈕。在我們的房地產示例中,我們希望能夠:

  • 取消或將房產設置為已售出
  • 接受或拒絕報價

有人可能會說,我們已經可以通過手動更改狀態來完成這些事情,但這並不太方便。此外,我們還想增加一些額外的處理:當報價被接受時,我們想設定房產的售價和買家。

操作類型(Action Type)

參考:本主題相關文檔可參考ActionsError management

在我們的房地產模塊中,我們希望將些業務邏輯和一些按鈕關聯,最常見的做法是:

  • 在視圖中添加一個按鈕,比如在視圖header部分:
<form>
    <header>
        <button name="action_do_something" type="object" string="Do Something"/>
    </header>
    <sheet>
        <field name="name"/>
    </sheet>
</form>
  • 將該按鈕和業務邏輯關聯:
from odoo import fields, models

class TestAction(models.Model):
    _name = "test.action"

    name = fields.Char()

    def action_do_something(self):
        for record in self:
            record.name = "Something"
        return True

通過將type="object"分配給我們的按鈕, Odoo框架將在給定模型上執行帶有name="action_do_something"的Python方法。

需要註意的第一個重要細節是,我們的方法名沒有首碼下劃線(_)。這使我們的方法成為一個公共方法,可以直接通過Odoo介面調用(通過RPC調用)。到目前為止,我們創建的所有方法(compute、onchange)都是在內部調用的,因此我們使用了首碼為下劃線的私有方法。除非需要從用戶界面調用方法,否則應始終將方法定義為私有。

還要註意,我們對self迴圈。始終假設可以對多個記錄調用同一個方法;這有利於重用性。

最後,公共方法應該始終返回一些東西,以便可以通過XML-RPC調用它。當有疑問時,只需return True即可。

Odoo源代碼中有數百個示例。其中一個例子是 視圖中的按鈕 和其對應的Python方法

<form class="o_lead_opportunity_form" js_class="crm_form">
    <header>
        <button name="action_set_won_rainbowman" string="Mark Won"
            type="object" class="oe_highlight"
            attrs="{'invisible': ['|','|', ('active','=',False), ('probability', '=', 100), ('type', '=', 'lead')]}"/>
        ...略
    def action_set_won_rainbowman(self):
        self.ensure_one()
        self.action_set_won()

        message = self._get_rainbowman_message()
        if message:
            return {
                'effect': {
                    'fadeout': 'slow',
                    'message': message,
                    'img_url': '/web/image/%s/%s/image_1024' % (self.team_id.user_id._name, self.team_id.user_id.id) if self.team_id.user_id.image_1024 else '/web/static/src/img/smile.svg',
                    'type': 'rainbow_man',
                }
            }
        return True

練習1

添加 ‘Cancel’ 和‘Sold’ 按鈕到 estate.property 模型。已取消的房產不能被設置為已出售,已出售的房產不能被取消。

預期效果動畫:

提示:為了拋出錯誤,可以使用 UserError 函數。

修改odoo14\custom\estate\views\estate_property_views.xml中的estate_property_view_form視圖

    <record id="estate_property_view_form" model="ir.ui.view">
        <field name="name">estate.property.form</field>
        <field name="model">estate.property</field>
        <field name="arch" type="xml">
            <form string="estate property form">
                <!-- header元素為本次新增 -->
                <header>
                    <button name="set_property_sold" type="object" string="SOLD"></button>                    
                    <button name="set_property_canceled" type="object" string="CANCEL"></button>
                </header>
                <sheet>
                    <h1>
                        <field name="name"/>
                    </h1>
                    <p>
                        <field name="tag_ids" widget="many2many_tags"/>
                    </p>
                    <group>
                        <group>
                            <!-- state 欄位為本次新增 -->
                            <field name="state" string="Status"></field>
                            <field name="property_type_id" string="Property Type"></field>
                            <field name="postcode" string="Postcode" ></field>
                            <field name="date_availability" string="Available From"></field>
                        </group>
                        <group>
                            <field name="expected_price" string="Expected Price"></field>
                            <field name="best_price" string="Best Price" />
                            <field name="selling_price" string="Selling Price"></field>
                        </group>
                    </group>
                    <notebook>
                        <page string="Description">
                            <group>
                                <field name="description"></field>
                                <field name="bedrooms"></field>
                                <field name="living_area"></field>
                                <field name="facades"></field>
                                <field name="garage"></field>
                                <field name="garden"></field>
                                <field name="garden_area"></field>
                                <field name="garden_orientation"></field>
                                <field name="total_area" string="Total Area"></field>
                            </group>
                        </page>
                        <page string="Offers">
                            <field name="offer_ids" />
                        </page>
                        <page string="Other info">
                            <group>
                                <field name="salesman_id" string="Salesman"></field>
                                <field name="buyer_id" string="Buyer"></field>
                            </group>
                        </page>
                    </notebook>
                </sheet>
            </form>
        </field>
    </record>

修改odoo14\custom\estate\models\estate_property.py

開頭增加導入UserError

from odoo.exceptions import UserError

末尾新增以下代碼

    def set_property_canceled(self):
        if self.state == 'Sold':
            raise UserError('不能取消已出售房產')
        else:
            self.state = 'Canceled'

        return True

    def set_property_sold(self):
        if self.state == 'Canceled':
            raise UserError('不能出售已取消房產')
        else:
            self.state = 'Sold'

        return True

重啟服務,瀏覽器中驗證

練習2

添加‘Accept’ 和‘Refuse’ 到estate.property.offer 模型。

預期效果動畫:

提示: 把圖標當按鈕用,請查看這個例子

<button name="action_confirm" string="Confirm" states="draft" type="object" icon="fa-check"/>

修改odoo14\custom\estate\views\estate_property_offer_views.xmlestate_property_offer_view_tree

    <record id="estate_property_offer_view_tree" model="ir.ui.view">
        <field name="name">estate.property.offer.tree</field>
        <field name="model">estate.property.offer</field>
        <field name="arch" type="xml">
            <tree string="PropertyOffers">
                <field name="price" string="Price"/>
                <field name="partner_id" string="partner ID"/>
                <field name="validity" string="Validity(days)"/>
                <field name="deadline" string="Deadline"/>
                <!-- button 為本次新增 -->
                <button name="action_accept_offer" string=""  type="object" icon="fa-check"/>
                <button name="action_refuse_offer" string=""  type="object" icon="fa-times"/>
                <field name="status" string="Status"/>
            </tree>
        </field>
    </record>

修改odoo14\custom\estate\models\estate_property_offer.py,最末尾添加以下代碼

    def action_accept_offer(self):
        self.status = 'Accepted'
        self.property_id.state = 'Offer Accepted'
        return True

    def action_refuse_offer(self):
        self.status = 'Refused'
        return True

重啟服務,瀏覽器中驗證

練習3

當報價被接受時,設定相應房產的買家和售價。

預期效果動畫:

註意:在現實生活中,給定房產只能接受一個報價!

修改odoo14\custom\estate\models\estate_property_offer.pyaction_accept_offer函數如下

    def action_accept_offer(self):
        self.status = 'Accepted'
        self.property_id.state = 'Offer Accepted'
        self.property_id.selling_price = 260000
        self.property_id.buyer_id = self.partner_id
        return True

重啟服務,瀏覽器中驗證

對象類型(Object Type)

“一些用戶界面”章節中,我們創建了連接到菜單的操作。你可能好奇,是否可以連接操作到按鈕。好消息,的確可以,其中一種實現方式如下:

<button type="action" name="%(test.test_model_action)d" string="My Action"/>

我們使用 type="action" 且在name中引用外部標識

作者:授客
微信/QQ:1033553122
全國軟體測試QQ交流群:7156436

Git地址:https://gitee.com/ishouke
友情提示:限於時間倉促,文中可能存在錯誤,歡迎指正、評論!
作者五行缺錢,如果覺得文章對您有幫助,請掃描下邊的二維碼打賞作者,金額隨意,您的支持將是我繼續創作的源動力,打賞後如有任何疑問,請聯繫我!!!
           微信打賞                        支付寶打賞                  全國軟體測試交流QQ群  
              


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本博文介紹CSS三大特性之一:優先順序。 1 規則 (1)若選擇器相同,則執行層疊性(層疊性:給相同的選擇器設置相同的樣式,則“後來居上”,後面設置的樣式會覆蓋前面設置的樣式); (2)若選擇器不同,則有優先順序。 2 選擇器權重 常見的選擇器權重如下表: 選擇器 權重 繼承或者*(通配符) 0,0,0 ...
  • RocketMQ 是大家耳熟能詳的消息隊列,開源項目 rocketmq-spring 可以幫助開發者在 Spring Boot 項目中快速整合 RocketMQ。 這篇文章會介紹 Spring Boot 項目使用 rocketmq-spring SDK 實現消息收發的操作流程,同時筆者會從開發者的角 ...
  • Java 8 中提供了許多函數式介面,包括Function、Consumer、Supplier、Predicate 等等。這 4 個介面就是本篇將要分享的內容 ...
  • SpringCloud基本介紹 SpringCloud官方文檔 1.提出問題 先思考一個問題,沒有微服務技術,是不是程式員就不能開發大型項目? 是可以的,對大型項目進行模塊劃分,對各個模塊進行實現。但模塊之間更多地是以API調用完成,耦合度較高,不利於拓展和維護(在沒有微服務技術時,很多大型項目就已 ...
  • 電腦網路基礎,考驗一個程式員的基本功,也能更快的篩選出更優秀的人才。 說說TCP的三次握手 假設發送端為客戶端,接收端為服務端。開始時客戶端和服務端的狀態都是CLOSED。 第一次握手:客戶端向服務端發起建立連接請求,客戶端會隨機生成一個起始序列號x,客戶端向服務端發送的欄位中包含標誌位SYN=1 ...
  • 如果一個BEAN類上加了@Transactional,則預設的該類及其子類的公開方法均會開啟事務,但有時某些業務場景下某些公開的方法可能並不需要事務,那這種情況該如何做呢? 常規的做法: 針對不同的場景及事務傳播特性,定義不同的公開方法【哪怕是同一種業務】,併在方法上添加@Transactional ...
  • 一言以蔽之:重寫 equals 方法是為了比較對象的內容是否相等,重寫 hashCode 方法是為了保證對象在哈希表等數據結構中的正確性。 1、在 Java 中,如果一個類重寫了 equals 方法,則必須同時重寫 hashCode 方法。這是因為在 Java 中,對象的 hashCode 值用於在 ...
  • “林子雨大數據” 實驗3 HBase操作與介面編程 環境搭建 VM虛擬機和Ubuntu系統的安裝 在Windows中使用VirtualBox安裝Ubuntu虛擬機(2020年7月版本)_廈大資料庫實驗室博客 (xmu.edu.cn) Hadoop安裝(偽分散式) Hadoop3.1.3安裝教程_單機 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...