diff --git a/mail_activity_team/README.rst b/mail_activity_team/README.rst new file mode 100644 index 0000000000..6f46e8a9f7 --- /dev/null +++ b/mail_activity_team/README.rst @@ -0,0 +1,125 @@ +================== +Mail Activity Team +================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:1ec2986e180d35e605a67ecb2b8256da4ee87b09abedeab928d81618833db93c + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png + :target: https://odoo-community.org/page/development-status + :alt: Alpha +.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fsocial-lightgray.png?logo=github + :target: https://github.com/OCA/social/tree/17.0/mail_activity_team + :alt: OCA/social +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/social-17-0/social-17-0-mail_activity_team + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/social&target_branch=17.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module adds the possibility to assign teams to activities. + +.. IMPORTANT:: + This is an alpha version, the data model and design can change at any time without warning. + Only for development or testing purpose, do not use in production. + `More details on development status `_ + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +To set up new teams: + +1. Go to *Settings / Activate developer mode* +2. Go to *Settings / Technical / Discuss / Activity Teams* +3. Create a new Team and assign (optionally) the models in which it will + be used, and the members of the team. + +You can also assign a user to Activity teams going to *Settings / Users +& Companies / Users*, and in the *Preferences* tab, field Activity +Teams. + +When you create a new activity the application will propose the user's +assigned team. + +You can report on the activities assigned to a team going to *Dashboards +/ Activities*, and then filter by a specific team or group by teams. + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* ForgeFlow +* Sodexis + +Contributors +------------ + +- `ForgeFlow `__: + + - Jordi Ballester Alomar (jordi.ballester@forgeflow.com) + - Miquel Raïch (miquel.raich@forgeflow.com) + - Bernat Puig Font (bernat.puig@forgeflow.com) + +- Pedro Gonzalez (pedro.gonzalez@pesol.es) +- `Tecnativa `__: + + - David Vidal + +- `Dynapps `__: + + - Raf Ven + +- [Trobz] (https://trobz.com): + + - Son Ho sonhd@trobz.com + +Other credits +------------- + +The migration of this module from 16.0 to 17.0 was financially supported +by Camptocamp + +Maintainers +----------- + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +This module is part of the `OCA/social `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/mail_activity_team/__init__.py b/mail_activity_team/__init__.py new file mode 100644 index 0000000000..0650744f6b --- /dev/null +++ b/mail_activity_team/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/mail_activity_team/__manifest__.py b/mail_activity_team/__manifest__.py new file mode 100644 index 0000000000..3e34a73678 --- /dev/null +++ b/mail_activity_team/__manifest__.py @@ -0,0 +1,30 @@ +# Copyright 2018-22 ForgeFlow S.L. +# Copyright 2021 Sodexis +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +{ + "name": "Mail Activity Team", + "summary": "Add Teams to Activities", + "version": "17.0.1.0.0", + "development_status": "Alpha", + "category": "Social Network", + "website": "https://github.com/OCA/social", + "author": "ForgeFlow, Sodexis, Odoo Community Association (OCA)", + "license": "AGPL-3", + "installable": True, + "depends": ["mail_activity_board"], + "data": [ + "security/ir.model.access.csv", + "security/mail_activity_team_security.xml", + "views/ir_actions_server_views.xml", + "views/mail_activity_type.xml", + "views/mail_activity_team_views.xml", + "views/mail_activity_views.xml", + "views/res_users_views.xml", + ], + "assets": { + "web.assets_backend": [ + "mail_activity_team/static/src/components/*/*", + "mail_activity_team/static/src/models/*", + ], + }, +} diff --git a/mail_activity_team/i18n/es.po b/mail_activity_team/i18n/es.po new file mode 100644 index 0000000000..462dd00982 --- /dev/null +++ b/mail_activity_team/i18n/es.po @@ -0,0 +1,209 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * mail_activity_team +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-11-08 12:58+0000\n" +"Last-Translator: Ivorra78 \n" +"Language-Team: none\n" +"Language: es\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.17\n" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__active +msgid "Active" +msgstr "Activado" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity +msgid "Activity" +msgstr "Actividad" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_mixin +msgid "Activity Mixin" +msgstr "Mezclador de Actividad" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_actions_server__activity_team_id +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_cron__activity_team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Activity Team" +msgstr "Equipo de Actividad" + +#. module: mail_activity_team +#: model:ir.actions.act_window,name:mail_activity_team.mail_activity_team_action +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_ids +#: model:ir.ui.menu,name:mail_activity_team.menu_mail_activity_team +msgid "Activity Teams" +msgstr "Equipos de Actividad" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_type +msgid "Activity Type" +msgstr "Tipo de Actividad" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Archived" +msgstr "Archivado" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Assign to missing activities" +msgstr "Asignar a Actividades pendientes" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_uid +msgid "Created by" +msgstr "Creado por" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_date +msgid "Created on" +msgstr "Creado el" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_type__default_team_id +msgid "Default Team" +msgstr "Equipo Predeterminado" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__display_name +msgid "Display Name" +msgstr "Mostrar Nombre" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__id +msgid "ID" +msgstr "ID (identificación)" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team____last_update +msgid "Last Modified on" +msgstr "Última Modificación el" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_uid +msgid "Last Updated by" +msgstr "Actualizado por Última vez por" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_date +msgid "Last Updated on" +msgstr "Última Actualización el" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_team +msgid "Mail Activity Team" +msgstr "Equipo de Actividad Postal" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Members" +msgstr "Miembros" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__count_missing_activities +msgid "Missing Activities" +msgstr "Actividades Pendientes" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "My Activities" +msgstr "Mis Actividades" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "My Team Activities" +msgstr "Mis Actividades en Equipo" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__name +msgid "Name" +msgstr "nombre" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_ir_actions_server +msgid "Server Action" +msgstr "Acción de Servidor" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "Team" +msgstr "Equipo" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "Team Activities" +msgstr "Actividades de Equipo" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__user_id +msgid "Team Leader" +msgstr "Líder de Equipo" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__member_ids +msgid "Team Members" +msgstr "Miembros del Equipo" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_user_id +msgid "Team user" +msgstr "Usuario del Equipo" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_kanban +msgid "Team:" +msgstr "Equipo:" + +#. module: mail_activity_team +#. odoo-python +#: code:addons/mail_activity_team/models/mail_activity.py:0 +#, python-format +msgid "" +"The assigned user %(user_name)s is not member of the team %(team_name)s." +msgstr "" +"El usuario asignado %(user_name)s no es miembro del equipo %(team_name)s." + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__res_model_ids +msgid "Used models" +msgstr "Modelos usados" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_res_users +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__user_id +msgid "User" +msgstr "Usuario" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_account_bank_statement_line__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_journal__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_move__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_payment__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_setup_bank_manual_config__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_event__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_registration__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_mixin__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mailing_mailing__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_product__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_template__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner_bank__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_user_ids +msgid "test field" +msgstr "campo de prueba" diff --git a/mail_activity_team/i18n/fr.po b/mail_activity_team/i18n/fr.po new file mode 100644 index 0000000000..24ed607587 --- /dev/null +++ b/mail_activity_team/i18n/fr.po @@ -0,0 +1,208 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * mail_activity_team +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 15.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2022-03-10 10:17+0000\n" +"Last-Translator: tfo \n" +"Language-Team: none\n" +"Language: fr\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n > 1;\n" +"X-Generator: Weblate 4.3.2\n" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__active +msgid "Active" +msgstr "Actif" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity +msgid "Activity" +msgstr "Activité" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_mixin +msgid "Activity Mixin" +msgstr "Combinaison d'activités" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_actions_server__activity_team_id +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_cron__activity_team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Activity Team" +msgstr "Equipe d'activité" + +#. module: mail_activity_team +#: model:ir.actions.act_window,name:mail_activity_team.mail_activity_team_action +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_ids +#: model:ir.ui.menu,name:mail_activity_team.menu_mail_activity_team +msgid "Activity Teams" +msgstr "Equipes d'activité" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_type +msgid "Activity Type" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Archived" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Assign to missing activities" +msgstr "Assigner une équipe aux activités manquantes" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_uid +msgid "Created by" +msgstr "Créé par" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_date +msgid "Created on" +msgstr "Créé le" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_type__default_team_id +msgid "Default Team" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__display_name +msgid "Display Name" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__id +msgid "ID" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team____last_update +msgid "Last Modified on" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_date +msgid "Last Updated on" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_team +msgid "Mail Activity Team" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Members" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__count_missing_activities +msgid "Missing Activities" +msgstr "" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "My Activities" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "My Team Activities" +msgstr "Activités de mon équipe" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__name +msgid "Name" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_ir_actions_server +msgid "Server Action" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "Team" +msgstr "" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "Team Activities" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__user_id +msgid "Team Leader" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__member_ids +msgid "Team Members" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_user_id +msgid "Team user" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_kanban +msgid "Team:" +msgstr "" + +#. module: mail_activity_team +#. odoo-python +#: code:addons/mail_activity_team/models/mail_activity.py:0 +#, python-format +msgid "" +"The assigned user %(user_name)s is not member of the team %(team_name)s." +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__res_model_ids +msgid "Used models" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_res_users +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__user_id +msgid "User" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_account_bank_statement_line__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_journal__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_move__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_payment__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_setup_bank_manual_config__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_event__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_registration__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_mixin__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mailing_mailing__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_product__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_template__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner_bank__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_user_ids +msgid "test field" +msgstr "" diff --git a/mail_activity_team/i18n/it.po b/mail_activity_team/i18n/it.po new file mode 100644 index 0000000000..867e9151db --- /dev/null +++ b/mail_activity_team/i18n/it.po @@ -0,0 +1,215 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * mail_activity_team +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 13.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-12-20 14:36+0000\n" +"Last-Translator: mymage \n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.17\n" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__active +msgid "Active" +msgstr "Attivo" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity +msgid "Activity" +msgstr "Attività" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_mixin +msgid "Activity Mixin" +msgstr "Mixin attività" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_actions_server__activity_team_id +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_cron__activity_team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Activity Team" +msgstr "Team Attività" + +#. module: mail_activity_team +#: model:ir.actions.act_window,name:mail_activity_team.mail_activity_team_action +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_ids +#: model:ir.ui.menu,name:mail_activity_team.menu_mail_activity_team +msgid "Activity Teams" +msgstr "Team Attività" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_type +msgid "Activity Type" +msgstr "Tipo attività" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Archived" +msgstr "In archivio" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Assign to missing activities" +msgstr "Assegna ad attività mancanti" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_uid +msgid "Created by" +msgstr "Creato da" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_date +msgid "Created on" +msgstr "Creato il" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_type__default_team_id +msgid "Default Team" +msgstr "Team predefinito" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__display_name +msgid "Display Name" +msgstr "Nome visualizzato" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__id +msgid "ID" +msgstr "ID" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team____last_update +msgid "Last Modified on" +msgstr "Ultima modifica il" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_uid +msgid "Last Updated by" +msgstr "Ultimo aggiornamento di" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_date +msgid "Last Updated on" +msgstr "Ultima Modifica il" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_team +msgid "Mail Activity Team" +msgstr "Team Attività Messaggi" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Members" +msgstr "Membri" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__count_missing_activities +msgid "Missing Activities" +msgstr "Attività Mancanti" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "My Activities" +msgstr "Le mie attività" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "My Team Activities" +msgstr "Attività del mio team" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__name +msgid "Name" +msgstr "Nome" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_ir_actions_server +msgid "Server Action" +msgstr "Azione server" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "Team" +msgstr "Team" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "Team Activities" +msgstr "Attività del mio team" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__user_id +msgid "Team Leader" +msgstr "Team leader" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__member_ids +msgid "Team Members" +msgstr "Membri Team" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_user_id +msgid "Team user" +msgstr "Utente del team" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_kanban +msgid "Team:" +msgstr "Team:" + +#. module: mail_activity_team +#. odoo-python +#: code:addons/mail_activity_team/models/mail_activity.py:0 +#, python-format +msgid "" +"The assigned user %(user_name)s is not member of the team %(team_name)s." +msgstr "" +"L'utente assegnato %(user_name)s nn è un membro del team %(team_name)s." + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__res_model_ids +msgid "Used models" +msgstr "Modelli usati" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_res_users +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__user_id +msgid "User" +msgstr "Utente" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_account_bank_statement_line__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_journal__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_move__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_payment__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_setup_bank_manual_config__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_event__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_registration__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_mixin__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mailing_mailing__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_product__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_template__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner_bank__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_user_ids +msgid "test field" +msgstr "campo test" + +#~ msgid "Users" +#~ msgstr "Utenti" + +#~ msgid "The assigned user is not member of the team." +#~ msgstr "L'utente assegnato non è un membro del team." diff --git a/mail_activity_team/i18n/mail_activity_team.pot b/mail_activity_team/i18n/mail_activity_team.pot new file mode 100644 index 0000000000..e0bcc35a2f --- /dev/null +++ b/mail_activity_team/i18n/mail_activity_team.pot @@ -0,0 +1,205 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * mail_activity_team +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__active +msgid "Active" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity +msgid "Activity" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_mixin +msgid "Activity Mixin" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_actions_server__activity_team_id +#: model:ir.model.fields,field_description:mail_activity_team.field_ir_cron__activity_team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Activity Team" +msgstr "" + +#. module: mail_activity_team +#: model:ir.actions.act_window,name:mail_activity_team.mail_activity_team_action +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_ids +#: model:ir.ui.menu,name:mail_activity_team.menu_mail_activity_team +msgid "Activity Teams" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_type +msgid "Activity Type" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Archived" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Assign to missing activities" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_uid +msgid "Created by" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__create_date +msgid "Created on" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_type__default_team_id +msgid "Default Team" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__display_name +msgid "Display Name" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__id +msgid "ID" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team____last_update +msgid "Last Modified on" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__write_date +msgid "Last Updated on" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_mail_activity_team +msgid "Mail Activity Team" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_team_view_form +msgid "Members" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__count_missing_activities +msgid "Missing Activities" +msgstr "" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "My Activities" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "My Team Activities" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__name +msgid "Name" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_ir_actions_server +msgid "Server Action" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_id +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_search +msgid "Team" +msgstr "" + +#. module: mail_activity_team +#. odoo-javascript +#: code:addons/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml:0 +#, python-format +msgid "Team Activities" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__user_id +msgid "Team Leader" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__member_ids +msgid "Team Members" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__team_user_id +msgid "Team user" +msgstr "" + +#. module: mail_activity_team +#: model_terms:ir.ui.view,arch_db:mail_activity_team.mail_activity_view_kanban +msgid "Team:" +msgstr "" + +#. module: mail_activity_team +#. odoo-python +#: code:addons/mail_activity_team/models/mail_activity.py:0 +#, python-format +msgid "" +"The assigned user %(user_name)s is not member of the team %(team_name)s." +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_team__res_model_ids +msgid "Used models" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model,name:mail_activity_team.model_res_users +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity__user_id +msgid "User" +msgstr "" + +#. module: mail_activity_team +#: model:ir.model.fields,field_description:mail_activity_team.field_account_bank_statement_line__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_journal__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_move__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_payment__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_account_setup_bank_manual_config__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_event__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_event_registration__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mail_activity_mixin__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_mailing_mailing__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_product__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_product_template__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_partner_bank__activity_team_user_ids +#: model:ir.model.fields,field_description:mail_activity_team.field_res_users__activity_team_user_ids +msgid "test field" +msgstr "" diff --git a/mail_activity_team/models/__init__.py b/mail_activity_team/models/__init__.py new file mode 100644 index 0000000000..32109baf12 --- /dev/null +++ b/mail_activity_team/models/__init__.py @@ -0,0 +1,6 @@ +from . import ir_actions_server +from . import mail_activity_team +from . import mail_activity +from . import mail_activity_mixin +from . import res_users +from . import mail_activity_type diff --git a/mail_activity_team/models/ir_actions_server.py b/mail_activity_team/models/ir_actions_server.py new file mode 100644 index 0000000000..9a005da2dd --- /dev/null +++ b/mail_activity_team/models/ir_actions_server.py @@ -0,0 +1,20 @@ +# Copyright 2023 Camptocamp SA (https://www.camptocamp.com). +# @author Iván Todorovich +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class IrActionsServer(models.Model): + _inherit = "ir.actions.server" + + activity_team_id = fields.Many2one( + "mail.activity.team", + string="Activity Team", + ) + + def _run_action_next_activity(self, eval_context=None): + # OVERRIDE to force the activity team on scheduled actions + if self.activity_user_type == "specific" and self.activity_team_id: + self = self.with_context(force_activity_team=self.activity_team_id) + return super()._run_action_next_activity(eval_context=eval_context) diff --git a/mail_activity_team/models/mail_activity.py b/mail_activity_team/models/mail_activity.py new file mode 100644 index 0000000000..418dc04328 --- /dev/null +++ b/mail_activity_team/models/mail_activity.py @@ -0,0 +1,87 @@ +# Copyright 2018-22 ForgeFlow S.L. +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). + +from odoo import SUPERUSER_ID, _, api, fields, models +from odoo.exceptions import ValidationError + + +class MailActivity(models.Model): + _inherit = "mail.activity" + + 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.sudo().env["ir.model"].search([("model", "=", res_model)], limit=1) + domain = [("member_ids", "in", [user_id])] + if res_model: + domain.extend( + ["|", ("res_model_ids", "=", False), ("res_model_ids", "in", model.ids)] + ) + return self.env["mail.activity.team"].search(domain, limit=1) + + user_id = fields.Many2one(string="User", required=False) + team_user_id = fields.Many2one( + string="Team user", related="user_id", readonly=False + ) + + team_id = fields.Many2one( + comodel_name="mail.activity.team", default=lambda s: s._get_default_team_id() + ) + + @api.onchange("user_id") + def _onchange_user_id(self): + if not self.user_id or ( + self.team_id and self.user_id in self.team_id.member_ids + ): + return + self.team_id = self.with_context( + default_res_model=self.sudo().res_model_id.model + )._get_default_team_id(user_id=self.user_id.id) + + @api.onchange("team_id") + def _onchange_team_id(self): + if self.team_id and self.user_id not in self.team_id.member_ids: + if self.team_id.user_id: + self.user_id = self.team_id.user_id + elif len(self.team_id.member_ids) == 1: + self.user_id = self.team_id.member_ids + else: + self.user_id = self.env["res.users"] + + @api.constrains("team_id", "user_id") + def _check_team_and_user(self): + for activity in self: + # SUPERUSER is used to put mail.activity on some objects + # like sale.order coming from stock.picking + # (for example with exception type activity, with no backorder). + # SUPERUSER is inactive and then even if you add it + # to member_ids it's not taken account + # To not be blocked we must add it to constraint condition. + # We must consider also users that could be archived but come from + # an automatic scheduled activity + if ( + activity.user_id.id != SUPERUSER_ID + and activity.team_id + and activity.user_id + and activity.user_id + not in activity.team_id.with_context(active_test=False).member_ids + ): + raise ValidationError( + _( + "The assigned user %(user_name)s is " + "not member of the team %(team_name)s.", + user_name=activity.user_id.name, + team_name=activity.team_id.name, + ) + ) + + @api.onchange("activity_type_id") + def _onchange_activity_type_id(self): + res = super()._onchange_activity_type_id() + if self.activity_type_id.default_team_id: + self.team_id = self.activity_type_id.default_team_id + members = self.activity_type_id.default_team_id.member_ids + if self.user_id not in members and members: + self.user_id = members[:1] + return res diff --git a/mail_activity_team/models/mail_activity_mixin.py b/mail_activity_team/models/mail_activity_mixin.py new file mode 100644 index 0000000000..4d844e8a3f --- /dev/null +++ b/mail_activity_team/models/mail_activity_mixin.py @@ -0,0 +1,100 @@ +# Copyright 2021 Tecnativa - David Vidal +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +from odoo import api, fields, models + + +class MailActivityMixin(models.AbstractModel): + _inherit = "mail.activity.mixin" + + activity_team_user_ids = fields.Many2many( + comodel_name="res.users", + string="test field", + compute="_compute_activity_team_user_ids", + search="_search_activity_team_user_ids", + ) + + @api.depends("activity_ids") + def _compute_activity_team_user_ids(self): + for rec in self: + rec.activity_team_user_ids = rec.activity_ids.mapped("team_id.member_ids") + + def _search_my_activity_date_deadline(self, operator, operand): + if not self._context.get("team_activities", False): + return super()._search_my_activity_date_deadline(operator, operand) + activity_ids = self.env["mail.activity"]._search( + [ + ("date_deadline", operator, operand), + ("res_model", "=", self._name), + "|", + ("user_id", "=", self.env.user.id), + ("team_id", "in", self.env.user.activity_team_ids.ids), + ] + ) + return [("activity_ids", "in", activity_ids)] + + @api.model + def _search_activity_team_user_ids(self, operator, operand): + return [("activity_ids.team_id.member_ids", operator, operand)] + + def activity_schedule( + self, act_type_xmlid="", date_deadline=None, summary="", note="", **act_values + ): + """With automatic activities, the user onchange won't act so we must + ensure the right group is set and no exceptions are raised due to + user-team missmatch. We can hook onto `act_values` dict as it's passed + to the create activity method. + """ + if self.env.context.get("force_activity_team"): + act_values["team_id"] = self.env.context["force_activity_team"].id + if "team_id" not in act_values: + if act_type_xmlid: + activity_type = self.sudo().env.ref(act_type_xmlid) + else: + activity_type = ( + self.env["mail.activity.type"] + .sudo() + .browse(act_values["activity_type_id"]) + ) + if activity_type.default_team_id: + act_values.update({"team_id": activity_type.default_team_id.id}) + if ( + not act_values.get("user_id") + and activity_type.default_team_id.member_ids + ): + act_values.update( + {"user_id": activity_type.default_team_id.member_ids[:1].id} + ) + else: + user_id = act_values.get("user_id") + if user_id: + team = ( + self.env["mail.activity"] + .with_context( + default_res_model=self._name, + ) + ._get_default_team_id(user_id=user_id) + ) + act_values.update({"team_id": team.id}) + return super().activity_schedule( + act_type_xmlid=act_type_xmlid, + date_deadline=date_deadline, + summary=summary, + note=note, + **act_values, + ) + + @api.depends( + "activity_ids.date_deadline", "activity_ids.user_id", "activity_ids.team_id" + ) + @api.depends_context("uid") + def _compute_my_activity_date_deadline(self): + for record in self: + record.my_activity_date_deadline = next( + ( + activity.date_deadline + for activity in record.activity_ids + if activity.user_id.id == record.env.uid + or activity.team_id.id in record.env.user.activity_team_ids.ids + ), + False, + ) diff --git a/mail_activity_team/models/mail_activity_team.py b/mail_activity_team/models/mail_activity_team.py new file mode 100644 index 0000000000..6c6a71c502 --- /dev/null +++ b/mail_activity_team/models/mail_activity_team.py @@ -0,0 +1,69 @@ +# Copyright 2018-22 ForgeFlow S.L. +# Copyright 2021 Sodexis +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +from odoo import api, fields, models + + +class MailActivityTeam(models.Model): + _name = "mail.activity.team" + _description = "Mail Activity Team" + + @api.depends("res_model_ids", "member_ids") + def _compute_missing_activities(self): + activity_model = self.env["mail.activity"] + for team in self: + domain = [("team_id", "=", False)] + if team.member_ids: + domain.append(("user_id", "in", team.member_ids.ids)) + if team.res_model_ids: + domain.append(("res_model_id", "in", team.res_model_ids.ids)) + team.count_missing_activities = activity_model.search_count(domain) + + name = fields.Char(required=True, translate=True) + active = fields.Boolean(default=True) + res_model_ids = fields.Many2many( + comodel_name="ir.model", + string="Used models", + domain=lambda self: [ + ( + "model", + "in", + [ + k + for k in self.env.registry + if issubclass( + type(self.env[k]), type(self.env["mail.activity.mixin"]) + ) + and self.env[k]._auto + ], + ) + ], + ) + member_ids = fields.Many2many( + comodel_name="res.users", + relation="mail_activity_team_users_rel", + string="Team Members", + ) + user_id = fields.Many2one(comodel_name="res.users", string="Team Leader") + count_missing_activities = fields.Integer( + string="Missing Activities", compute="_compute_missing_activities", default=0 + ) + + @api.onchange("user_id") + def _onchange_user_id(self): + if self.user_id and self.user_id not in self.member_ids: + members_ids = self.member_ids.ids + members_ids.append(self.user_id.id) + self.member_ids = [(4, member) for member in members_ids] + + def assign_team_to_unassigned_activities(self): + activity_model = self.env["mail.activity"] + for team in self: + domain = [("team_id", "=", False)] + if team.member_ids: + domain.append(("user_id", "in", team.member_ids.ids)) + if team.res_model_ids: + domain.append(("res_model_id", "in", team.res_model_ids.ids)) + missing_activities = activity_model.search(domain) + for missing_activity in missing_activities: + missing_activity.write({"team_id": team.id}) diff --git a/mail_activity_team/models/mail_activity_type.py b/mail_activity_team/models/mail_activity_type.py new file mode 100644 index 0000000000..73a2da784c --- /dev/null +++ b/mail_activity_team/models/mail_activity_type.py @@ -0,0 +1,10 @@ +# Copyright 2022 CreuBlanca +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class MailActivityType(models.Model): + _inherit = "mail.activity.type" + + default_team_id = fields.Many2one(comodel_name="mail.activity.team") diff --git a/mail_activity_team/models/res_users.py b/mail_activity_team/models/res_users.py new file mode 100644 index 0000000000..083709ac34 --- /dev/null +++ b/mail_activity_team/models/res_users.py @@ -0,0 +1,77 @@ +# Copyright 2018-22 ForgeFlow S.L. +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +from odoo import api, fields, models, modules + + +class ResUsers(models.Model): + _inherit = "res.users" + + activity_team_ids = fields.Many2many( + comodel_name="mail.activity.team", + relation="mail_activity_team_users_rel", + string="Activity Teams", + ) + + @api.model + def systray_get_activities(self): + if not self.env.context.get("team_activities"): + return super().systray_get_activities() + query = """SELECT m.id, count(*), act.res_model as model, + CASE + WHEN %(today)s::date - + act.date_deadline::date = 0 Then 'today' + WHEN %(today)s::date - + act.date_deadline::date > 0 Then 'overdue' + WHEN %(today)s::date - + act.date_deadline::date < 0 Then 'planned' + END AS states, act.user_id as user_id + FROM mail_activity AS act + JOIN ir_model AS m ON act.res_model_id = m.id + WHERE team_id in ( + SELECT mail_activity_team_id + FROM mail_activity_team_users_rel + WHERE res_users_id = %(user_id)s + ) + GROUP BY m.id, states, act.res_model, act.user_id;""" + user = self.env.uid + self.env.cr.execute( + query, + { + "today": fields.Date.context_today(self), + "user_id": user, + }, + ) + activity_data = self.env.cr.dictfetchall() + model_ids = [a["id"] for a in activity_data] + model_names = { + n["id"]: n["display_name"] + for n in self.env["ir.model"] + .sudo() + .browse(model_ids) + .read(["id", "display_name"]) + } + user_activities = {} + for activity in activity_data: + if not user_activities.get(activity["model"]): + module = self.env[activity["model"]]._original_module + icon = module and modules.module.get_module_icon(module) + user_activities[activity["model"]] = { + "id": activity["id"], + "name": model_names[activity["id"]], + "model": activity["model"], + "type": "activity", + "icon": icon, + "total_count": 0, + "today_count": 0, + "overdue_count": 0, + "planned_count": 0, + } + user_activities[activity["model"]][ + "%s_count" % activity["states"] + ] += activity["count"] + if ( + activity["states"] in ("today", "overdue") + and activity["user_id"] != user + ): + user_activities[activity["model"]]["total_count"] += activity["count"] + return list(user_activities.values()) diff --git a/mail_activity_team/pyproject.toml b/mail_activity_team/pyproject.toml new file mode 100644 index 0000000000..4231d0cccb --- /dev/null +++ b/mail_activity_team/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/mail_activity_team/readme/CONTRIBUTORS.md b/mail_activity_team/readme/CONTRIBUTORS.md new file mode 100644 index 0000000000..85b9598b77 --- /dev/null +++ b/mail_activity_team/readme/CONTRIBUTORS.md @@ -0,0 +1,11 @@ +- [ForgeFlow](https://www.forgeflow.com): + - Jordi Ballester Alomar () + - Miquel Raïch () + - Bernat Puig Font () +- Pedro Gonzalez () +- [Tecnativa](https://www.tecnativa.com): + - David Vidal +- [Dynapps](https://www.dynapps.eu): + - Raf Ven +- [Trobz] (https://trobz.com): + - Son Ho diff --git a/mail_activity_team/readme/CREDITS.md b/mail_activity_team/readme/CREDITS.md new file mode 100644 index 0000000000..2683261617 --- /dev/null +++ b/mail_activity_team/readme/CREDITS.md @@ -0,0 +1 @@ +The migration of this module from 16.0 to 17.0 was financially supported by Camptocamp diff --git a/mail_activity_team/readme/DESCRIPTION.md b/mail_activity_team/readme/DESCRIPTION.md new file mode 100644 index 0000000000..02d863de61 --- /dev/null +++ b/mail_activity_team/readme/DESCRIPTION.md @@ -0,0 +1 @@ +This module adds the possibility to assign teams to activities. diff --git a/mail_activity_team/readme/USAGE.md b/mail_activity_team/readme/USAGE.md new file mode 100644 index 0000000000..3da67bd8ea --- /dev/null +++ b/mail_activity_team/readme/USAGE.md @@ -0,0 +1,16 @@ +To set up new teams: + +1. Go to *Settings / Activate developer mode* +2. Go to *Settings / Technical / Discuss / Activity Teams* +3. Create a new Team and assign (optionally) the models in which it + will be used, and the members of the team. + +You can also assign a user to Activity teams going to *Settings / Users +& Companies / Users*, and in the *Preferences* tab, field Activity +Teams. + +When you create a new activity the application will propose the user's +assigned team. + +You can report on the activities assigned to a team going to *Dashboards +/ Activities*, and then filter by a specific team or group by teams. diff --git a/mail_activity_team/security/ir.model.access.csv b/mail_activity_team/security/ir.model.access.csv new file mode 100644 index 0000000000..7f5f7bb530 --- /dev/null +++ b/mail_activity_team/security/ir.model.access.csv @@ -0,0 +1,3 @@ +"id","name","model_id:id","group_id:id","perm_read","perm_write","perm_create","perm_unlink" +access_mail_activity_team_user,mail.activity.team.user,model_mail_activity_team,base.group_user,1,1,0,0 +access_mail_activity_team_system_user,mail.activity.team.system.user,model_mail_activity_team,base.group_system,1,1,1,1 diff --git a/mail_activity_team/security/mail_activity_team_security.xml b/mail_activity_team/security/mail_activity_team_security.xml new file mode 100644 index 0000000000..638eb3d3d3 --- /dev/null +++ b/mail_activity_team/security/mail_activity_team_security.xml @@ -0,0 +1,17 @@ + + + + + mail.activity: user: my team + + ["|", ('team_id', 'in', user.activity_team_ids.ids), "&", ('team_id', '=', False), ('user_id', '=', user.id)] + + + + + + + + diff --git a/mail_activity_team/static/description/icon.png b/mail_activity_team/static/description/icon.png new file mode 100644 index 0000000000..3a0328b516 Binary files /dev/null and b/mail_activity_team/static/description/icon.png differ diff --git a/mail_activity_team/static/description/index.html b/mail_activity_team/static/description/index.html new file mode 100644 index 0000000000..76c86dcad5 --- /dev/null +++ b/mail_activity_team/static/description/index.html @@ -0,0 +1,469 @@ + + + + + +Mail Activity Team + + + +
+

