Skip to Content
Menu
Musisz się zarejestrować, aby móc wchodzić w interakcje z tą społecznością.
To pytanie dostało ostrzeżenie
2 Odpowiedzi
7233 Widoki

Hi,

In model "mail.message" , I want to set the value 'Employee Only' by default True , if the Type is a comment.

So , I inherited the method create from "mail.message" I added the condition in the function , but I still having errors , what's wrong? Any help please?

class MessageExtend(models.Model):
    _inherit = "mail.message"
     
    def create(self, values_list):
        tracking_values_list = []
        for values in values_list:

               if 'message_type' in ['comment']:
                self.is_internal = True

            if 'email_from' not in values:  # needed to compute reply_to
                author_id, email_from = self.env['mail.thread']._message_compute_author(values.get('author_id'),
                                                                                        email_from=None,
                                                                                        raise_exception=False)
                values['email_from'] = email_from


   .....

Thanks.

Awatar
Odrzuć
Najlepsza odpowiedź

Hello Christina, 

I would suggest using this code, I have tested and works well for me:

class MailClass(models.Model):
    _inherit = "mail.message"
    @api.model_create_multi
    def create(self, vals):
        records = super(MailClass, self).create(vals)
        for record in records:
            # if the message type of the mail.message is a comment, mark as internal
            if record.message_type == "comment":
                record.is_internal = True
        return records
              When overriding a function it is best practice to call the base function using super instead of copy and pasting the code, this will help when migrating Odoo versions. Meaning if the base function changes it should be an issue as you are still supplying code with the correct parameters it needs. 

              I hope this solves your issue,

              Thanks, 
              Awatar
              Odrzuć
              Najlepsza odpowiedź

              Hi,

              Update the function like this and see:

                if 'message_type' in ['comment']:
                              values_list['is_internal'] = True


              Thanks

              Awatar
              Odrzuć

              Hello Niyas,

              Would it be:

              if 'message_type' in values_list['comment'] ? This is a good idea to change before supplying into the function.

              Thanks,

              Sorry more like

              "if values_list['message_type'] == "comment"'

              Powiązane posty Odpowiedzi Widoki Czynność
              0
              wrz 23
              41
              4
              mar 23
              16694
              2
              lip 22
              3560
              0
              maj 22
              1870
              1
              lis 21
              18269