在Odoo,当我从“我的管道”打开机会时,在那个机会上,我按下“新消息”按钮,然后来自该机会的客户(以及该机会的追随者)作为该消息的接收者:
在该邮件的收件人列表中,该客户的名称附近有一个选中的复选框。
这是因为文件addons/mail/static/src/xml/chatter.xml
有这个:
<!-- List of followers -->
<div class="o_composer_suggested_partners">
<t t-foreach='widget.suggested_partners' t-as='recipient'>
<div t-attf-title="Add as recipient and follower (reason: #{recipient.reason})">
<input type="checkbox"
t-att-checked="recipient.checked ? 'checked' : undefined"
t-att-data-fullname="recipient.full_name"/>
<t t-esc="recipient.name"/>
<t t-if="recipient.email_address">(<t t-esc="recipient.email_address"/>)</t>
</div>
</t>
</div>
并且悬停在其中一个不需要的收件人上会显示以下消息“添加为收件人和关注者(原因:客户)”。
addons/crm/models/crm_lead.py
中有相关的源代码
@api.multi
def _message_add_suggested_recipient(self, result, partner=None, email=None, reason=''):
""" Called by message_get_suggested_recipients, to add a suggested
recipient in the result dictionary. The form is :
partner_id, partner_name<partner_email> or partner_name, reason """
self.ensure_one()
if email and not partner:
# get partner info from email
partner_info = self.message_partner_info_from_emails([email])[0]
if partner_info.get('partner_id'):
partner = self.env['res.partner'].sudo().browse([partner_info['partner_id']])[0]
if email and email in [val[1] for val in result[self.ids[0]]]: # already existing email -> skip
return result
if partner and partner in self.message_partner_ids: # recipient already in the followers -> skip
return result
if partner and partner.id in [val[0] for val in result[self.ids[0]]]: # already existing partner ID -> skip
return result
if partner and partner.email: # complete profile: id, name <email>
result[self.ids[0]].append((partner.id, '%s<%s>' % (partner.name, partner.email), reason))
elif partner: # incomplete profile: id, name
result[self.ids[0]].append((partner.id, '%s' % (partner.name), reason))
else: # unknown partner, we are probably managing an email address
result[self.ids[0]].append((False, email, reason))
return result
@api.multi
def message_get_suggested_recipients(self):
""" Returns suggested recipients for ids. Those are a list of
tuple (partner_id, partner_name, reason), to be managed by Chatter. """
result = dict((res_id, []) for res_id in self.ids)
if 'user_id' in self._fields:
for obj in self.sudo(): # SUPERUSER because of a read on res.users that would crash otherwise
if not obj.user_id or not obj.user_id.partner_id:
continue
obj._message_add_suggested_recipient(result, partner=obj.user_id.partner_id, reason=self._fields['user_id'].string)
return result
在addons/mail/static/src/js/chatter.js
message_get_suggested_recipients: function () {
var self = this;
var email_addresses = _.pluck(this.suggested_partners, 'email_address');
return this.thread_dataset
.call('message_get_suggested_recipients', [[this.context.default_res_id], this.context])
.done(function (suggested_recipients) {
var thread_recipients = suggested_recipients[self.context.default_res_id];
_.each(thread_recipients, function (recipient) {
var parsed_email = utils.parse_email(recipient[1]);
if (_.indexOf(email_addresses, parsed_email[1]) === -1) {
self.suggested_partners.push({
checked: true,
partner_id: recipient[0],
full_name: recipient[1],
name: parsed_email[0],
email_address: parsed_email[1],
reason: recipient[2],
});
}
});
});
},
有没有办法默认情况下在这里没有为客户检查复选框?
那是对的吗?
crm_lead.py
中)以包含伙伴的“checked”= False。chatter.js
中)从参数recipient
获取检查值,而不是默认生成true
(checked: true
)。在/static/src/xml/chatter.xml
的模块中创建一个文件,其中包含以下内容:
<templates>
<t t-name="mail.chatter.ChatComposer" t-extend="mail.chatter.ChatComposer">
<t
t-jquery="input[type='checkbox'][t-att-data-fullname='recipient.full_name']"
t-operation="replace">
<input type="checkbox" t-att-data-fullname="recipient.full_name" />
</t>
</t>
</templates>
然后在清单中调用此文件:
{
# name, author, ...
'qweb': [
'static/src/xml/chatter.xml'
],
}
注意:这将改变Odoo中所有聊天的行为。它仅针对v10进行了测试。
在修补CZoellner先生提供的solution之后。谢谢!:)
我想出了一个解决方案:只是不知道如何打包它作为一个插件。
查看已注释的行已更改。
改变addons/mail/static/src/js/chatter.js
message_get_suggested_recipients: function () {
var self = this;
var email_addresses = _.pluck(this.suggested_partners, 'email_address');
return this.thread_dataset
.call('message_get_suggested_recipients', [[this.context.default_res_id], this.context])
.done(function (suggested_recipients) {
var thread_recipients = suggested_recipients[self.context.default_res_id];
_.each(thread_recipients, function (recipient) {
var parsed_email = utils.parse_email(recipient[1]);
if (_.indexOf(email_addresses, parsed_email[1]) === -1) {
self.suggested_partners.push({
//checked: true,
checked: recipient[3] || true,
partner_id: recipient[0],
full_name: recipient[1],
name: parsed_email[0],
email_address: parsed_email[1],
reason: recipient[2],
});
}
});
});
},
addons/mail/models/mail_thread.py
@api.multi
def _message_add_suggested_recipient(self, result, partner=None, email=None, reason=''):
""" Called by message_get_suggested_recipients, to add a suggested
recipient in the result dictionary. The form is :
partner_id, partner_name<partner_email> or partner_name, reason """
self.ensure_one()
if email and not partner:
# get partner info from email
partner_info = self.message_partner_info_from_emails([email])[0]
if partner_info.get('partner_id'):
partner = self.env['res.partner'].sudo().browse([partner_info['partner_id']])[0]
if email and email in [val[1] for val in result[self.ids[0]]]: # already existing email -> skip
return result
if partner and partner in self.message_partner_ids: # recipient already in the followers -> skip
return result
if partner and partner.id in [val[0] for val in result[self.ids[0]]]: # already existing partner ID -> skip
return result
if partner and partner.email: # complete profile: id, name <email>
#result[self.ids[0]].append((partner.id, '%s<%s>' % (partner.name, partner.email), reason))
result[self.ids[0]].append((partner.id, '%s<%s>' % (partner.name, partner.email), reason, False))
elif partner: # incomplete profile: id, name
result[self.ids[0]].append((partner.id, '%s' % (partner.name), reason))
else: # unknown partner, we are probably managing an email address
result[self.ids[0]].append((False, email, reason))
return result
这很有效!
为了使它成为Odoo中的插件,我创建了以下内容的插件:
manifest.朋友
# -*- coding: utf-8 -*-
{
...omitted for brewity...
'depends': ['base','crm','mail'],
'data': [
'views/chatter.xml'
]
...omitted for brewity...
}
静态/ src目录/ JS / chatter.js
odoo.define('addon1.chatter', function(require){
'use strict';
var composer = require('mail.composer');
composer.BasicComposer.include({
message_get_suggested_recipients: function () {
var self = this;
var email_addresses = _.pluck(this.suggested_partners, 'email_address');
return this.thread_dataset
.call('message_get_suggested_recipients', [[this.context.default_res_id], this.context])
.done(function (suggested_recipients) {
var thread_recipients = suggested_recipients[self.context.default_res_id];
_.each(thread_recipients, function (recipient) {
var parsed_email = utils.parse_email(recipient[1]);
if (_.indexOf(email_addresses, parsed_email[1]) === -1) {
self.suggested_partners.push({
checked: recipient[3] || true,
partner_id: recipient[0],
full_name: recipient[1],
name: parsed_email[0],
email_address: parsed_email[1],
reason: recipient[2],
});
}
});
});
}
});
});
意见/ chatter.xml
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<data>
<template id="assets_backend" name="addon1" inherit_id="web.assets_backend">
<xpath expr="." position="inside">
<script type="text/javascript" src="/addon1/static/src/js/chatter.js"></script>
</xpath>
</template>
</data>
</odoo>
车型/ models.py
# -*- coding: utf-8 -*-
from odoo import models, fields, api, tools
from odoo.addons.mail.models.mail_thread import MailThread
class addon1(models.AbstractModel):
_inherit = 'mail.thread'
@api.multi
def _message_add_suggested_recipient(self, result, partner=None, email=None, reason=''):
result = super(MailThread, self)._message_add_suggested_recipient(self, result, partner, email, reason)
if partner and partner.email: # complete profile: id, name <email>
result[self.ids[0]].append((partner.id, '%s<%s>' % (partner.name, partner.email), reason, False))
return result
在安装了这个插件后,我可以观察到当Odoo网站打开时,javascript(来自插件)加载,但是断点没有抓到正确的位置(当发出“新消息”时),这意味着加载的javascript无效。
怎么了?