Mail Activity Team

+ + +

Alpha License: AGPL-3 OCA/social Translate me on Weblate Try me on Runboat

+

This module adds the possibility to assign teams to activities.

+
+

Important

+

This is an alpha version, the data model and design can change at any time without warning. +Only for development or testing purpose, do not use in production. +More details on development status

+
+

Table of contents

+ +
+

Usage

+

To set up new teams:

+
    +
  1. Go to Settings / Activate developer mode
  2. +
  3. Go to Settings / Technical / Discuss / Activity Teams
  4. +
  5. Create a new Team and assign (optionally) the models in which it will +be used, and the members of the team.
  6. +
+

You can also assign a user to Activity teams going to Settings / Users +& Companies / Users, and in the Preferences tab, field Activity +Teams.

+

When you create a new activity the application will propose the user’s +assigned team.

+

You can report on the activities assigned to a team going to Dashboards +/ Activities, and then filter by a specific team or group by teams.

+
+
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Authors

+
    +
  • ForgeFlow
  • +
  • Sodexis
  • +
+
+
+

Contributors

+ +
+
+

Other credits

+

The migration of this module from 16.0 to 17.0 was financially supported +by Camptocamp

+
+
+

Maintainers

+

This module is maintained by the OCA.

+Odoo Community Association +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

