Skip to Content
เมนู
คุณต้องลงทะเบียนเพื่อโต้ตอบกับคอมมูนิตี้
คำถามนี้ถูกตั้งค่าสถานะ
2 ตอบกลับ
4072 มุมมอง

I added an onchange function on the field "state" of the sale order to log the state to the log, the function is getting fired when the a quotation is created and it logs the "draft" state of the sale order, but when I confirm it or when create an invoice and pay it, the function is not fired.

The code looks like this:

import logging
from odoo import api, models
_logger = logging.getLogger(__name__)

class SaleOrder(models.Model):
   
_inherit = "sale.order"
    _description = "Sales Order"
    

    @api.onchange('state')
    
def_onchange_sale_order_state(self):
       
_logger.info("on order state change: %s", self.state)


eventually I want to create some records in another model when the quotation is confirmed and turned into sale order.


Any ideas why it's not working?

อวตาร
ละทิ้ง
คำตอบที่ดีที่สุด

While creating and paying invoices sales order invoice state changes not the order state so you must add invoice_status too in your onchange method.

อวตาร
ละทิ้ง
ผู้เขียน

Well what I'm trying to reach is to have some action fired when the "sale quotation" turned into a "sale order", this is before creating an invoice or paying it.
The flow is "quotation" => "quotation sent" => "sale order", after that you create a invoice.

คำตอบที่ดีที่สุด

Hi Omar,

The Onchange will never get called if the state is changed with the buttons on top of the form. instead the action "action_confirm()" is called. so for your code to work you have to do:

def action_confirm(self):
        _logger.info("on order state change: %s", self.state)
        super().action_confirm()

อวตาร
ละทิ้ง
Related Posts ตอบกลับ มุมมอง กิจกรรม
1
ส.ค. 25
2337
Sales quotation แก้ไขแล้ว
2
มี.ค. 24
5310
2
มี.ค. 22
2099
0
เม.ย. 19
5812
1
มี.ค. 15
5191