[IMP] mail_activity_team: code improvements

pull/529/head
Jaime Arroyo 2020-07-06 11:20:40 +02:00
parent abcd022975
commit 6228db50d5
4 changed files with 66 additions and 57 deletions

View File

@ -11,7 +11,7 @@ def migrate(env, version):
'domain_force': "['|', '|', "
"('privacy', 'not in', ['private', 'team']),"
"'&', ('privacy', '=', 'private'),"
"('partner_ids', 'in', user.partner_id.id),"
"('partner_ids', '=', user.partner_id.id),"
"'&', ('privacy', '=', 'team'),"
"('team_id', 'in', user.activity_team_ids.ids)]"
})

View File

@ -10,11 +10,11 @@ class CalendarEvent(models.Model):
def _get_default_team_id(self, user_id=None):
if not user_id:
user_id = self.env.uid
res_model = self.env.context.get('default_res_model')
model = self.env['ir.model'].search(
[('model', '=', res_model)], limit=1)
domain = [('member_ids', 'in', [user_id])]
res_model = self.env.context.get('default_res_model')
if res_model:
model = self.env['ir.model'].search(
[('model', '=', res_model)], limit=1)
domain.extend(['|', ('res_model_ids', '=', False),
('res_model_ids', 'in', model.ids)])
return self.env['mail.activity.team'].search(domain, limit=1)
@ -27,8 +27,7 @@ class CalendarEvent(models.Model):
default=lambda s: s._get_default_team_id(),
)
@api.multi
def read(self, fields=None, load='_classic_read'):
def _get_read_fields(self, fields):
expected_fields = ['privacy', 'team_id']
extra_fields = []
fixed_fields = [
@ -36,12 +35,23 @@ class CalendarEvent(models.Model):
'duration', 'user_id', 'state', 'interval', 'count',
'recurrent_id_date', 'rrule'
]
recurrent_fields = self._get_recurrent_fields()
public_fields = list(set(
recurrent_fields + fixed_fields))
if not fields:
fields = list(self._fields)
for field in expected_fields:
if field not in fields:
fields.append(field)
extra_fields.append(field)
return fields, extra_fields, public_fields
@api.multi
def read(self, fields=None, load='_classic_read'):
# This function manages which fields a user can read based on the
# team it belongs.
fields, extra_fields, public_fields = self._get_read_fields(fields)
result = super().read(fields, load)
for r in result:
if r['team_id'] and r['privacy'] == 'team':
@ -52,9 +62,6 @@ class CalendarEvent(models.Model):
users = team.member_ids
if self.env.user not in users:
for f in r:
recurrent_fields = self._get_recurrent_fields()
public_fields = list(set(
recurrent_fields + fixed_fields))
if f not in public_fields:
if isinstance(r[f], list):
r[f] = []

View File

@ -14,7 +14,7 @@
<record id="calendar.calendar_event_rule_private" model="ir.rule">
<field name="name">Private or group events</field>
<field name="domain_force">['|', '|', ('privacy', 'not in', ['private', 'team']), '&amp;', ('privacy', '=', 'private'), ('partner_ids', 'in', user.partner_id.id), '&amp;', ('privacy', '=', 'team'), ('team_id', 'in', user.activity_team_ids.ids)]</field>
<field name="domain_force">['|', '|', ('privacy', 'not in', ['private', 'team']), '&amp;', ('privacy', '=', 'private'), ('partner_ids', '=', user.partner_id.id), '&amp;', ('privacy', '=', 'team'), ('team_id', 'in', user.activity_team_ids.ids)]</field>
</record>
</odoo>

View File