This module is part of the OCA/social project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml b/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml new file mode 100644 index 0000000000..c30e3b4d08 --- /dev/null +++ b/mail_activity_team/static/src/components/activity_menu_view/activity_menu_view.xml @@ -0,0 +1,33 @@ + + + + + + + + diff --git a/mail_activity_team/static/src/models/activity_menu.esm.js b/mail_activity_team/static/src/models/activity_menu.esm.js new file mode 100644 index 0000000000..4ee18279a0 --- /dev/null +++ b/mail_activity_team/static/src/models/activity_menu.esm.js @@ -0,0 +1,37 @@ +/** @odoo-module */ + +import {ActivityMenu} from "@mail/core/web/activity_menu"; +import {patch} from "@web/core/utils/patch"; + +patch(ActivityMenu.prototype, { + setup() { + super.setup(); + this.currentFilter = "my"; + }, + activateFilter(filter_el) { + this.deactivateButtons(); + + filter_el.addClass("active"); + this.currentFilter = filter_el.data("filter"); + this.updateTeamActivitiesContext(); + this.fetchSystrayActivities(); + }, + updateTeamActivitiesContext() { + var active = false; + if (this.currentFilter === "team") { + active = true; + } + this.env.services.orm.user.updateContext({team_activities: active}); + }, + onBeforeOpen() { + this.env.services.orm.user.updateContext({team_activities: false}); + super.onBeforeOpen(); + }, + + deactivateButtons() { + $(".o_filter_nav_item").removeClass("active"); + }, + onClickActivityFilter(filter) { + this.activateFilter($("." + filter)); + }, +}); diff --git a/mail_activity_team/tests/__init__.py b/mail_activity_team/tests/__init__.py new file mode 100644 index 0000000000..f4a7f59501 --- /dev/null +++ b/mail_activity_team/tests/__init__.py @@ -0,0 +1 @@ +from . import test_mail_activity_team diff --git a/mail_activity_team/tests/test_mail_activity_team.py b/mail_activity_team/tests/test_mail_activity_team.py new file mode 100644 index 0000000000..84409e864b --- /dev/null +++ b/mail_activity_team/tests/test_mail_activity_team.py @@ -0,0 +1,340 @@ +# Copyright 2018-22 ForgeFlow S.L. +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). + +from datetime import date + +from odoo.exceptions import ValidationError +from odoo.tests.common import Form, TransactionCase + + +class TestMailActivityTeam(TransactionCase): + @classmethod + def setUpClass(cls): + super().setUpClass() + cls.env = cls.env(context=dict(cls.env.context, tracking_disable=True)) + # Start from a clean slate + cls.env["mail.activity.team"].search([]).unlink() + # Create Users + 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, + [ + cls.env.ref("base.group_user").id, + cls.env.ref("base.group_partner_manager").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, [cls.env.ref("base.group_user").id])], + } + ) + cls.employee3 = cls.env["res.users"].create( + { + "company_id": cls.env.ref("base.main_company").id, + "name": "Employee 3", + "login": "csu3", + "email": "crmuser3@yourcompany.com", + "groups_id": [(6, 0, [cls.env.ref("base.group_user").id])], + } + ) + # Create Activity Types + cls.activity1 = cls.env["mail.activity.type"].create( + { + "name": "Initial Contact", + "delay_count": 5, + "delay_unit": "days", + "summary": "ACT 1 : Presentation, barbecue, ... ", + "res_model": "res.partner", + } + ) + cls.activity2 = cls.env["mail.activity.type"].create( + { + "name": "Call for Demo", + "delay_count": 6, + "delay_unit": "days", + "summary": "ACT 2 : I want to show you my ERP !", + "res_model": "res.partner", + } + ) + # Create Teams and Activities + cls.partner_client = cls.env.ref("base.res_partner_1") + cls.partner_ir_model = cls.env["ir.model"]._get("res.partner") + cls.act1 = ( + cls.env["mail.activity"] + .with_user(cls.employee) + .create( + { + "activity_type_id": cls.activity1.id, + "note": "Partner activity 1.", + "res_id": cls.partner_client.id, + "res_model_id": cls.partner_ir_model.id, + "user_id": cls.employee.id, + } + ) + ) + cls.team1 = cls.env["mail.activity.team"].create( + { + "name": "Team 1", + "res_model_ids": [(6, 0, [cls.partner_ir_model.id])], + "member_ids": [(6, 0, [cls.employee.id])], + } + ) + cls.team2 = cls.env["mail.activity.team"].create( + { + "name": "Team 2", + "res_model_ids": [(6, 0, [cls.partner_ir_model.id])], + "member_ids": [(6, 0, [cls.employee.id, cls.employee2.id])], + } + ) + cls.act2 = ( + cls.env["mail.activity"] + .with_user(cls.employee) + .create( + { + "activity_type_id": cls.activity2.id, + "note": "Partner activity 2.", + "res_id": cls.partner_client.id, + "res_model_id": cls.partner_ir_model.id, + "user_id": cls.employee.id, + } + ) + ) + + def test_activity_members(self): + self.team1.member_ids |= self.employee2 + self.partner_client.invalidate_recordset() + self.assertIn(self.employee2, self.partner_client.activity_team_user_ids) + self.assertIn(self.employee, self.partner_client.activity_team_user_ids) + self.assertEqual( + self.partner_client, + self.env["res.partner"].search( + [("activity_team_user_ids", "=", self.employee.id)] + ), + ) + + def test_team_and_user_onchange(self): + with self.assertRaises(ValidationError): + self.team1.member_ids = [(3, self.employee.id)] + self.act2.team_id = self.team1 + self.act2.user_id = self.employee + + def test_missing_activities(self): + self.assertFalse(self.act1.team_id, "Error: Activity 1 should not have a team.") + self.assertEqual(self.team1.count_missing_activities, 1) + self.team1.assign_team_to_unassigned_activities() + self.team1._compute_missing_activities() + self.assertEqual(self.team1.count_missing_activities, 0) + self.assertEqual(self.act1.team_id, self.team1) + + def test_leader_onchange(self): + self.team2.user_id = self.employee3 + self.team2._onchange_user_id() + self.assertTrue(self.employee3 in self.team2.member_ids) + + def test_activity_onchanges_keep_user(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + with Form(self.act2) as form: + form.team_id = self.env["mail.activity.team"] + self.assertEqual(form.user_id, self.employee) + + def test_activity_onchanges_user_no_member_team(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + with self.assertRaises( + AssertionError, msg="can't write on invisible field user_id" + ): + with Form(self.act2) as form: + form.user_id = self.employee2 + + def test_activity_onchanges_user_no_team(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + with Form(self.act2) as form: + form.team_id = self.env["mail.activity.team"] + form.user_id = self.employee2 + self.assertEqual(form.team_id, self.team2) + + def test_activity_onchanges_team_no_member(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + self.team2.user_id = False + self.team2.member_ids = False + with Form(self.act2) as form: + form.team_id = self.team2 + self.assertFalse(form.user_id) + + def test_activity_onchanges_team_different_member(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + self.team2.user_id = self.employee2 + self.team2.member_ids = self.employee2 + with Form(self.act2) as form: + form.team_id = self.team2 + self.assertEqual(form.user_id, self.employee2) + + def test_activity_onchanges_team_different_member_no_leader(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + self.team2.user_id = False + self.team2.member_ids = self.employee2 + with Form(self.act2) as form: + form.team_id = self.team2 + self.assertEqual(form.user_id, self.employee2) + + def test_activity_onchanges_activity_type_set_team(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + self.activity1.default_team_id = self.team2 + self.assertEqual(self.act2.activity_type_id, self.activity2) + with Form(self.act2) as form: + form.activity_type_id = self.activity1 + self.assertEqual(form.team_id, self.team2) + + def test_activity_onchanges_activity_type_no_team(self): + self.assertEqual( + self.act2.team_id, self.team1, "Error: Activity 2 should have Team 1." + ) + self.assertEqual(self.act2.activity_type_id, self.activity2) + with Form(self.act2) as form: + form.activity_type_id = self.activity1 + self.assertEqual(form.team_id, self.team1) + + def test_activity_constrain(self): + with self.assertRaises(ValidationError): + self.act2.write({"user_id": self.employee2.id, "team_id": self.team1.id}) + + def test_schedule_activity(self): + """Correctly assign teams to auto scheduled activities. Those won't + trigger onchanges and could raise constraints and team missmatches""" + partner_record = self.employee.partner_id.with_user(self.employee.id) + activity = partner_record.activity_schedule( + user_id=self.employee2.id, + activity_type_id=self.env.ref("mail.mail_activity_data_call").id, + ) + self.assertEqual(activity.team_id, self.team2) + + def test_schedule_activity_default_team(self): + """Correctly assign teams to auto scheduled activities. Those won't + trigger onchanges and could raise constraints and team missmatches""" + partner_record = self.employee.partner_id.with_user(self.employee.id) + self.env.ref("mail.mail_activity_data_call").default_team_id = self.team2 + activity = partner_record.activity_schedule( + act_type_xmlid="mail.mail_activity_data_call", + user_id=self.employee2.id, + ) + self.assertEqual(activity.team_id, self.team2) + self.assertEqual(activity.user_id, self.employee2) + + def test_schedule_activity_default_team_no_user(self): + """Correctly assign teams to auto scheduled activities. Those won't + trigger onchanges and could raise constraints and team missmatches""" + partner_record = self.employee.partner_id.with_user(self.employee.id) + self.activity2.default_team_id = self.team2 + self.team2.member_ids = self.employee2 + activity = partner_record.activity_schedule( + activity_type_id=self.activity2.id, + ) + self.assertEqual(activity.team_id, self.team2) + self.assertEqual(activity.user_id, self.employee2) + + def test_activity_count(self): + res = ( + self.env["res.users"] + .with_user(self.employee.id) + .with_context(**{"team_activities": True}) + .systray_get_activities() + ) + self.assertEqual(res[0]["total_count"], 0) + self.assertEqual(res[0]["today_count"], 1) + partner_record = self.employee.partner_id.with_user(self.employee.id) + self.activity2.default_team_id = self.team2 + activity = partner_record.activity_schedule( + activity_type_id=self.activity2.id, user_id=self.employee2.id + ) + activity.flush_recordset() + res = ( + self.env["res.users"] + .with_user(self.employee.id) + .with_context(**{"team_activities": True}) + .systray_get_activities() + ) + self.assertEqual(res[0]["total_count"], 1) + self.assertEqual(res[0]["today_count"], 2) + res = self.env["res.users"].with_user(self.employee.id).systray_get_activities() + self.assertEqual(res[0]["total_count"], 2) + + def test_activity_schedule_next(self): + self.activity1.write( + { + "default_team_id": self.team1.id, + "triggered_next_type_id": self.activity2.id, + } + ) + self.activity2.default_team_id = self.team2 + self.team2.member_ids = self.employee2 + partner_record = self.employee.partner_id.with_user(self.employee.id) + activity = partner_record.activity_schedule(activity_type_id=self.activity1.id) + activity.flush_recordset() + _messages, next_activities = activity._action_done() + self.assertTrue(next_activities) + self.assertEqual(next_activities.team_id, self.team2) + self.assertEqual(next_activities.user_id, self.employee2) + + def test_schedule_activity_from_server_action(self): + partner = self.env["res.partner"].create({"name": "Test Partner"}) + action = self.env["ir.actions.server"].create( + { + "name": "Test Server Action", + "model_id": self.partner_ir_model.id, + "state": "next_activity", + "activity_type_id": self.activity1.id, + "activity_user_type": "specific", + "activity_user_id": self.employee.id, + "activity_team_id": self.team1.id, + } + ) + action.with_context(active_model=partner._name, active_ids=partner.ids).run() + self.assertEqual(partner.activity_ids[-1].team_id, self.team1) + action.activity_team_id = self.team2 + action.with_context(active_model=partner._name, active_ids=partner.ids).run() + self.assertEqual(partner.activity_ids[-1].team_id, self.team2) + + def test_my_activity_date_deadline(self): + today = date.today() + self.act2.write( + { + "user_id": False, + "team_id": self.team1.id, + "date_deadline": today, + } + ) + partner = ( + self.env["res.partner"] + .with_context(team_activities=True) + .with_user(self.employee.id) + .search([("my_activity_date_deadline", "=", today)]) + ) + self.assertEqual(partner, self.partner_client) + self.assertEqual(partner.my_activity_date_deadline, today) diff --git a/mail_activity_team/views/ir_actions_server_views.xml b/mail_activity_team/views/ir_actions_server_views.xml new file mode 100644 index 0000000000..22d596fede --- /dev/null +++ b/mail_activity_team/views/ir_actions_server_views.xml @@ -0,0 +1,22 @@ + + + + + + ir.actions.server + + + + + + + + + diff --git a/mail_activity_team/views/mail_activity_team_views.xml b/mail_activity_team/views/mail_activity_team_views.xml new file mode 100644 index 0000000000..8c2a47b31f --- /dev/null +++ b/mail_activity_team/views/mail_activity_team_views.xml @@ -0,0 +1,107 @@ + + + + + + + mail.activity.team.view.form + mail.activity.team + +
+
+ +
+ + + + + + + + + + + + + + + + + + +
+
+
+ + + + + mail.activity.team.view.tree + mail.activity.team + + + + + + + + + + + + mail.activity.team.view.search + mail.activity.team + + + + + + + + + + + + + Activity Teams + mail.activity.team + tree,form + [] + {} + + + + + + + +
diff --git a/mail_activity_team/views/mail_activity_type.xml b/mail_activity_team/views/mail_activity_type.xml new file mode 100644 index 0000000000..325873a555 --- /dev/null +++ b/mail_activity_team/views/mail_activity_type.xml @@ -0,0 +1,22 @@ + + + + + + mail.activity.type.form (in mail_activity_team) + mail.activity.type + + + + + + + + + + + diff --git a/mail_activity_team/views/mail_activity_views.xml b/mail_activity_team/views/mail_activity_views.xml new file mode 100644 index 0000000000..f314bdcf16 --- /dev/null +++ b/mail_activity_team/views/mail_activity_views.xml @@ -0,0 +1,103 @@ + + + + + mail.activity.view.form.popup + mail.activity + + + + team_id + + + + + + + + + + mail.activity.view.tree + mail.activity + + + + + + + + + + mail.activity.view.form + mail.activity + + + + not team_id + + + + + + + + + + mail.activity.boards.view.kanban + mail.activity + + + + + + +
+
+ Team: +
+
+
+
+ + + + mail.activity.boards.view.search + mail.activity + + + + + + + + + + + + + + + +
diff --git a/mail_activity_team/views/res_users_views.xml b/mail_activity_team/views/res_users_views.xml new file mode 100644 index 0000000000..544a5a9606 --- /dev/null +++ b/mail_activity_team/views/res_users_views.xml @@ -0,0 +1,16 @@ + + + + + res.users.form.activity.team + res.users + + + + + + + + + +