@ -1,95 +1,97 @@
# Copyright 2018 Eficent Business and IT Consulting Services, S.L.
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
from odoo.tests.common import TransactionCase
from odoo.tests.common import SavepointCase
from odoo.exceptions import ValidationError
from odoo.fields import Datetime
from datetime import timedelta
class TestMailActivityTeam(TransactionCase):
class TestMailActivityTeam(SavepointCase):
def setUp(self):
super(TestMailActivityTeam, self).setUp()
@classmethod
def setUpClass(cls):
super(TestMailActivityTeam, cls).setUpClass()
cls.env = cls.env(context=dict(
cls.env.context, tracking_disable=True, no_reset_password=True)
)
cls.env["mail.activity.team"].search([]).unlink()
self.env["mail.activity.team"].search([]).unlink()
self.employee = self.env['res.users'].create({
'company_id': self.env.ref("base.main_company").id,
cls.employee = cls.env['res.users'].create({
'company_id': cls.env.ref("base.main_company").id,
'name': "Employee",
'login': "csu",
'email': "crmuser@yourcompany.com",
'groups_id': [(6, 0, [
self.env.ref('base.group_user').id,
self.env.ref('base.group_partner_manager').id])]
cls.env.ref('base.group_user').id,
cls.env.ref('base.group_partner_manager').id])]
})
self.employee2 = self.env['res.users'].create({
'company_id': self.env.ref("base.main_company").id,
cls.employee2 = cls.env['res.users'].create({
'company_id': cls.env.ref("base.main_company").id,
'name': "Employee 2",
'login': "csu2",
'email': "crmuser2@yourcompany.com",
'groups_id': [(6, 0, [self.env.ref('base.group_user').id])]
'groups_id': [(6, 0, [cls.env.ref('base.group_user').id])]
})
self.partner_ir_model = self.env['ir.model']._get('res.partner')
cls.partner_ir_model = cls.env['ir.model']._get('res.partner')
activity_type_model = self.env['mail.activity.type']
self.activity1 = activity_type_model.create({
activity_type_model = cls.env['mail.activity.type']
cls.activity1 = activity_type_model.create({
'name': 'Initial Contact',
'days': 5,
'summary': 'ACT 1 : Presentation, barbecue, ... ',
'res_model_id': self.partner_ir_model.id,
'res_model_id': cls.partner_ir_model.id,
})
self.activity2 = activity_type_model.create({
cls.activity2 = activity_type_model.create({
'name': 'Call for Demo',
'days': 6,
'summary': 'ACT 2 : I want to show you my ERP !',
'res_model_id': self.partner_ir_model.id,
'res_model_id': cls.partner_ir_model.id,
})
self.partner_client = self.env.ref("base.res_partner_1")
cls.partner_client = cls.env.ref("base.res_partner_1")
self.act1 = self.env['mail.activity'].sudo(self.employee).create({
'activity_type_id': self.activity1.id,
cls.act1 = cls.env['mail.activity'].sudo(cls.employee).create({
'activity_type_id': cls.activity1.id,
'note': 'Partner activity 1.',
'res_id': self.partner_client.id,
'res_model_id': self.partner_ir_model.id,
'user_id': self.employee.id,
'res_id': cls.partner_client.id,
'res_model_id': cls.partner_ir_model.id,
'user_id': cls.employee.id,
})
self.team1 = self.env['mail.activity.team'].sudo().create({
cls.team1 = cls.env['mail.activity.team'].sudo().create({
'name': 'Team 1',
'res_model_ids': [(6, 0, [self.partner_ir_model.id])],
'member_ids': [(6, 0, [self.employee.id])],
'res_model_ids': [(6, 0, [cls.partner_ir_model.id])],
'member_ids': [(6, 0, [cls.employee.id])],
})
self.team2 = self.env['mail.activity.team'].sudo().create({
cls.team2 = cls.env['mail.activity.team'].sudo().create({
'name': 'Team 2',
'res_model_ids': [(6, 0, [self.partner_ir_model.id])],
'member_ids': [(6, 0, [self.employee.id, self.employee2.id])],
'res_model_ids': [(6, 0, [cls.partner_ir_model.id])],
'member_ids': [(6, 0, [cls.employee.id, cls.employee2.id])],
})
self.act2 = self.env['mail.activity'].sudo(self.employee).create({
'activity_type_id': self.activity2.id,
cls.act2 = cls.env['mail.activity'].sudo(cls.employee).create({
'activity_type_id': cls.activity2.id,
'note': 'Partner activity 2.',
'res_id': self.partner_client.id,
'res_model_id': self.partner_ir_model.id,
'user_id': self.employee.id,
'res_id': cls.partner_client.id,
'res_model_id': cls.partner_ir_model.id,
'user_id': cls.employee.id,
})
self.act3 = self.env['mail.activity'].sudo(self.employee).create({
'activity_type_id': self.browse_ref(
cls.act3 = cls.env['mail.activity'].sudo(cls.employee).create({
'activity_type_id': cls.env.ref(
'mail.mail_activity_data_meeting').id,
'note': 'Meeting activity 3.',
'res_id': self.partner_client.id,
'res_model_id': self.partner_ir_model.id,
'user_id': self.employee.id,
'team_id': self.team1.id,
'res_id': cls.partner_client.id,
'res_model_id': cls.partner_ir_model.id,
'user_id': cls.employee.id,
'team_id': cls.team1.id,
'summary': 'Metting activity'
})
self.start = Datetime.now()
self.stop = Datetime.to_string(
Datetime.from_string(self.start) + timedelta(hours=1)
cls.start = Datetime.now()
cls.stop = Datetime.to_string(
Datetime.from_string(cls.start) + timedelta(hours=1)
)
def test_meeting_blank(self):