From aa6d0569ee39b7c4ad11031032e4668c6a397d30 Mon Sep 17 00:00:00 2001 From: Anjeel Haria Date: Wed, 9 Oct 2024 15:03:54 +0530 Subject: [PATCH] Updated Website Membership Registration changes pre-commit fixes pre-commit fixes pre-commit Fix --- partner_cde/__init__.py | 1 + partner_cde/__manifest__.py | 13 + partner_cde/models/__init__.py | 1 + partner_cde/models/res_partner.py | 11 + partner_cde/views/res_partner_view.xml | 14 + partner_contact_birthdate/README.rst | 97 +++ partner_contact_birthdate/__init__.py | 3 + partner_contact_birthdate/__manifest__.py | 16 + partner_contact_birthdate/i18n/am.po | 39 ++ partner_contact_birthdate/i18n/ar.po | 40 ++ partner_contact_birthdate/i18n/bg.po | 39 ++ partner_contact_birthdate/i18n/bs.po | 40 ++ partner_contact_birthdate/i18n/ca.po | 40 ++ partner_contact_birthdate/i18n/cs.po | 39 ++ partner_contact_birthdate/i18n/da.po | 40 ++ partner_contact_birthdate/i18n/de.po | 40 ++ partner_contact_birthdate/i18n/el_GR.po | 40 ++ partner_contact_birthdate/i18n/en_GB.po | 40 ++ partner_contact_birthdate/i18n/es.po | 40 ++ partner_contact_birthdate/i18n/es_CR.po | 40 ++ partner_contact_birthdate/i18n/es_EC.po | 40 ++ partner_contact_birthdate/i18n/es_MX.po | 40 ++ partner_contact_birthdate/i18n/es_VE.po | 40 ++ partner_contact_birthdate/i18n/et.po | 39 ++ partner_contact_birthdate/i18n/eu.po | 39 ++ partner_contact_birthdate/i18n/fi.po | 40 ++ partner_contact_birthdate/i18n/fr.po | 37 ++ partner_contact_birthdate/i18n/fr_CA.po | 40 ++ partner_contact_birthdate/i18n/fr_CH.po | 40 ++ partner_contact_birthdate/i18n/gl.po | 39 ++ partner_contact_birthdate/i18n/hr.po | 41 ++ partner_contact_birthdate/i18n/hr_HR.po | 41 ++ partner_contact_birthdate/i18n/hu.po | 39 ++ partner_contact_birthdate/i18n/it.po | 40 ++ partner_contact_birthdate/i18n/ja.po | 39 ++ partner_contact_birthdate/i18n/lt.po | 40 ++ partner_contact_birthdate/i18n/lv.po | 40 ++ partner_contact_birthdate/i18n/mk.po | 39 ++ partner_contact_birthdate/i18n/mn.po | 39 ++ partner_contact_birthdate/i18n/nb.po | 40 ++ partner_contact_birthdate/i18n/nb_NO.po | 40 ++ partner_contact_birthdate/i18n/nl.po | 39 ++ partner_contact_birthdate/i18n/nl_BE.po | 40 ++ partner_contact_birthdate/i18n/nl_NL.po | 40 ++ partner_contact_birthdate/i18n/pl.po | 41 ++ partner_contact_birthdate/i18n/pt.po | 40 ++ partner_contact_birthdate/i18n/pt_BR.po | 41 ++ partner_contact_birthdate/i18n/pt_PT.po | 40 ++ partner_contact_birthdate/i18n/ro.po | 40 ++ partner_contact_birthdate/i18n/ru.po | 41 ++ partner_contact_birthdate/i18n/sk.po | 39 ++ partner_contact_birthdate/i18n/sl.po | 40 ++ partner_contact_birthdate/i18n/sr@latin.po | 41 ++ partner_contact_birthdate/i18n/sv.po | 39 ++ partner_contact_birthdate/i18n/th.po | 39 ++ partner_contact_birthdate/i18n/tr.po | 39 ++ partner_contact_birthdate/i18n/tr_TR.po | 40 ++ partner_contact_birthdate/i18n/vi.po | 39 ++ partner_contact_birthdate/i18n/zh_CN.po | 40 ++ partner_contact_birthdate/i18n/zh_TW.po | 40 ++ partner_contact_birthdate/models/__init__.py | 3 + .../models/res_partner.py | 25 + .../readme/CONTRIBUTORS.rst | 7 + .../readme/DESCRIPTION.rst | 7 + .../readme/INSTALLATION.rst | 5 + partner_contact_birthdate/readme/USAGE.rst | 5 + .../static/description/age.png | Bin 0 -> 97611 bytes .../static/description/icon.png | Bin 0 -> 9455 bytes .../static/description/index.html | 441 ++++++++++++++ partner_contact_birthdate/tests/__init__.py | 3 + .../tests/test_res_partner.py | 21 + .../views/res_partner.xml | 24 + .../README.rst | 92 +++ .../__init__.py | 1 + .../__manifest__.py | 16 + .../i18n/ca.po | 22 + .../i18n/da.po | 22 + .../i18n/de.po | 24 + .../i18n/es.po | 24 + .../i18n/fi.po | 24 + .../i18n/fr.po | 24 + .../i18n/hr.po | 23 + .../i18n/hr_HR.po | 26 + .../i18n/hu.po | 22 + .../i18n/it.po | 24 + .../i18n/ja.po | 22 + .../i18n/nl.po | 24 + .../i18n/pt.po | 22 + .../i18n/pt_BR.po | 25 + .../i18n/pt_PT.po | 25 + .../i18n/sl.po | 25 + .../readme/CONTRIBUTORS.rst | 9 + .../readme/DESCRIPTION.rst | 4 + .../readme/USAGE.rst | 1 + .../static/description/icon.png | Bin 0 -> 9455 bytes .../static/description/index.html | 436 ++++++++++++++ .../views/res_partner.xml | 21 + project_role/README.rst | 112 ++++ project_role/__init__.py | 3 + project_role/__manifest__.py | 25 + project_role/i18n/de.po | 554 ++++++++++++++++++ project_role/i18n/es.po | 450 ++++++++++++++ project_role/i18n/es_AR.po | 492 ++++++++++++++++ project_role/i18n/es_PA.po | 433 ++++++++++++++ project_role/i18n/fr.po | 474 +++++++++++++++ project_role/i18n/hr.po | 443 ++++++++++++++ project_role/i18n/it.po | 450 ++++++++++++++ project_role/i18n/sl.po | 502 ++++++++++++++++ project_role/models/__init__.py | 7 + project_role/models/project_assignment.py | 157 +++++ project_role/models/project_project.py | 57 ++ project_role/models/project_role.py | 135 +++++ project_role/models/res_company.py | 17 + project_role/models/res_config_settings.py | 17 + project_role/readme/CONFIGURE.rst | 20 + project_role/readme/CONTRIBUTORS.rst | 6 + project_role/readme/DESCRIPTION.rst | 3 + project_role/security/ir.model.access.csv | 7 + project_role/security/project_role.xml | 23 + project_role/static/description/icon.png | Bin 0 -> 9455 bytes project_role/static/description/index.html | 452 ++++++++++++++ project_role/tests/__init__.py | 3 + project_role/tests/test_project_role.py | 312 ++++++++++ project_role/views/project_assignment.xml | 198 +++++++ project_role/views/project_project.xml | 29 + project_role/views/project_role.xml | 67 +++ project_role/views/res_config_settings.xml | 93 +++ .../__manifest__.py | 4 + .../controllers/main.py | 139 +++-- .../controllers/portal.py | 14 +- website_membership_registration/i18n/nl.po | 4 +- .../models/res_config_settings.py | 29 +- .../models/res_partner.py | 6 +- .../models/website.py | 26 +- .../website_membership_registration.editor.js | 86 +++ .../templates/website.xml | 78 ++- .../views/res_config_settings_view.xml | 43 -- .../views/res_partner_view.xml | 5 + .../views/snippets/snippets.xml | 30 + .../__init__.py | 1 + .../__manifest__.py | 18 + .../controllers/__init__.py | 2 + .../controllers/main.py | 26 + .../controllers/portal.py | 9 + .../templates/website.xml | 67 +++ .../views/snippets/snippets.xml | 19 + .../__init__.py | 1 + .../__manifest__.py | 18 + .../controllers/__init__.py | 2 + .../controllers/main.py | 24 + .../controllers/portal.py | 5 + .../templates/website.xml | 67 +++ .../views/snippets/snippets.xml | 19 + .../__init__.py | 0 .../__manifest__.py | 19 + .../views/res_partner_view.xml | 20 + .../__init__.py | 2 + .../__manifest__.py | 20 + .../controllers/__init__.py | 2 + .../controllers/main.py | 44 ++ .../controllers/portal.py | 18 + .../models/__init__.py | 1 + .../models/res_partner.py | 7 + .../templates/website.xml | 29 + .../views/res_partner_view.xml | 15 + .../views/snippets/snippets.xml | 11 + website_project_role_members/__init__.py | 1 + website_project_role_members/__manifest__.py | 1 + .../controllers/__init__.py | 1 + .../controllers/portal.py | 5 + .../templates/portal_template.xml | 14 + 171 files changed, 10062 insertions(+), 153 deletions(-) create mode 100644 partner_cde/__init__.py create mode 100644 partner_cde/__manifest__.py create mode 100644 partner_cde/models/__init__.py create mode 100644 partner_cde/models/res_partner.py create mode 100644 partner_cde/views/res_partner_view.xml create mode 100644 partner_contact_birthdate/README.rst create mode 100644 partner_contact_birthdate/__init__.py create mode 100644 partner_contact_birthdate/__manifest__.py create mode 100644 partner_contact_birthdate/i18n/am.po create mode 100644 partner_contact_birthdate/i18n/ar.po create mode 100644 partner_contact_birthdate/i18n/bg.po create mode 100644 partner_contact_birthdate/i18n/bs.po create mode 100644 partner_contact_birthdate/i18n/ca.po create mode 100644 partner_contact_birthdate/i18n/cs.po create mode 100644 partner_contact_birthdate/i18n/da.po create mode 100644 partner_contact_birthdate/i18n/de.po create mode 100644 partner_contact_birthdate/i18n/el_GR.po create mode 100644 partner_contact_birthdate/i18n/en_GB.po create mode 100644 partner_contact_birthdate/i18n/es.po create mode 100644 partner_contact_birthdate/i18n/es_CR.po create mode 100644 partner_contact_birthdate/i18n/es_EC.po create mode 100644 partner_contact_birthdate/i18n/es_MX.po create mode 100644 partner_contact_birthdate/i18n/es_VE.po create mode 100644 partner_contact_birthdate/i18n/et.po create mode 100644 partner_contact_birthdate/i18n/eu.po create mode 100644 partner_contact_birthdate/i18n/fi.po create mode 100644 partner_contact_birthdate/i18n/fr.po create mode 100644 partner_contact_birthdate/i18n/fr_CA.po create mode 100644 partner_contact_birthdate/i18n/fr_CH.po create mode 100644 partner_contact_birthdate/i18n/gl.po create mode 100644 partner_contact_birthdate/i18n/hr.po create mode 100644 partner_contact_birthdate/i18n/hr_HR.po create mode 100644 partner_contact_birthdate/i18n/hu.po create mode 100644 partner_contact_birthdate/i18n/it.po create mode 100644 partner_contact_birthdate/i18n/ja.po create mode 100644 partner_contact_birthdate/i18n/lt.po create mode 100644 partner_contact_birthdate/i18n/lv.po create mode 100644 partner_contact_birthdate/i18n/mk.po create mode 100644 partner_contact_birthdate/i18n/mn.po create mode 100644 partner_contact_birthdate/i18n/nb.po create mode 100644 partner_contact_birthdate/i18n/nb_NO.po create mode 100644 partner_contact_birthdate/i18n/nl.po create mode 100644 partner_contact_birthdate/i18n/nl_BE.po create mode 100644 partner_contact_birthdate/i18n/nl_NL.po create mode 100644 partner_contact_birthdate/i18n/pl.po create mode 100644 partner_contact_birthdate/i18n/pt.po create mode 100644 partner_contact_birthdate/i18n/pt_BR.po create mode 100644 partner_contact_birthdate/i18n/pt_PT.po create mode 100644 partner_contact_birthdate/i18n/ro.po create mode 100644 partner_contact_birthdate/i18n/ru.po create mode 100644 partner_contact_birthdate/i18n/sk.po create mode 100644 partner_contact_birthdate/i18n/sl.po create mode 100644 partner_contact_birthdate/i18n/sr@latin.po create mode 100644 partner_contact_birthdate/i18n/sv.po create mode 100644 partner_contact_birthdate/i18n/th.po create mode 100644 partner_contact_birthdate/i18n/tr.po create mode 100644 partner_contact_birthdate/i18n/tr_TR.po create mode 100644 partner_contact_birthdate/i18n/vi.po create mode 100644 partner_contact_birthdate/i18n/zh_CN.po create mode 100644 partner_contact_birthdate/i18n/zh_TW.po create mode 100644 partner_contact_birthdate/models/__init__.py create mode 100644 partner_contact_birthdate/models/res_partner.py create mode 100644 partner_contact_birthdate/readme/CONTRIBUTORS.rst create mode 100644 partner_contact_birthdate/readme/DESCRIPTION.rst create mode 100644 partner_contact_birthdate/readme/INSTALLATION.rst create mode 100644 partner_contact_birthdate/readme/USAGE.rst create mode 100644 partner_contact_birthdate/static/description/age.png create mode 100644 partner_contact_birthdate/static/description/icon.png create mode 100644 partner_contact_birthdate/static/description/index.html create mode 100644 partner_contact_birthdate/tests/__init__.py create mode 100644 partner_contact_birthdate/tests/test_res_partner.py create mode 100644 partner_contact_birthdate/views/res_partner.xml create mode 100644 partner_contact_personal_information_page/README.rst create mode 100644 partner_contact_personal_information_page/__init__.py create mode 100644 partner_contact_personal_information_page/__manifest__.py create mode 100644 partner_contact_personal_information_page/i18n/ca.po create mode 100644 partner_contact_personal_information_page/i18n/da.po create mode 100644 partner_contact_personal_information_page/i18n/de.po create mode 100644 partner_contact_personal_information_page/i18n/es.po create mode 100644 partner_contact_personal_information_page/i18n/fi.po create mode 100644 partner_contact_personal_information_page/i18n/fr.po create mode 100644 partner_contact_personal_information_page/i18n/hr.po create mode 100644 partner_contact_personal_information_page/i18n/hr_HR.po create mode 100644 partner_contact_personal_information_page/i18n/hu.po create mode 100644 partner_contact_personal_information_page/i18n/it.po create mode 100644 partner_contact_personal_information_page/i18n/ja.po create mode 100644 partner_contact_personal_information_page/i18n/nl.po create mode 100644 partner_contact_personal_information_page/i18n/pt.po create mode 100644 partner_contact_personal_information_page/i18n/pt_BR.po create mode 100644 partner_contact_personal_information_page/i18n/pt_PT.po create mode 100644 partner_contact_personal_information_page/i18n/sl.po create mode 100644 partner_contact_personal_information_page/readme/CONTRIBUTORS.rst create mode 100644 partner_contact_personal_information_page/readme/DESCRIPTION.rst create mode 100644 partner_contact_personal_information_page/readme/USAGE.rst create mode 100644 partner_contact_personal_information_page/static/description/icon.png create mode 100644 partner_contact_personal_information_page/static/description/index.html create mode 100644 partner_contact_personal_information_page/views/res_partner.xml create mode 100644 project_role/README.rst create mode 100644 project_role/__init__.py create mode 100644 project_role/__manifest__.py create mode 100644 project_role/i18n/de.po create mode 100644 project_role/i18n/es.po create mode 100644 project_role/i18n/es_AR.po create mode 100644 project_role/i18n/es_PA.po create mode 100644 project_role/i18n/fr.po create mode 100644 project_role/i18n/hr.po create mode 100644 project_role/i18n/it.po create mode 100644 project_role/i18n/sl.po create mode 100644 project_role/models/__init__.py create mode 100644 project_role/models/project_assignment.py create mode 100644 project_role/models/project_project.py create mode 100644 project_role/models/project_role.py create mode 100644 project_role/models/res_company.py create mode 100644 project_role/models/res_config_settings.py create mode 100644 project_role/readme/CONFIGURE.rst create mode 100644 project_role/readme/CONTRIBUTORS.rst create mode 100644 project_role/readme/DESCRIPTION.rst create mode 100644 project_role/security/ir.model.access.csv create mode 100644 project_role/security/project_role.xml create mode 100644 project_role/static/description/icon.png create mode 100644 project_role/static/description/index.html create mode 100644 project_role/tests/__init__.py create mode 100644 project_role/tests/test_project_role.py create mode 100644 project_role/views/project_assignment.xml create mode 100644 project_role/views/project_project.xml create mode 100644 project_role/views/project_role.xml create mode 100644 project_role/views/res_config_settings.xml create mode 100644 website_membership_registration/static/src/js/website_membership_registration.editor.js create mode 100644 website_membership_registration/views/snippets/snippets.xml create mode 100644 website_membership_registration_partner_cde/__init__.py create mode 100644 website_membership_registration_partner_cde/__manifest__.py create mode 100644 website_membership_registration_partner_cde/controllers/__init__.py create mode 100644 website_membership_registration_partner_cde/controllers/main.py create mode 100644 website_membership_registration_partner_cde/controllers/portal.py create mode 100644 website_membership_registration_partner_cde/templates/website.xml create mode 100644 website_membership_registration_partner_cde/views/snippets/snippets.xml create mode 100644 website_membership_registration_partner_contact_birthdate/__init__.py create mode 100644 website_membership_registration_partner_contact_birthdate/__manifest__.py create mode 100644 website_membership_registration_partner_contact_birthdate/controllers/__init__.py create mode 100644 website_membership_registration_partner_contact_birthdate/controllers/main.py create mode 100644 website_membership_registration_partner_contact_birthdate/controllers/portal.py create mode 100644 website_membership_registration_partner_contact_birthdate/templates/website.xml create mode 100644 website_membership_registration_partner_contact_birthdate/views/snippets/snippets.xml create mode 100644 website_membership_registration_project_role_members/__init__.py create mode 100644 website_membership_registration_project_role_members/__manifest__.py create mode 100644 website_membership_registration_project_role_members/views/res_partner_view.xml create mode 100644 website_membership_registration_social/__init__.py create mode 100644 website_membership_registration_social/__manifest__.py create mode 100644 website_membership_registration_social/controllers/__init__.py create mode 100644 website_membership_registration_social/controllers/main.py create mode 100644 website_membership_registration_social/controllers/portal.py create mode 100644 website_membership_registration_social/models/__init__.py create mode 100644 website_membership_registration_social/models/res_partner.py create mode 100644 website_membership_registration_social/templates/website.xml create mode 100644 website_membership_registration_social/views/res_partner_view.xml create mode 100644 website_membership_registration_social/views/snippets/snippets.xml create mode 100644 website_project_role_members/controllers/__init__.py create mode 100644 website_project_role_members/controllers/portal.py create mode 100644 website_project_role_members/templates/portal_template.xml diff --git a/partner_cde/__init__.py b/partner_cde/__init__.py new file mode 100644 index 0000000..0650744 --- /dev/null +++ b/partner_cde/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/partner_cde/__manifest__.py b/partner_cde/__manifest__.py new file mode 100644 index 0000000..b91a769 --- /dev/null +++ b/partner_cde/__manifest__.py @@ -0,0 +1,13 @@ +{ + "name": "Partner extension for collaborative development environments", + "summary": "Allows to capture details of collaborative development environments for partners", + "category": "Membership", + "version": "16.0.1.0.0", + "author": "Onestein", + "website": "https://www.onestein.nl", + "license": "AGPL-3", + "depends": ["base"], + "data": [ + "views/res_partner_view.xml", + ], +} diff --git a/partner_cde/models/__init__.py b/partner_cde/models/__init__.py new file mode 100644 index 0000000..91fed54 --- /dev/null +++ b/partner_cde/models/__init__.py @@ -0,0 +1 @@ +from . import res_partner diff --git a/partner_cde/models/res_partner.py b/partner_cde/models/res_partner.py new file mode 100644 index 0000000..09a5c65 --- /dev/null +++ b/partner_cde/models/res_partner.py @@ -0,0 +1,11 @@ +from odoo import fields, models + + +class ResPartner(models.Model): + _inherit = "res.partner" + + github_login = fields.Char(string="Github Username") + gitlab_email = fields.Char(help="Can be used to reconcile commits") + gitlab_username = fields.Char( + help="Can be used to reconcile merge requests, issues, comment, and reviews", + ) diff --git a/partner_cde/views/res_partner_view.xml b/partner_cde/views/res_partner_view.xml new file mode 100644 index 0000000..839fd4b --- /dev/null +++ b/partner_cde/views/res_partner_view.xml @@ -0,0 +1,14 @@ + + + + res.partner + + + + + + + + + + diff --git a/partner_contact_birthdate/README.rst b/partner_contact_birthdate/README.rst new file mode 100644 index 0000000..e7cc48c --- /dev/null +++ b/partner_contact_birthdate/README.rst @@ -0,0 +1,97 @@ +=================== +Contact's birthdate +=================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:db7b80c505264ae253e70964033a5805613fd32ba70d9368a8e6ce22dd1b54a7 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |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%2Fpartner--contact-lightgray.png?logo=github + :target: https://github.com/OCA/partner-contact/tree/16.0/partner_contact_birthdate + :alt: OCA/partner-contact +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/partner-contact-16-0/partner-contact-16-0-partner_contact_birthdate + :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/partner-contact&target_branch=16.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module was written to extend the functionality of Odoo to support setting +a birthdate using a date format and allow you to benefit of a clearer API and +UI. + +Add a computed age field on Partners + +.. image:: https://raw.githubusercontent.com/OCA/partner-contact/16.0/partner_contact_birthdate/static/description/age.png + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +To use this module, you need to: + +* Edit or create a partner. +* Ensure it is **not** a company. +* Set the birthdate there. + +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 +~~~~~~~ + +* Tecnativa + +Contributors +~~~~~~~~~~~~ + +* EL Hadji DEM +* Jairo Llopis +* Matjaž Mozetič +* Rudolf Schnapka +* Denis Leemann +* Tharathip Chaweewongphan +* Druidoo () + +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/partner-contact `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/partner_contact_birthdate/__init__.py b/partner_contact_birthdate/__init__.py new file mode 100644 index 0000000..4b76c7b --- /dev/null +++ b/partner_contact_birthdate/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from . import models diff --git a/partner_contact_birthdate/__manifest__.py b/partner_contact_birthdate/__manifest__.py new file mode 100644 index 0000000..fb18b6e --- /dev/null +++ b/partner_contact_birthdate/__manifest__.py @@ -0,0 +1,16 @@ +# Copyright 2014-2015 Grupo ESOC +# Copyright 2017-Apertoso N.V. () +# Copyright 2019-2020: Druidoo () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +{ + "name": "Contact's birthdate", + "version": "16.0.1.0.0", + "author": "Tecnativa, Odoo Community Association (OCA)", + "category": "Customer Relationship Management", + "website": "https://www.onestein.nl", + "depends": ["partner_contact_personal_information_page"], + "data": ["views/res_partner.xml"], + "license": "AGPL-3", + "installable": True, +} diff --git a/partner_contact_birthdate/i18n/am.po b/partner_contact_birthdate/i18n/am.po new file mode 100644 index 0000000..b5a24c3 --- /dev/null +++ b/partner_contact_birthdate/i18n/am.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Amharic (https://www.transifex.com/oca/teams/23907/am/)\n" +"Language: am\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "ተባባሪ" diff --git a/partner_contact_birthdate/i18n/ar.po b/partner_contact_birthdate/i18n/ar.po new file mode 100644 index 0000000..4f1c7c2 --- /dev/null +++ b/partner_contact_birthdate/i18n/ar.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Arabic (https://www.transifex.com/oca/teams/23907/ar/)\n" +"Language: ar\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=6; plural=n==0 ? 0 : n==1 ? 1 : n==2 ? 2 : n%100>=3 " +"&& n%100<=10 ? 3 : n%100>=11 && n%100<=99 ? 4 : 5;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "الشريك" diff --git a/partner_contact_birthdate/i18n/bg.po b/partner_contact_birthdate/i18n/bg.po new file mode 100644 index 0000000..3f56b5f --- /dev/null +++ b/partner_contact_birthdate/i18n/bg.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-12-31 01:39+0000\n" +"PO-Revision-Date: 2016-12-31 01:39+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Bulgarian (https://www.transifex.com/oca/teams/23907/bg/)\n" +"Language: bg\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Партньор" diff --git a/partner_contact_birthdate/i18n/bs.po b/partner_contact_birthdate/i18n/bs.po new file mode 100644 index 0000000..8f4b083 --- /dev/null +++ b/partner_contact_birthdate/i18n/bs.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Bosnian (https://www.transifex.com/oca/teams/23907/bs/)\n" +"Language: bs\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/ca.po b/partner_contact_birthdate/i18n/ca.po new file mode 100644 index 0000000..2d6b17e --- /dev/null +++ b/partner_contact_birthdate/i18n/ca.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2024-06-03 14:34+0000\n" +"Last-Translator: Eric Antones \n" +"Language-Team: Catalan (https://www.transifex.com/oca/teams/23907/ca/)\n" +"Language: ca\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: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Edat" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Data de naixement" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contacte" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/cs.po b/partner_contact_birthdate/i18n/cs.po new file mode 100644 index 0000000..fe4d034 --- /dev/null +++ b/partner_contact_birthdate/i18n/cs.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Czech (https://www.transifex.com/oca/teams/23907/cs/)\n" +"Language: cs\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Společník" diff --git a/partner_contact_birthdate/i18n/da.po b/partner_contact_birthdate/i18n/da.po new file mode 100644 index 0000000..f08f836 --- /dev/null +++ b/partner_contact_birthdate/i18n/da.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2019-07-30 11:51+0000\n" +"Last-Translator: Hans Henrik Gabelgaard \n" +"Language-Team: Danish (https://www.transifex.com/oca/teams/23907/da/)\n" +"Language: da\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 3.7.1\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Fødselsdato" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Kontakt" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/de.po b/partner_contact_birthdate/i18n/de.po new file mode 100644 index 0000000..bda11fc --- /dev/null +++ b/partner_contact_birthdate/i18n/de.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-05-01 20:42+0000\n" +"PO-Revision-Date: 2022-11-04 14:44+0000\n" +"Last-Translator: Maria Sparenberg \n" +"Language-Team: German (https://www.transifex.com/oca/teams/23907/de/)\n" +"Language: de\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.14.1\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Alter" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Geburtsdatum" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Kontakt" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/el_GR.po b/partner_contact_birthdate/i18n/el_GR.po new file mode 100644 index 0000000..f1391bf --- /dev/null +++ b/partner_contact_birthdate/i18n/el_GR.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Greek (Greece) (https://www.transifex.com/oca/teams/23907/" +"el_GR/)\n" +"Language: el_GR\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Συνεργάτης" diff --git a/partner_contact_birthdate/i18n/en_GB.po b/partner_contact_birthdate/i18n/en_GB.po new file mode 100644 index 0000000..f8cbfc6 --- /dev/null +++ b/partner_contact_birthdate/i18n/en_GB.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: English (United Kingdom) (https://www.transifex.com/oca/" +"teams/23907/en_GB/)\n" +"Language: en_GB\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/es.po b/partner_contact_birthdate/i18n/es.po new file mode 100644 index 0000000..02865a9 --- /dev/null +++ b/partner_contact_birthdate/i18n/es.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2023-08-31 08:13+0000\n" +"Last-Translator: Ivorra78 \n" +"Language-Team: Spanish (https://www.transifex.com/oca/teams/23907/es/)\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: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Edad" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Fecha de nacimiento" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contacto" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/es_CR.po b/partner_contact_birthdate/i18n/es_CR.po new file mode 100644 index 0000000..0b6b335 --- /dev/null +++ b/partner_contact_birthdate/i18n/es_CR.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Spanish (Costa Rica) (https://www.transifex.com/oca/" +"teams/23907/es_CR/)\n" +"Language: es_CR\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/es_EC.po b/partner_contact_birthdate/i18n/es_EC.po new file mode 100644 index 0000000..2241bb2 --- /dev/null +++ b/partner_contact_birthdate/i18n/es_EC.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Spanish (Ecuador) (https://www.transifex.com/oca/teams/23907/" +"es_EC/)\n" +"Language: es_EC\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/es_MX.po b/partner_contact_birthdate/i18n/es_MX.po new file mode 100644 index 0000000..b59b3cd --- /dev/null +++ b/partner_contact_birthdate/i18n/es_MX.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Spanish (Mexico) (https://www.transifex.com/oca/teams/23907/" +"es_MX/)\n" +"Language: es_MX\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/es_VE.po b/partner_contact_birthdate/i18n/es_VE.po new file mode 100644 index 0000000..81f6b3a --- /dev/null +++ b/partner_contact_birthdate/i18n/es_VE.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Spanish (Venezuela) (https://www.transifex.com/oca/" +"teams/23907/es_VE/)\n" +"Language: es_VE\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/et.po b/partner_contact_birthdate/i18n/et.po new file mode 100644 index 0000000..9255766 --- /dev/null +++ b/partner_contact_birthdate/i18n/et.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Estonian (https://www.transifex.com/oca/teams/23907/et/)\n" +"Language: et\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/eu.po b/partner_contact_birthdate/i18n/eu.po new file mode 100644 index 0000000..6ee876d --- /dev/null +++ b/partner_contact_birthdate/i18n/eu.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Basque (https://www.transifex.com/oca/teams/23907/eu/)\n" +"Language: eu\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Kidea" diff --git a/partner_contact_birthdate/i18n/fi.po b/partner_contact_birthdate/i18n/fi.po new file mode 100644 index 0000000..ef8a520 --- /dev/null +++ b/partner_contact_birthdate/i18n/fi.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +# Timo Talvitie , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-08-17 02:52+0000\n" +"PO-Revision-Date: 2017-08-17 02:52+0000\n" +"Last-Translator: Timo Talvitie , 2017\n" +"Language-Team: Finnish (https://www.transifex.com/oca/teams/23907/fi/)\n" +"Language: fi\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Syntymäaika" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Kumppani" diff --git a/partner_contact_birthdate/i18n/fr.po b/partner_contact_birthdate/i18n/fr.po new file mode 100644 index 0000000..1f17309 --- /dev/null +++ b/partner_contact_birthdate/i18n/fr.po @@ -0,0 +1,37 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 11.0+e\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-02-11 17:43+0000\n" +"PO-Revision-Date: 2022-11-29 12:45+0000\n" +"Last-Translator: Pierrick Brun \n" +"Language-Team: \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.14.1\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Âge" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Date de naissance" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contact" diff --git a/partner_contact_birthdate/i18n/fr_CA.po b/partner_contact_birthdate/i18n/fr_CA.po new file mode 100644 index 0000000..85561a0 --- /dev/null +++ b/partner_contact_birthdate/i18n/fr_CA.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: French (Canada) (https://www.transifex.com/oca/teams/23907/" +"fr_CA/)\n" +"Language: fr_CA\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partenaire" diff --git a/partner_contact_birthdate/i18n/fr_CH.po b/partner_contact_birthdate/i18n/fr_CH.po new file mode 100644 index 0000000..dcc564f --- /dev/null +++ b/partner_contact_birthdate/i18n/fr_CH.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: French (Switzerland) (https://www.transifex.com/oca/" +"teams/23907/fr_CH/)\n" +"Language: fr_CH\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partenaire" diff --git a/partner_contact_birthdate/i18n/gl.po b/partner_contact_birthdate/i18n/gl.po new file mode 100644 index 0000000..95997ef --- /dev/null +++ b/partner_contact_birthdate/i18n/gl.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Galician (https://www.transifex.com/oca/teams/23907/gl/)\n" +"Language: gl\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Empresa" diff --git a/partner_contact_birthdate/i18n/hr.po b/partner_contact_birthdate/i18n/hr.po new file mode 100644 index 0000000..73fa758 --- /dev/null +++ b/partner_contact_birthdate/i18n/hr.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-12-31 01:39+0000\n" +"PO-Revision-Date: 2023-01-04 02:38+0000\n" +"Last-Translator: Bole \n" +"Language-Team: Croatian (https://www.transifex.com/oca/teams/23907/hr/)\n" +"Language: hr\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" +"X-Generator: Weblate 4.14.1\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Dob" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Rođendan" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Kontakt" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/hr_HR.po b/partner_contact_birthdate/i18n/hr_HR.po new file mode 100644 index 0000000..d77a7fd --- /dev/null +++ b/partner_contact_birthdate/i18n/hr_HR.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2017-06-10 01:50+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Croatian (Croatia) (https://www.transifex.com/oca/teams/23907/" +"hr_HR/)\n" +"Language: hr_HR\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Datum rođenja" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/hu.po b/partner_contact_birthdate/i18n/hu.po new file mode 100644 index 0000000..ba0ed37 --- /dev/null +++ b/partner_contact_birthdate/i18n/hu.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Hungarian (https://www.transifex.com/oca/teams/23907/hu/)\n" +"Language: hu\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/it.po b/partner_contact_birthdate/i18n/it.po new file mode 100644 index 0000000..7118bd9 --- /dev/null +++ b/partner_contact_birthdate/i18n/it.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2023-07-06 19:09+0000\n" +"Last-Translator: Francesco Foresti \n" +"Language-Team: Italian (https://www.transifex.com/oca/teams/23907/it/)\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: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Età" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Data di nascita" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contatto" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/ja.po b/partner_contact_birthdate/i18n/ja.po new file mode 100644 index 0000000..c829378 --- /dev/null +++ b/partner_contact_birthdate/i18n/ja.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Japanese (https://www.transifex.com/oca/teams/23907/ja/)\n" +"Language: ja\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "パートナ" diff --git a/partner_contact_birthdate/i18n/lt.po b/partner_contact_birthdate/i18n/lt.po new file mode 100644 index 0000000..853675c --- /dev/null +++ b/partner_contact_birthdate/i18n/lt.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Lithuanian (https://www.transifex.com/oca/teams/23907/lt/)\n" +"Language: lt\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && (n" +"%100<10 || n%100>=20) ? 1 : 2);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partneris" diff --git a/partner_contact_birthdate/i18n/lv.po b/partner_contact_birthdate/i18n/lv.po new file mode 100644 index 0000000..73b7086 --- /dev/null +++ b/partner_contact_birthdate/i18n/lv.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Latvian (https://www.transifex.com/oca/teams/23907/lv/)\n" +"Language: lv\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n != 0 ? 1 : " +"2);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partneris" diff --git a/partner_contact_birthdate/i18n/mk.po b/partner_contact_birthdate/i18n/mk.po new file mode 100644 index 0000000..4636c32 --- /dev/null +++ b/partner_contact_birthdate/i18n/mk.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Macedonian (https://www.transifex.com/oca/teams/23907/mk/)\n" +"Language: mk\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=(n % 10 == 1 && n % 100 != 11) ? 0 : 1;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Партнер" diff --git a/partner_contact_birthdate/i18n/mn.po b/partner_contact_birthdate/i18n/mn.po new file mode 100644 index 0000000..eca5218 --- /dev/null +++ b/partner_contact_birthdate/i18n/mn.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Mongolian (https://www.transifex.com/oca/teams/23907/mn/)\n" +"Language: mn\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Харилцагч" diff --git a/partner_contact_birthdate/i18n/nb.po b/partner_contact_birthdate/i18n/nb.po new file mode 100644 index 0000000..756fbe6 --- /dev/null +++ b/partner_contact_birthdate/i18n/nb.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Norwegian Bokmål (https://www.transifex.com/oca/teams/23907/" +"nb/)\n" +"Language: nb\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/nb_NO.po b/partner_contact_birthdate/i18n/nb_NO.po new file mode 100644 index 0000000..cf00e91 --- /dev/null +++ b/partner_contact_birthdate/i18n/nb_NO.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Norwegian Bokmål (Norway) (https://www.transifex.com/oca/" +"teams/23907/nb_NO/)\n" +"Language: nb_NO\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/nl.po b/partner_contact_birthdate/i18n/nl.po new file mode 100644 index 0000000..1a885ea --- /dev/null +++ b/partner_contact_birthdate/i18n/nl.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +msgid "" +msgstr "" +"Project-Id-Version: partner-contact (8.0)\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2015-09-23 21:40+0000\n" +"PO-Revision-Date: 2015-08-06 21:25+0000\n" +"Last-Translator: <>\n" +"Language-Team: Dutch (http://www.transifex.com/oca/OCA-partner-contact-8-0/" +"language/nl/)\n" +"Language: nl\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/nl_BE.po b/partner_contact_birthdate/i18n/nl_BE.po new file mode 100644 index 0000000..ee14fa2 --- /dev/null +++ b/partner_contact_birthdate/i18n/nl_BE.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Dutch (Belgium) (https://www.transifex.com/oca/teams/23907/" +"nl_BE/)\n" +"Language: nl_BE\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Relatie" diff --git a/partner_contact_birthdate/i18n/nl_NL.po b/partner_contact_birthdate/i18n/nl_NL.po new file mode 100644 index 0000000..3ca6c10 --- /dev/null +++ b/partner_contact_birthdate/i18n/nl_NL.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# Peter Hageman , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2017-06-10 01:50+0000\n" +"Last-Translator: Peter Hageman , 2017\n" +"Language-Team: Dutch (Netherlands) (https://www.transifex.com/oca/" +"teams/23907/nl_NL/)\n" +"Language: nl_NL\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Geboortedatum" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Relatie" diff --git a/partner_contact_birthdate/i18n/pl.po b/partner_contact_birthdate/i18n/pl.po new file mode 100644 index 0000000..7e0b26d --- /dev/null +++ b/partner_contact_birthdate/i18n/pl.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Polish (https://www.transifex.com/oca/teams/23907/pl/)\n" +"Language: pl\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=4; plural=(n==1 ? 0 : (n%10>=2 && n%10<=4) && (n" +"%100<12 || n%100>=14) ? 1 : n!=1 && (n%10>=0 && n%10<=1) || (n%10>=5 && n" +"%10<=9) || (n%100>=12 && n%100<=14) ? 2 : 3);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/pt.po b/partner_contact_birthdate/i18n/pt.po new file mode 100644 index 0000000..b5731af --- /dev/null +++ b/partner_contact_birthdate/i18n/pt.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# Tiago Baptista , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-11-14 03:37+0000\n" +"PO-Revision-Date: 2021-11-10 21:35+0000\n" +"Last-Translator: Pedro Castro Silva \n" +"Language-Team: Portuguese (https://www.transifex.com/oca/teams/23907/pt/)\n" +"Language: pt\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: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Idade" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Data de Nascimento" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contacto" + +#~ msgid "Partner" +#~ msgstr "Parceiro" diff --git a/partner_contact_birthdate/i18n/pt_BR.po b/partner_contact_birthdate/i18n/pt_BR.po new file mode 100644 index 0000000..6262e68 --- /dev/null +++ b/partner_contact_birthdate/i18n/pt_BR.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2020-08-12 18:59+0000\n" +"Last-Translator: Rodrigo Macedo \n" +"Language-Team: Portuguese (Brazil) (https://www.transifex.com/oca/" +"teams/23907/pt_BR/)\n" +"Language: pt_BR\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 3.10\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "Idade" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Data de nascimento" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "Contato" + +#~ msgid "Partner" +#~ msgstr "Parceiro" diff --git a/partner_contact_birthdate/i18n/pt_PT.po b/partner_contact_birthdate/i18n/pt_PT.po new file mode 100644 index 0000000..58c5af9 --- /dev/null +++ b/partner_contact_birthdate/i18n/pt_PT.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2017-06-10 01:50+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Portuguese (Portugal) (https://www.transifex.com/oca/" +"teams/23907/pt_PT/)\n" +"Language: pt_PT\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Data de Nascimento" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Parceiro" diff --git a/partner_contact_birthdate/i18n/ro.po b/partner_contact_birthdate/i18n/ro.po new file mode 100644 index 0000000..1520c27 --- /dev/null +++ b/partner_contact_birthdate/i18n/ro.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Romanian (https://www.transifex.com/oca/teams/23907/ro/)\n" +"Language: ro\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n==1?0:(((n%100>19)||((n%100==0)&&(n!=0)))?" +"2:1));\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partener" diff --git a/partner_contact_birthdate/i18n/ru.po b/partner_contact_birthdate/i18n/ru.po new file mode 100644 index 0000000..1faea96 --- /dev/null +++ b/partner_contact_birthdate/i18n/ru.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Russian (https://www.transifex.com/oca/teams/23907/ru/)\n" +"Language: ru\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=4; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<12 || n%100>14) ? 1 : n%10==0 || (n%10>=5 && n%10<=9) || (n" +"%100>=11 && n%100<=14)? 2 : 3);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Контрагент" diff --git a/partner_contact_birthdate/i18n/sk.po b/partner_contact_birthdate/i18n/sk.po new file mode 100644 index 0000000..b9006a9 --- /dev/null +++ b/partner_contact_birthdate/i18n/sk.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Slovak (https://www.transifex.com/oca/teams/23907/sk/)\n" +"Language: sk\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/sl.po b/partner_contact_birthdate/i18n/sl.po new file mode 100644 index 0000000..283d80e --- /dev/null +++ b/partner_contact_birthdate/i18n/sl.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-06-10 01:50+0000\n" +"PO-Revision-Date: 2017-06-10 01:50+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Slovenian (https://www.transifex.com/oca/teams/23907/sl/)\n" +"Language: sl\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=4; plural=(n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n" +"%100==4 ? 2 : 3);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "Rojstni datum" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/sr@latin.po b/partner_contact_birthdate/i18n/sr@latin.po new file mode 100644 index 0000000..34c7c18 --- /dev/null +++ b/partner_contact_birthdate/i18n/sr@latin.po @@ -0,0 +1,41 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Serbian (Latin) (https://www.transifex.com/oca/teams/23907/" +"sr@latin/)\n" +"Language: sr@latin\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=(n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2);\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Partner" diff --git a/partner_contact_birthdate/i18n/sv.po b/partner_contact_birthdate/i18n/sv.po new file mode 100644 index 0000000..ba0063d --- /dev/null +++ b/partner_contact_birthdate/i18n/sv.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Swedish (https://www.transifex.com/oca/teams/23907/sv/)\n" +"Language: sv\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Företag" diff --git a/partner_contact_birthdate/i18n/th.po b/partner_contact_birthdate/i18n/th.po new file mode 100644 index 0000000..b31bc10 --- /dev/null +++ b/partner_contact_birthdate/i18n/th.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Thai (https://www.transifex.com/oca/teams/23907/th/)\n" +"Language: th\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "พาร์ทเนอร์" diff --git a/partner_contact_birthdate/i18n/tr.po b/partner_contact_birthdate/i18n/tr.po new file mode 100644 index 0000000..4317c13 --- /dev/null +++ b/partner_contact_birthdate/i18n/tr.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Turkish (https://www.transifex.com/oca/teams/23907/tr/)\n" +"Language: tr\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" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "İş Ortağı" diff --git a/partner_contact_birthdate/i18n/tr_TR.po b/partner_contact_birthdate/i18n/tr_TR.po new file mode 100644 index 0000000..c95ac22 --- /dev/null +++ b/partner_contact_birthdate/i18n/tr_TR.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Turkish (Turkey) (https://www.transifex.com/oca/teams/23907/" +"tr_TR/)\n" +"Language: tr_TR\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Ortak" diff --git a/partner_contact_birthdate/i18n/vi.po b/partner_contact_birthdate/i18n/vi.po new file mode 100644 index 0000000..3eca47a --- /dev/null +++ b/partner_contact_birthdate/i18n/vi.po @@ -0,0 +1,39 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Vietnamese (https://www.transifex.com/oca/teams/23907/vi/)\n" +"Language: vi\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "Đối tác" diff --git a/partner_contact_birthdate/i18n/zh_CN.po b/partner_contact_birthdate/i18n/zh_CN.po new file mode 100644 index 0000000..30b2a2e --- /dev/null +++ b/partner_contact_birthdate/i18n/zh_CN.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Chinese (China) (https://www.transifex.com/oca/teams/23907/" +"zh_CN/)\n" +"Language: zh_CN\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "业务伙伴" diff --git a/partner_contact_birthdate/i18n/zh_TW.po b/partner_contact_birthdate/i18n/zh_TW.po new file mode 100644 index 0000000..36eb30c --- /dev/null +++ b/partner_contact_birthdate/i18n/zh_TW.po @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_birthdate +# +# Translators: +# OCA Transbot , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-03-10 03:39+0000\n" +"PO-Revision-Date: 2017-03-10 03:39+0000\n" +"Last-Translator: OCA Transbot , 2017\n" +"Language-Team: Chinese (Taiwan) (https://www.transifex.com/oca/teams/23907/" +"zh_TW/)\n" +"Language: zh_TW\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__age +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__age +msgid "Age" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_partner__birthdate_date +#: model:ir.model.fields,field_description:partner_contact_birthdate.field_res_users__birthdate_date +msgid "Birthdate" +msgstr "" + +#. module: partner_contact_birthdate +#: model:ir.model,name:partner_contact_birthdate.model_res_partner +msgid "Contact" +msgstr "" + +#~ msgid "Partner" +#~ msgstr "夥伴" diff --git a/partner_contact_birthdate/models/__init__.py b/partner_contact_birthdate/models/__init__.py new file mode 100644 index 0000000..284a83f --- /dev/null +++ b/partner_contact_birthdate/models/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from . import res_partner diff --git a/partner_contact_birthdate/models/res_partner.py b/partner_contact_birthdate/models/res_partner.py new file mode 100644 index 0000000..e2e0ad8 --- /dev/null +++ b/partner_contact_birthdate/models/res_partner.py @@ -0,0 +1,25 @@ +# Copyright (C) 2014-2015 Grupo ESOC +# Copyright 2017-Apertoso N.V. () +# Copyright 2019-2020: Druidoo () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from dateutil.relativedelta import relativedelta + +from odoo import api, fields, models + + +class ResPartner(models.Model): + """Partner with birth date in date format.""" + + _inherit = "res.partner" + + birthdate_date = fields.Date("Birthdate") + age = fields.Integer(readonly=True, compute="_compute_age") + + @api.depends("birthdate_date") + def _compute_age(self): + for record in self: + age = 0 + if record.birthdate_date: + age = relativedelta(fields.Date.today(), record.birthdate_date).years + record.age = age diff --git a/partner_contact_birthdate/readme/CONTRIBUTORS.rst b/partner_contact_birthdate/readme/CONTRIBUTORS.rst new file mode 100644 index 0000000..64b86b6 --- /dev/null +++ b/partner_contact_birthdate/readme/CONTRIBUTORS.rst @@ -0,0 +1,7 @@ +* EL Hadji DEM +* Jairo Llopis +* Matjaž Mozetič +* Rudolf Schnapka +* Denis Leemann +* Tharathip Chaweewongphan +* Druidoo () diff --git a/partner_contact_birthdate/readme/DESCRIPTION.rst b/partner_contact_birthdate/readme/DESCRIPTION.rst new file mode 100644 index 0000000..179eeb1 --- /dev/null +++ b/partner_contact_birthdate/readme/DESCRIPTION.rst @@ -0,0 +1,7 @@ +This module was written to extend the functionality of Odoo to support setting +a birthdate using a date format and allow you to benefit of a clearer API and +UI. + +Add a computed age field on Partners + +.. image:: ../static/description/age.png diff --git a/partner_contact_birthdate/readme/INSTALLATION.rst b/partner_contact_birthdate/readme/INSTALLATION.rst new file mode 100644 index 0000000..c628846 --- /dev/null +++ b/partner_contact_birthdate/readme/INSTALLATION.rst @@ -0,0 +1,5 @@ +To install this module, you need to: + +* Install the OCA repository `partner-contact `_. +* Update your modules list. +* Search and install this module. diff --git a/partner_contact_birthdate/readme/USAGE.rst b/partner_contact_birthdate/readme/USAGE.rst new file mode 100644 index 0000000..b2f2840 --- /dev/null +++ b/partner_contact_birthdate/readme/USAGE.rst @@ -0,0 +1,5 @@ +To use this module, you need to: + +* Edit or create a partner. +* Ensure it is **not** a company. +* Set the birthdate there. diff --git a/partner_contact_birthdate/static/description/age.png b/partner_contact_birthdate/static/description/age.png new file mode 100644 index 0000000000000000000000000000000000000000..3a215b4552af423a9ab5594831d4bf4a03f5d2f0 GIT binary patch literal 97611 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 +

Beta License: AGPL-3 OCA/partner-contact Translate me on Weblate Try me on Runboat

+

This module was written to extend the functionality of Odoo to support setting +a birthdate using a date format and allow you to benefit of a clearer API and +UI.

+

Add a computed age field on Partners

+https://raw.githubusercontent.com/OCA/partner-contact/16.0/partner_contact_birthdate/static/description/age.png +

Table of contents

+ +
+

Usage

+

To use this module, you need to:

+
    +
  • Edit or create a partner.
  • +
  • Ensure it is not a company.
  • +
  • Set the birthdate there.
  • +
+
+
+

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

+
    +
  • Tecnativa
  • +
+
+
+

Contributors

+ +
+
+

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/partner-contact project on GitHub.

+

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

+
+
+ + + diff --git a/partner_contact_birthdate/tests/__init__.py b/partner_contact_birthdate/tests/__init__.py new file mode 100644 index 0000000..d79e79a --- /dev/null +++ b/partner_contact_birthdate/tests/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import test_res_partner diff --git a/partner_contact_birthdate/tests/test_res_partner.py b/partner_contact_birthdate/tests/test_res_partner.py new file mode 100644 index 0000000..ed4714a --- /dev/null +++ b/partner_contact_birthdate/tests/test_res_partner.py @@ -0,0 +1,21 @@ +# Copyright 2019-2020: Druidoo () +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from dateutil.relativedelta import relativedelta + +from odoo import fields +from odoo.tests import common + + +class TestResPartner(common.TransactionCase): + def setUp(self): + super(TestResPartner, self).setUp() + self.partner_admin = self.env.ref("base.partner_admin") + self.partner_admin.write({"birthdate_date": "1991-09-05"}) + + def test_compute_age(self): + self.partner_admin._compute_age() + age = relativedelta( + fields.Date.today(), self.partner_admin.birthdate_date + ).years + self.assertEqual(self.partner_admin.age, age) diff --git a/partner_contact_birthdate/views/res_partner.xml b/partner_contact_birthdate/views/res_partner.xml new file mode 100644 index 0000000..2a72caf --- /dev/null +++ b/partner_contact_birthdate/views/res_partner.xml @@ -0,0 +1,24 @@ + + + + + Birthdate Date field + res.partner + + + + + + + + + diff --git a/partner_contact_personal_information_page/README.rst b/partner_contact_personal_information_page/README.rst new file mode 100644 index 0000000..053eaa7 --- /dev/null +++ b/partner_contact_personal_information_page/README.rst @@ -0,0 +1,92 @@ +====================================== +Personal information page for contacts +====================================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:4bd91197ba2eb622494535877234acb17d3da589b20e46b4f158d410de16afc8 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |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%2Fpartner--contact-lightgray.png?logo=github + :target: https://github.com/OCA/partner-contact/tree/16.0/partner_contact_personal_information_page + :alt: OCA/partner-contact +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/partner-contact-16-0/partner-contact-16-0-partner_contact_personal_information_page + :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/partner-contact&target_branch=16.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module extends the contact management functionality. + +Its only purpose is to serve as a base for other modules that add personal +information fields to **contacts that are persons**. + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +You can find a new page called *Personal Information* in the contact's form. + +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 +~~~~~~~ + +* Nicolas JEUDY + +Contributors +~~~~~~~~~~~~ + +* EL Hadji DEM +* Jairo Llopis +* Matjaž Mozetič +* Rudolf Schnapka +* Richard deMeester +* Nicolas JEUDY +* Nikul CHaudhary +* Jeroen Evens +* Tharathip Chaweewongphan + +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/partner-contact `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/partner_contact_personal_information_page/__init__.py b/partner_contact_personal_information_page/__init__.py new file mode 100644 index 0000000..c71289a --- /dev/null +++ b/partner_contact_personal_information_page/__init__.py @@ -0,0 +1 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). diff --git a/partner_contact_personal_information_page/__manifest__.py b/partner_contact_personal_information_page/__manifest__.py new file mode 100644 index 0000000..c49b7b1 --- /dev/null +++ b/partner_contact_personal_information_page/__manifest__.py @@ -0,0 +1,16 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +{ + "name": "Personal information page for contacts", + "summary": "Add a page to contacts form to put personal information", + "version": "16.0.1.0.1", + "category": "Customer Relationship Management", + "website": "https://www.onestein.nl", + "author": "Nicolas JEUDY,Odoo Community Association (OCA)", + "license": "AGPL-3", + "application": False, + "installable": True, + "auto_install": False, + "depends": ["base"], + "data": ["views/res_partner.xml"], +} diff --git a/partner_contact_personal_information_page/i18n/ca.po b/partner_contact_personal_information_page/i18n/ca.po new file mode 100644 index 0000000..cfb398f --- /dev/null +++ b/partner_contact_personal_information_page/i18n/ca.po @@ -0,0 +1,22 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 15.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2022-04-07 14:05+0000\n" +"Last-Translator: juliap98 \n" +"Language-Team: none\n" +"Language: ca\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: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informació personal" diff --git a/partner_contact_personal_information_page/i18n/da.po b/partner_contact_personal_information_page/i18n/da.po new file mode 100644 index 0000000..4f1d721 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/da.po @@ -0,0 +1,22 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 11.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2018-11-09 09:02+0000\n" +"Last-Translator: Hans Henrik Gabelgaard \n" +"Language-Team: none\n" +"Language: da\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 3.2.2\n" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Personlig information" diff --git a/partner_contact_personal_information_page/i18n/de.po b/partner_contact_personal_information_page/i18n/de.po new file mode 100644 index 0000000..d2fa832 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/de.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2016-08-18 02:46+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: German (https://www.transifex.com/oca/teams/23907/de/)\n" +"Language: de\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Persönliche Auskunft" diff --git a/partner_contact_personal_information_page/i18n/es.po b/partner_contact_personal_information_page/i18n/es.po new file mode 100644 index 0000000..127500b --- /dev/null +++ b/partner_contact_personal_information_page/i18n/es.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2016-08-18 02:46+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Spanish (https://www.transifex.com/oca/teams/23907/es/)\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Información personal" diff --git a/partner_contact_personal_information_page/i18n/fi.po b/partner_contact_personal_information_page/i18n/fi.po new file mode 100644 index 0000000..6a74e8b --- /dev/null +++ b/partner_contact_personal_information_page/i18n/fi.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# Timo Talvitie , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-08-17 02:52+0000\n" +"PO-Revision-Date: 2017-08-17 02:52+0000\n" +"Last-Translator: Timo Talvitie , 2017\n" +"Language-Team: Finnish (https://www.transifex.com/oca/teams/23907/fi/)\n" +"Language: fi\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Henkilön tiedot" diff --git a/partner_contact_personal_information_page/i18n/fr.po b/partner_contact_personal_information_page/i18n/fr.po new file mode 100644 index 0000000..4c1f2b1 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/fr.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2016-08-18 02:46+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: French (https://www.transifex.com/oca/teams/23907/fr/)\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informations personnelles" diff --git a/partner_contact_personal_information_page/i18n/hr.po b/partner_contact_personal_information_page/i18n/hr.po new file mode 100644 index 0000000..e918ec7 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/hr.po @@ -0,0 +1,23 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-02-15 19:22+0000\n" +"Last-Translator: Bole \n" +"Language-Team: none\n" +"Language: hr\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" +"X-Generator: Weblate 4.14.1\n" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Privatni podaci" diff --git a/partner_contact_personal_information_page/i18n/hr_HR.po b/partner_contact_personal_information_page/i18n/hr_HR.po new file mode 100644 index 0000000..1153d65 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/hr_HR.po @@ -0,0 +1,26 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# Bole , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-11-14 03:37+0000\n" +"PO-Revision-Date: 2016-11-14 03:37+0000\n" +"Last-Translator: Bole , 2016\n" +"Language-Team: Croatian (Croatia) (https://www.transifex.com/oca/teams/23907/" +"hr_HR/)\n" +"Language: hr_HR\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Osobne informacije" diff --git a/partner_contact_personal_information_page/i18n/hu.po b/partner_contact_personal_information_page/i18n/hu.po new file mode 100644 index 0000000..387d897 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/hu.po @@ -0,0 +1,22 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2021-09-08 21:33+0000\n" +"Last-Translator: Tamás Dombos \n" +"Language-Team: none\n" +"Language: hu\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: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Személyes adatok" diff --git a/partner_contact_personal_information_page/i18n/it.po b/partner_contact_personal_information_page/i18n/it.po new file mode 100644 index 0000000..efef6cc --- /dev/null +++ b/partner_contact_personal_information_page/i18n/it.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# Giuliano Lotta , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-01-07 04:23+0000\n" +"PO-Revision-Date: 2017-01-07 04:23+0000\n" +"Last-Translator: Giuliano Lotta , 2017\n" +"Language-Team: Italian (https://www.transifex.com/oca/teams/23907/it/)\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informazioni personali" diff --git a/partner_contact_personal_information_page/i18n/ja.po b/partner_contact_personal_information_page/i18n/ja.po new file mode 100644 index 0000000..1760c22 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/ja.po @@ -0,0 +1,22 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-11-30 12:34+0000\n" +"Last-Translator: Tatsuki Kanda \n" +"Language-Team: none\n" +"Language: ja\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=1; plural=0;\n" +"X-Generator: Weblate 4.17\n" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "個人情報" diff --git a/partner_contact_personal_information_page/i18n/nl.po b/partner_contact_personal_information_page/i18n/nl.po new file mode 100644 index 0000000..fa83d8d --- /dev/null +++ b/partner_contact_personal_information_page/i18n/nl.po @@ -0,0 +1,24 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2016-08-18 02:46+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Dutch (https://www.transifex.com/oca/teams/23907/nl/)\n" +"Language: nl\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Persoonlijke informatie" diff --git a/partner_contact_personal_information_page/i18n/pt.po b/partner_contact_personal_information_page/i18n/pt.po new file mode 100644 index 0000000..a32d576 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/pt.po @@ -0,0 +1,22 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2021-11-10 21:35+0000\n" +"Last-Translator: Pedro Castro Silva \n" +"Language-Team: none\n" +"Language: pt\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: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informação Pessoal" diff --git a/partner_contact_personal_information_page/i18n/pt_BR.po b/partner_contact_personal_information_page/i18n/pt_BR.po new file mode 100644 index 0000000..8f4f430 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/pt_BR.po @@ -0,0 +1,25 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# Albert Vonpupp , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-12-03 03:23+0000\n" +"PO-Revision-Date: 2016-12-03 03:23+0000\n" +"Last-Translator: Albert Vonpupp , 2016\n" +"Language-Team: Portuguese (Brazil) (https://www.transifex.com/oca/" +"teams/23907/pt_BR/)\n" +"Language: pt_BR\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informação pessoal" diff --git a/partner_contact_personal_information_page/i18n/pt_PT.po b/partner_contact_personal_information_page/i18n/pt_PT.po new file mode 100644 index 0000000..62d68e4 --- /dev/null +++ b/partner_contact_personal_information_page/i18n/pt_PT.po @@ -0,0 +1,25 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# Tiago Baptista , 2017 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 10.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2017-01-20 18:18+0000\n" +"PO-Revision-Date: 2017-01-20 18:18+0000\n" +"Last-Translator: Tiago Baptista , 2017\n" +"Language-Team: Portuguese (Portugal) (https://www.transifex.com/oca/" +"teams/23907/pt_PT/)\n" +"Language: pt_PT\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" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Informação Pessoal" diff --git a/partner_contact_personal_information_page/i18n/sl.po b/partner_contact_personal_information_page/i18n/sl.po new file mode 100644 index 0000000..560ccff --- /dev/null +++ b/partner_contact_personal_information_page/i18n/sl.po @@ -0,0 +1,25 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * partner_contact_personal_information_page +# +# Translators: +# OCA Transbot , 2016 +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 9.0c\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2016-08-18 02:46+0000\n" +"PO-Revision-Date: 2016-08-18 02:46+0000\n" +"Last-Translator: OCA Transbot , 2016\n" +"Language-Team: Slovenian (https://www.transifex.com/oca/teams/23907/sl/)\n" +"Language: sl\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=4; plural=(n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n" +"%100==4 ? 2 : 3);\n" + +#. module: partner_contact_personal_information_page +#: model_terms:ir.ui.view,arch_db:partner_contact_personal_information_page.personal_information +msgid "Personal Information" +msgstr "Osebni podatki" diff --git a/partner_contact_personal_information_page/readme/CONTRIBUTORS.rst b/partner_contact_personal_information_page/readme/CONTRIBUTORS.rst new file mode 100644 index 0000000..f779df0 --- /dev/null +++ b/partner_contact_personal_information_page/readme/CONTRIBUTORS.rst @@ -0,0 +1,9 @@ +* EL Hadji DEM +* Jairo Llopis +* Matjaž Mozetič +* Rudolf Schnapka +* Richard deMeester +* Nicolas JEUDY +* Nikul CHaudhary +* Jeroen Evens +* Tharathip Chaweewongphan diff --git a/partner_contact_personal_information_page/readme/DESCRIPTION.rst b/partner_contact_personal_information_page/readme/DESCRIPTION.rst new file mode 100644 index 0000000..74b8079 --- /dev/null +++ b/partner_contact_personal_information_page/readme/DESCRIPTION.rst @@ -0,0 +1,4 @@ +This module extends the contact management functionality. + +Its only purpose is to serve as a base for other modules that add personal +information fields to **contacts that are persons**. diff --git a/partner_contact_personal_information_page/readme/USAGE.rst b/partner_contact_personal_information_page/readme/USAGE.rst new file mode 100644 index 0000000..5de516f --- /dev/null +++ b/partner_contact_personal_information_page/readme/USAGE.rst @@ -0,0 +1 @@ +You can find a new page called *Personal Information* in the contact's form. diff --git a/partner_contact_personal_information_page/static/description/icon.png b/partner_contact_personal_information_page/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..3a0328b516c4980e8e44cdb63fd945757ddd132d GIT binary patch literal 9455 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 z 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 Xviia!U7SGha1wx#SCgwmn*{w2TRX*I literal 0 HcmV?d00001 diff --git a/partner_contact_personal_information_page/static/description/index.html b/partner_contact_personal_information_page/static/description/index.html new file mode 100644 index 0000000..bbf5308 --- /dev/null +++ b/partner_contact_personal_information_page/static/description/index.html @@ -0,0 +1,436 @@ + + + + + + +Personal information page for contacts + + + +
+

Personal information page for contacts

+ + +

Beta License: AGPL-3 OCA/partner-contact Translate me on Weblate Try me on Runboat

+

This module extends the contact management functionality.

+

Its only purpose is to serve as a base for other modules that add personal +information fields to contacts that are persons.

+

Table of contents

+ +
+

Usage

+

You can find a new page called Personal Information in the contact’s form.

+
+
+

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

+
    +
  • Nicolas JEUDY
  • +
+
+
+

Contributors

+ +
+
+

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/partner-contact project on GitHub.

+

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

+
+
+
+ + diff --git a/partner_contact_personal_information_page/views/res_partner.xml b/partner_contact_personal_information_page/views/res_partner.xml new file mode 100644 index 0000000..3a6bc5a --- /dev/null +++ b/partner_contact_personal_information_page/views/res_partner.xml @@ -0,0 +1,21 @@ + + + + + Personal information page for contacts form + res.partner + + 2 + + + + + + + + + diff --git a/project_role/README.rst b/project_role/README.rst new file mode 100644 index 0000000..40348a0 --- /dev/null +++ b/project_role/README.rst @@ -0,0 +1,112 @@ +============= +Project Roles +============= + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |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%2Fproject-lightgray.png?logo=github + :target: https://github.com/OCA/project/tree/16.0/project_role + :alt: OCA/project +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/project-16-0/project-16-0-project_role + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/140/16.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module allows maintaining project roster based on roles and assignments. +List of roles is configured at company level, while assignments can be created +on project, company, and cross-company levels, with configurable inheritance. + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +To configure the list of roles avalable: + +#. Go to *Project > Configuration > Project Roles* +#. Add/remove roles according to your business processes + +To manage assignments on particular project: + +#. Go to *Project > Projects* +#. Open project of interest +#. Click on *Assignments* smart-button +#. Add/remove assignments as needed + +To manage assignments: + +#. Go to *Project > Assignments* +#. Add/remove assignments as needed + +Also, it's recommended to consider using ``web_m2x_options`` module in order to +avoid unneeded creation of roles and projects using Quick Create action by +setting the ``web_m2x_options.create`` system parameter to ``False``. + +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 smashing it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +~~~~~~~ + +* CorporateHub + +Contributors +~~~~~~~~~~~~ + +* `CorporateHub `__ + + * Alexey Pelykh + +* Alfadil Mustafa +* Tharathip Chaweewongphan + +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. + +.. |maintainer-alexey-pelykh| image:: https://github.com/alexey-pelykh.png?size=40px + :target: https://github.com/alexey-pelykh + :alt: alexey-pelykh + +Current `maintainer `__: + +|maintainer-alexey-pelykh| + +This module is part of the `OCA/project `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/project_role/__init__.py b/project_role/__init__.py new file mode 100644 index 0000000..4b76c7b --- /dev/null +++ b/project_role/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from . import models diff --git a/project_role/__manifest__.py b/project_role/__manifest__.py new file mode 100644 index 0000000..31b21f2 --- /dev/null +++ b/project_role/__manifest__.py @@ -0,0 +1,25 @@ +# Copyright 2018-2019 Brainbean Apps (https://brainbeanapps.com) +# Copyright 2020-2022 CorporateHub (https://corporatehub.eu) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +{ + "name": "Project Roles", + "version": "16.0.1.0.0", + "category": "Project", + "website": "https://www.onestein.nl", + "author": "CorporateHub, Odoo Community Association (OCA)", + "license": "AGPL-3", + "installable": True, + "application": False, + "summary": "Project role-based roster", + "depends": ["project", "mail"], + "data": [ + "security/ir.model.access.csv", + "security/project_role.xml", + "views/project_assignment.xml", + "views/project_project.xml", + "views/project_role.xml", + "views/res_config_settings.xml", + ], + "maintainers": ["alexey-pelykh"], +} diff --git a/project_role/i18n/de.po b/project_role/i18n/de.po new file mode 100644 index 0000000..a6f0cc0 --- /dev/null +++ b/project_role/i18n/de.po @@ -0,0 +1,554 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 13.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-03-03 09:15+0000\n" +"Last-Translator: Nils Coenen \n" +"Language-Team: none\n" +"Language: de\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.14.1\n" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "%(USER)s als %(ROLE)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "%(USER)s als %(ROLE)s in %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "%(USER)s als %(ROLE)s auf %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Projektrollen\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Aktion benötigt" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Aktiv" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Archiviert" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" +"Zuweisung %(ASSIGNMENT)s hat einen Konflikt mit einer anderen Zuweisung: " +"%(OTHER_ASSIGNMENT)s" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Rollenzuweisungen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Anhangsanzahl" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" +"Aktivieren Sie diese Option, um Projekte so zu konfigurieren, dass sie " +"Unternehmenszuweisungen standardmäßig erben." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" +"Aktivieren Sie diese Option, um Projekte so zu konfigurieren, dass die Rolle " +"standardmäßig auf Zuweisungen beschränkt wird." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Untergeordnete Rollen" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Unternehmen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Unternehmen" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "unternehmensweit" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Vollständige Bezeichnung" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Konfigurationseinstellungen" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Bitte Projektrollen für Projekte konfigurieren." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Erstellt von" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Erstellt am" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Beschreibung" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Anzeigename" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Abonnenten" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Abonnenten (Partner)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Gruppieren nach" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "Hat Nachricht" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Wenn es gesetzt ist, erfordern neue Nachrichten Ihre Aufmerksamkeit." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "" +"Wenn es gesetzt ist, gibt es einige Nachrichten mit einem Übertragungsfehler." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "Zuweisungen erben" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Ist Abonnent" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Zuletzt geändert am" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Zuletzt aktualisiert von" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Zuletzt aktualisiert am" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +#, fuzzy +msgid "Limit Project Role to Assignments" +msgstr "Projekt-Rollenzuweisungen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Haupt-Anhang" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Nachrichten-Übertragungsfehler" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Nachrichten" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Meine Rollenzuweisungen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Bezeichnung" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Anzahl der Aktionen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +#, fuzzy +msgid "Number of errors" +msgstr "Anzahl der Fehler" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Dies ist die Anzahl von Nachrichten, die eine Aktion benötigen." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Dies ist die Anzahl von Nachrichten mit einem Übertragungsfehler." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Übergeordnete Rolle" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Bitte zuerst die übergeordnete Rolle %s aktivieren." + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Projekt" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Projekt-Rollenzuweisung" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Projekt-Rollenzuweisungen" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Projektrolle" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Projektrollen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +#, fuzzy +msgid "Projects Inherit Assignments" +msgstr "Projekt-Rollenzuweisungen" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +#, fuzzy +msgid "Projects inherit Company assignments" +msgstr "Projekt-Rollenzuweisungen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Rolle" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "" +"Die Rolle \"%s\" steht im Konflikt mit einer anderen Rolle, die denselben " +"Namen hat." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "Eine Rolle mit demselben Namen existiert in dem Unternehmen bereits!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Rollen und Zuweisungen" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +#, fuzzy +msgid "SMS Delivery error" +msgstr "Nachrichten-Übertragungsfehler" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Projektrollen anlegen" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "Eine geteilte Rolle mit diesem Namen existiert bereits!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Benutzer" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" +"Benutzer %(USER)s kann keiner Rolle zugeordnet werden: %(ROLE)s in " +"%(PROJECT)s." + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "Benutzer %(USER)s kann der Rolle nicht zugeordnet werden: %(ROLE)s." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" +"Der Benutzer sollte einer Rolle innerhalb eines Unternehmens nur einmal " +"zugewiesen sein!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" +"Der Benutzer sollte einer Rolle innerhalb eines Projekts nur einmal " +"zugewiesen sein!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "Der Benutzer sollte einer Rolle nur einmal zugewiesen sein!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Website-Nachrichten" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Website-Kommunikationshistorie" + +#, python-format +#~ msgid "%s as %s" +#~ msgstr "%s als %s" + +#, python-format +#~ msgid "%s as %s in %s" +#~ msgstr "%s als %s für %s" + +#, python-format +#~ msgid "%s as %s on %s" +#~ msgstr "%s als %s für %s" + +#, python-format +#~ msgid "Assignment %s conflicts with another assignment: %s" +#~ msgstr "" +#~ "Die Rollenzuweisung %s steht im Konflikt mit einer anderen Zuweisung: %s" + +#~ msgid "Followers (Channels)" +#~ msgstr "Abonnenten (Kanäle)" + +#~ msgid "Inactive" +#~ msgstr "Inaktiv" + +#~ msgid "Inherit assignments" +#~ msgstr "Zuweisung vererben" + +#, fuzzy +#~ msgid "Limit role to assignments" +#~ msgstr "Projekt-Rollenzuweisungen" + +#~ msgid "Number of unread messages" +#~ msgstr "Dies ist die Anzahl von ungelesenen Nachrichten." + +#~ msgid "Unread Messages" +#~ msgstr "Ungelesene Nachrichten" + +#~ msgid "Unread Messages Counter" +#~ msgstr "Zähler für ungelesene Nachrichten" + +#, python-format +#~ msgid "User %s can not be assigned to role %s on %s." +#~ msgstr "" +#~ "Der Benutzer %s kann der Rolle %s in dem Projekt %s nicht zugewiesen " +#~ "werden." + +#, python-format +#~ msgid "User %s can not be assigned to role %s." +#~ msgstr "Der Benutzer %s kann der Rolle %s nicht zugewiesen werden." + +#~ msgid "If checked new messages require your attention." +#~ msgstr "" +#~ "Wenn es gesetzt ist, erfordern neue Nachrichten Ihre Aufmerksamkeit." + +#~ msgid "You cannot create recursive roles." +#~ msgstr "Es können keine rekursive Rollen erstellt werden." + +#~ msgid "Activity State" +#~ msgstr "Aktivitätsstatus" + +#~ msgid "Next Activity Deadline" +#~ msgstr "Frist für die nächste Aktivität" + +#~ msgid "Next Activity Summary" +#~ msgstr "Zusammenfassung der nächsten Aktivität" + +#~ msgid "Next Activity Type" +#~ msgstr "Typ der nächsten Aktivität" + +#~ msgid "Overdue" +#~ msgstr "Überfällig" + +#~ msgid "Planned" +#~ msgstr "Geplant" + +#~ msgid "Responsible User" +#~ msgstr "Verantwortlicher Benutzer" + +#~ msgid "" +#~ "Status based on activities\n" +#~ "Overdue: Due date is already passed\n" +#~ "Today: Activity date is today\n" +#~ "Planned: Future activities." +#~ msgstr "" +#~ "Der Status hängt von den Aktivitäten ab.\n" +#~ "Überfällig: Das Fälligkeitsdatum der Aktivität ist überschritten.\n" +#~ "Heute: Die Aktivität findet heute statt.\n" +#~ "Geplant: Die Aktivitäten findet in der Zukunft statt." + +#~ msgid "Today" +#~ msgstr "Heute" diff --git a/project_role/i18n/es.po b/project_role/i18n/es.po new file mode 100644 index 0000000..cc3c9cb --- /dev/null +++ b/project_role/i18n/es.po @@ -0,0 +1,450 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-02-01 10:45+0000\n" +"Last-Translator: David Ramia \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.14.1\n" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "%(USER)s como %(ROLE)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "%(USER)s como %(ROLE)s en %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "%(USER)s como %(ROLE)s en %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Roles del proyecto\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Acción Requerida" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Activo" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Archivado" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" +"La asignación %(ASSIGNMENT)s entra en conflicto con otra asignación: " +"%(OTHER_ASSIGNMENT)s" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Cuenta de asignaciones" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" +"Marque para configurar los proyectos para heredar las asignaciones de la " +"empresa de forma predeterminada." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" +"Marque para configurar los proyectos para limitar el rol a las asignaciones " +"de forma predeterminada." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Roles hijos" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Empresas" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Empresa" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "Toda la empresa" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Nombre completo" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Opciones de Configuración" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Configure un conjunto de roles, disponibles en los proyectos." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Creado por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Creado el" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Descripción" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Nombre mostrado" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Seguidores" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Seguidores (empresas)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Agrupar por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "Tiene mensaje" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Si está marcada, los nuevos mensajes requieren su atención." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "Si está marcado algunos mensajes tienen error de entrega." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "Heredar asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Es Seguidor" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Última Modificación el" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Última actualización por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Última actualización el" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Limitar el Rol del Proyecto a las Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "Limitar rol a asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Adjunto Principal" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Mensaje de Error de Entrega" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Mensajes" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Mis Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Nombre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Número de Acciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "Número de errores" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Número de mensajes que requieren una acción" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Número de mensajes con error de entrega" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Ruta padre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Rol padre" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Por favor active el rol %s del primer padre" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Proyecto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Asignación de Proyecto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Asignaciones de Proyecto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Rol del Proyecto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Roles del Proyecto" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Asignaciones Heredadas de los Proyectos" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "Proyectos que Heredan Asignaciones de la Compañía" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Rol" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "El Rol \"%s\" entra en conflicto con otro rol debido al mismo nombre." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "¡El Rol con ese nombre ya existe en la compañía!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Roles y Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "Error de Entrega SMS" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Configurar roles de proyecto" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "¡El Rol compartido con ese nombre ya existe!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Usuario" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "El usuario %(USER)s no se puede asignar al rol %(ROLE)s en %(PROJECT)s." + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "El usuario %(USER)s no se puede asignar al rol %(ROLE)s." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" +"¡El usuario puede ser asignado por rol solo una vez dentro de una empresa!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" +"¡El usuario puede ser asignado por rol solo una vez dentro de un proyecto!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "¡El usuario puede ser asignado por rol solo una vez!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Mensajes del Sitio Web" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Historial de comunicación del Sitio Web" diff --git a/project_role/i18n/es_AR.po b/project_role/i18n/es_AR.po new file mode 100644 index 0000000..3a726fb --- /dev/null +++ b/project_role/i18n/es_AR.po @@ -0,0 +1,492 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2022-02-06 20:59+0000\n" +"Last-Translator: Ignacio Buioli \n" +"Language-Team: none\n" +"Language: es_AR\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: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Roles de Proyecto\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Acción Requerida" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Activo" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Archivado" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Cuenta de Adjuntos" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" +"Marque para configurar proyectos para heredar las asignaciones de la empresa " +"de forma predeterminada." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" +"Marque para configurar proyectos para limitar el rol a las asignaciones de " +"forma predeterminada." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Roles Hijos" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Compañías" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Compañía" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "Toda la Empresa" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Nombre Completo" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Configurar Ajustes" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Configure un conjunto de roles, disponibles en los proyectos." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Creado por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Creado en" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Descripción" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Mostrar Nombre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Seguidores" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Seguidores (Contactos)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Agrupar Por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Si está seleccionado, los nuevos mensajes requieren su atención." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "Si está seleccionado, algunos mensajes tienen error de entrega." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Es Seguidor" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Última modificación en" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Última actualización realizada por" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Última actualización el" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Limitar el Rol del Proyecto a las Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Adjunto Principal" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Mensaje de Error de Entrega" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Mensajes" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Mis Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Nombre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Número de Acciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "Número de errores" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Número de mensajes que requieren una acción" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Número de mensajes con error de entrega" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Ruta del Padre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Rol del Padre" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Por favor active el rol %s del primer padre" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Proyecto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Asignación de Proyecto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Asignaciones de Proyecto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Rol del Proyecto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Roles del Proyecto" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Asignaciones Heredadas de los Proyectos" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "Proyectos que Heredan Asignaciones de la Compañía" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Rol" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "El Rol \"%s\" entra en conflicto con otro rol debido al mismo nombre." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "¡El Rol con ese nombre ya existe en la compañía!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Roles & Asignaciones" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "Error de Entrega SMS" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Configurar roles de proyecto" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "¡El Rol compartido con ese nombre ya existe!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Usuario" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" +"¡El usuario puede ser asignado por rol solo una vez dentro de una empresa!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" +"¡El usuario puede ser asignado por rol solo una vez dentro de un proyecto!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "¡El usuario puede ser asignado por rol solo una vez!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Mensajes del Sitio Web" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Historial de comunicación del Sitio Web" + +#, python-format +#~ msgid "%s as %s" +#~ msgstr "%s como %s" + +#, python-format +#~ msgid "%s as %s in %s" +#~ msgstr "%s como %s en %s" + +#, python-format +#~ msgid "%s as %s on %s" +#~ msgstr "%s como %s el %s" + +#, python-format +#~ msgid "Assignment %s conflicts with another assignment: %s" +#~ msgstr "La asignación %s entra en conflicto con otra asignación: %s" + +#~ msgid "Followers (Channels)" +#~ msgstr "Seguidores (Canales)" + +#~ msgid "Inherit assignments" +#~ msgstr "Asignaciones heredadas" + +#~ msgid "Limit role to assignments" +#~ msgstr "Limitar rol a asignaciones" + +#~ msgid "Number of unread messages" +#~ msgstr "Número de mensajes sin leer" + +#~ msgid "Unread Messages" +#~ msgstr "Mensajes sin Leer" + +#~ msgid "Unread Messages Counter" +#~ msgstr "Contador de los Mensajes sin Leer" + +#, python-format +#~ msgid "User %s can not be assigned to role %s on %s." +#~ msgstr "El usuario %s no se puede asignar al rol %s en %s." + +#, python-format +#~ msgid "User %s can not be assigned to role %s." +#~ msgstr "El usuario %s no se puede asignar al rol %s." diff --git a/project_role/i18n/es_PA.po b/project_role/i18n/es_PA.po new file mode 100644 index 0000000..1199147 --- /dev/null +++ b/project_role/i18n/es_PA.po @@ -0,0 +1,433 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: Automatically generated\n" +"Language-Team: none\n" +"Language: es_PA\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" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "" diff --git a/project_role/i18n/fr.po b/project_role/i18n/fr.po new file mode 100644 index 0000000..5a5a219 --- /dev/null +++ b/project_role/i18n/fr.po @@ -0,0 +1,474 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2021-05-14 18:47+0000\n" +"Last-Translator: Yves Le Doeuff \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: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Actif" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Archivé" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Affectations" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Nombre d'attachements" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" +"Cochez cette case pour configurer les projets afin qu'ils héritent des " +"affectations de l'entreprise par défaut." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" +"Cochez cette case pour configurer les projets afin de limiter le rôle aux " +"affectations par défaut." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Rôles enfants" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Sociétés" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Société" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "Dans toute l'entreprise" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Nom complet" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Configurer un ensemble de rôles, disponibles sur les projets." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Créé par" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Créé le" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Abonnés" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Abonnés (Partenaires)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Groupe par" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Est abonné" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Limiter le rôle du projet aux affectations" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Pièce jointe principale" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Mes affectations" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Nom" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Nombre d'actions" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "Nombre d'erreurs" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Nombre de messages qui nécessitent une action" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Chemin parent" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Rôle parent" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Veuillez activé le rôle parent %s" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Projet" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Affectation du projet" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Affectations du projet" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Rôle du projet" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Rôles du projet" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Affectations héritées du projet" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "Affectations de la société héritées du projet" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Rôle" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "" +"Le rôle \"%s\" est en conflit avec un autre rôle à cause d'un nom identique." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "Un rôle avec ce nom existe déjà dans la société !" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Rôles & Affectations" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Configurer les rôles du projet" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "Le rôle partagé avec ce nom existe déjà !" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Utilisateur" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" +"Un utilisateur ne peut être affecté qu'une seule fois par rôle au sein d'une " +"même entreprise !" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" +"Un utilisateur ne peut se voir attribuer un rôle qu'une seule fois dans un " +"projet !" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "Chaque rôle ne peut être attribué qu'une seule fois à un utilisateur !" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "" + +#, python-format +#~ msgid "Assignment %s conflicts with another assignment: %s" +#~ msgstr "L'affectation %s est en conflit avec une autre affectation : %s" + +#~ msgid "Followers (Channels)" +#~ msgstr "Abonnés (Canaux)" + +#~ msgid "Inherit assignments" +#~ msgstr "Affectations héritées" + +#~ msgid "Limit role to assignments" +#~ msgstr "Limiter le rôle aux affectations" + +#~ msgid "Number of unread messages" +#~ msgstr "Nombre de messages non lus" + +#~ msgid "Unread Messages" +#~ msgstr "Messages non lus" + +#~ msgid "Unread Messages Counter" +#~ msgstr "Messages non lus" + +#, python-format +#~ msgid "User %s can not be assigned to role %s on %s." +#~ msgstr "L'utilisateur %s ne peut pas se voir affecter le rôle %s sur %s." + +#, python-format +#~ msgid "User %s can not be assigned to role %s." +#~ msgstr "L'utilisateur %s ne peut pas se voir affecter le rôle %s." diff --git a/project_role/i18n/hr.po b/project_role/i18n/hr.po new file mode 100644 index 0000000..19d107c --- /dev/null +++ b/project_role/i18n/hr.po @@ -0,0 +1,443 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-02-15 17:23+0000\n" +"Last-Translator: Bole \n" +"Language-Team: none\n" +"Language: hr\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=3; plural=n%10==1 && n%100!=11 ? 0 : n%10>=2 && n" +"%10<=4 && (n%100<10 || n%100>=20) ? 1 : 2;\n" +"X-Generator: Weblate 4.14.1\n" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "%(USER)s kao %(ROLE)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "%(USER)s kao %(ROLE)s na %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "%(USER)s kao %(ROLE)s na %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Uloge na projektima\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Potrebne radnje" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Aktivno" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Arhivirano" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "Uloga %(ASSIGNMENT)s je u sukobu sa drugom ulogom: %(OTHER_ASSIGNMENT)s" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Broj priloga" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "Označite, da bi projekti naslijedili zaduženja tvrtke kao zadane." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "Označite za postavljanje projekata na ograničenje uloga za zaduživanje." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Podređene uloge" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Tvrtke" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Tvrtka" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "Unutra tvrtke" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Puni naziv" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Postavke" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Postavite skup uloga, dostupnih na projektima." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Kreirao" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Kreirano" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Opis" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Prikazani naziv" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Pratitelji" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Pratitelji (partneri)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Grupiraj po" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "Ima poruka" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Ako je označeno, nove poruke traže vašu pažnju." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "Ako je označeno, neke poruke imaju greške pri isporuci." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "Nasljedi zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Je pratitelj" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Zadnje modificirano" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Zadnji ažurirao" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Zadnje ažurirano" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Ograniči uloge na projektu na zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "Ograniči uloge na zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Glavni prilog" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Greška pri isporuci poruke" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Poruke" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Moja zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Naziv" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Broj radnji" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "Broj grešaka" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Broj poruka koje zahtijevaju pažnju" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Broj poruka sa greškama pri isporuci" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Nadređena putanja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Nadređena uloga" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Molimo prije aktivirajte nadređenu ulogu %s" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Projekt" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Uloga na projektu" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Projektna zaduženja" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Projektna uloga" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Projektne uloge" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Projekti nasljeđuju zaduženja" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "Projekti nasljeđuju zaduženja tvrtke" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Uloga" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "Uloga \"%s\" je u konfliktu sa drugom ulogom zbog istog naziva." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "Uloga istog imena već postoji unutar tvrtke!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Uloge i Zaduženja" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "Greška isporuke SMSa" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Postavke projektnih uloga" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "Dijeljena uloga istog naziva već postoji!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Korisnik" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" +"Korisniku %(USER)s nije moguće dodijeliti ulogu %(ROLE)s na %(PROJECT)s." + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "Korisniku %(USER)s nije moguće dodijeliti ulogu %(ROLE)s." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "Korisniku možete dodijeliti ulogu samo jednom unutar tvrtke!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "Korisniku može biti dodijeljeno zaduženje samo unutar projekta!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "Korisniku zaduženje može biti dodijeljeno samo jednom!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Poruke sa webstranica" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Povijest komunikacije webstranica" diff --git a/project_role/i18n/it.po b/project_role/i18n/it.po new file mode 100644 index 0000000..78cc4c3 --- /dev/null +++ b/project_role/i18n/it.po @@ -0,0 +1,450 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-05-24 18:11+0000\n" +"Last-Translator: Francesco Foresti \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: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "%(USER)s come %(ROLE)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "%(USER)s come %(ROLE)s in %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "%(USER)s come %(ROLE)s in %(PROJECT)s" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Ruoli progetto\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Azione richiesta" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Attivo" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "In archivio" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" +"L'incarico %(ASSIGNMENT)s è in conflitto con un altro incarico: " +"%(OTHER_ASSIGNMENT)s" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Conteggio allegati" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "" +"Selezionare per configurare i progetti per ereditare in modo predefinito gli " +"incarichi dell'azienda." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "" +"Selezionare per configurare i progetti per limitare il ruolo agli incarichi " +"in modo predefinito." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Ruoli figli" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Aziende" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Azienda" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "Tutta l'azienda" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Nome completo" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Impostazioni configurazione" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Configurare gruppi di ruoli, disponibili nei progetti." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Creato da" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Creato il" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Descrizione" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Nome visualizzato" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Seguito da" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Seguito da (partner)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Raggruppa per" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "Ha un messaggio" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Se selezionata, nuovi messaggi richiedono attenzione." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "Se selezionata, alcuni messaggi hanno un errore di consegna." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "Eredita incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Segue" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Ultima modifica il" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Ultimo aggiornamento di" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Ultimo aggiornamento il" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Limita ruolo progetto agli incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "Limita il ruolo agli incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Allegato principale" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Errore di consegna messaggio" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Messaggi" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Miei incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Nome" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Numero di azioni" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +msgid "Number of errors" +msgstr "Numero di errori" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Numero di messaggi che richiedono un'azione" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Numero di messaggi con errore di consegna" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Percorso padre" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Ruolo padre" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Attivare prima il ruolo padre %s" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Progetto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Incarico progetto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Incarichi progetto" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Ruolo progetto" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Ruoli progetto" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Incarichi ereditati dal progetto" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "I progetti ereditano gli incarichi azienda" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Ruolo" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "Il ruolo \"%s\" è in conflitto con un altro ruolo con lo stesso nome." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "Esiste già un ruolo con questo nome nell'azienda!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Ruoli & incarichi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +msgid "SMS Delivery error" +msgstr "Errore consegna SMS" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Configura ruoli progetto" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "Esiste già un ruolo condiviso con lo stesso nome!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Utente" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" +"L'utente %(USER)s non può essere assegnato al ruolo %(ROLE)s in %(PROJECT)s." + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "L'utente %(USER)s non può essere assegnato al ruolo %(ROLE)s." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "" +"Un utente può essere assegnato ad un solo ruolo alla volta in una azienda!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "" +"Un utente può essere assegnato ad un solo ruolo alla volta in un progetto!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "Un utente può essere assegnato ad un ruolo alla volta!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Messaggi sito web" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Storico comunicazioni sito web" diff --git a/project_role/i18n/sl.po b/project_role/i18n/sl.po new file mode 100644 index 0000000..3202382 --- /dev/null +++ b/project_role/i18n/sl.po @@ -0,0 +1,502 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * project_role +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 13.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-04-12 13:35+0000\n" +"Last-Translator: Matjaz Mozetic \n" +"Language-Team: none\n" +"Language: sl\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=4; plural=n%100==1 ? 0 : n%100==2 ? 1 : n%100==3 || n" +"%100==4 ? 2 : 3;\n" +"X-Generator: Weblate 4.14.1\n" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s in %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "%(USER)s as %(ROLE)s on %(PROJECT)s" +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "%(parent)s / %(own)s" +msgstr "%(parent)s / %(own)s" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"" +msgstr "" +"" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "" +"Project Roles\n" +" " +msgstr "" +"Projektne vloge\n" +" " + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction +msgid "Action Needed" +msgstr "Potrebno ukrepanje" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__active +#: model:ir.model.fields,field_description:project_role.field_project_role__active +msgid "Active" +msgstr "Aktivno" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_form +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_search +#: model_terms:ir.ui.view,arch_db:project_role.project_role_view_form +msgid "Archived" +msgstr "Arhivirano" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "" +"Assignment %(ASSIGNMENT)s conflicts with another assignment: " +"%(OTHER_ASSIGNMENT)s" +msgstr "" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_project_action +#: model:ir.ui.menu,name:project_role.menu_project_assignments +#: model_terms:ir.ui.view,arch_db:project_role.edit_project +msgid "Assignments" +msgstr "Zadolžitve" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_attachment_count +msgid "Attachment Count" +msgstr "Št. priponk" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to inherit company assignments by default." +msgstr "Označite, da bi projekti privzeto dedovali zadolžitve družbe." + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Check to configure projects to limit role to assignments by default." +msgstr "Označite, da bi privzeto omejili projektno vlogo na zadolžitve." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__child_ids +msgid "Child Roles" +msgstr "Podrejene vloge" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_company +msgid "Companies" +msgstr "Družbe" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__company_id +#: model:ir.model.fields,field_description:project_role.field_project_role__company_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company" +msgstr "Družba" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Company-Wide" +msgstr "V sklopu družbe" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__complete_name +msgid "Complete Name" +msgstr "Poln naziv" + +#. module: project_role +#: model:ir.model,name:project_role.model_res_config_settings +msgid "Config Settings" +msgstr "Nastavitve" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Configure set of roles, available on projects." +msgstr "Nastavi sklop pravil na voljo pri projektih." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__create_uid +msgid "Created by" +msgstr "Ustvaril" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__create_date +#: model:ir.model.fields,field_description:project_role.field_project_role__create_date +msgid "Created on" +msgstr "Ustvarjeno" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__description +msgid "Description" +msgstr "Opis" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__display_name +#: model:ir.model.fields,field_description:project_role.field_project_role__display_name +msgid "Display Name" +msgstr "Prikazani naziv" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_follower_ids +msgid "Followers" +msgstr "Sledilci" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_partner_ids +msgid "Followers (Partners)" +msgstr "Sledilci (partnerji)" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Group By" +msgstr "Združi po" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__has_message +msgid "Has Message" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__id +#: model:ir.model.fields,field_description:project_role.field_project_role__id +msgid "ID" +msgstr "ID" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction +msgid "If checked, new messages require your attention." +msgstr "Če označeno pomeni, da nova sporočila zahtevajo vašo pozornost." + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_sms_error +msgid "If checked, some messages have a delivery error." +msgstr "" +"Če označeno pomeni, da je pri nekaterih sporočilih prišlo do napake pri " +"dostavi." + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__inherit_assignments +msgid "Inherit Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_is_follower +msgid "Is Follower" +msgstr "Je sledilec" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment____last_update +#: model:ir.model.fields,field_description:project_role.field_project_role____last_update +msgid "Last Modified on" +msgstr "Zadnjič spremenjeno" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_uid +#: model:ir.model.fields,field_description:project_role.field_project_role__write_uid +msgid "Last Updated by" +msgstr "Zadnji posodobil" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__write_date +#: model:ir.model.fields,field_description:project_role.field_project_role__write_date +msgid "Last Updated on" +msgstr "Zadnjič posodobljeno" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_limit_role_to_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_limit_role_to_assignments +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Limit Project Role to Assignments" +msgstr "Omeji projektne vloge na zadolžitve" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_project__limit_role_to_assignments +msgid "Limit Role To Assignments" +msgstr "" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_main_attachment_id +msgid "Main Attachment" +msgstr "Glavna priponka" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error +msgid "Message Delivery error" +msgstr "Napaka ob dostavi sporočila" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_ids +msgid "Messages" +msgstr "Sporočila" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "My Assignments" +msgstr "Moje zadolžitve" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__name +#: model:ir.model.fields,field_description:project_role.field_project_role__name +msgid "Name" +msgstr "Naziv" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_needaction_counter +msgid "Number of Actions" +msgstr "Število ukrepov" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_error_counter +#, fuzzy +msgid "Number of errors" +msgstr "Število napak" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_needaction_counter +msgid "Number of messages which requires an action" +msgstr "Število sporočil, kjer je potrebno ukrepati" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__message_has_error_counter +msgid "Number of messages with delivery error" +msgstr "Število sporočil z napako ob dostavi" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_path +msgid "Parent Path" +msgstr "Nadrejena pot" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_role__parent_id +msgid "Parent Role" +msgstr "Nadrejena vloga" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Please activate first parent role %s" +msgstr "Najprej aktivirajte nadrejeno vlogo %s" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_project +#: model:ir.model.fields,field_description:project_role.field_project_assignment__project_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Project" +msgstr "Projekt" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_assignment +msgid "Project Assignment" +msgstr "Projektna zadolžitev" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.project_assignment_view_all_action +#: model:ir.model.fields,field_description:project_role.field_project_project__assignment_ids +msgid "Project Assignments" +msgstr "Projektne zadolžitve" + +#. module: project_role +#: model:ir.model,name:project_role.model_project_role +msgid "Project Role" +msgstr "Projektna vloga" + +#. module: project_role +#: model:ir.actions.act_window,name:project_role.company_project_roles_action +#: model:ir.ui.menu,name:project_role.project_menu_config_roles +msgid "Project Roles" +msgstr "Projektne vloge" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_res_company__project_inherit_assignments +#: model:ir.model.fields,field_description:project_role.field_res_config_settings__project_inherit_assignments +msgid "Projects Inherit Assignments" +msgstr "Projekti dedujejo zadolžitve" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Projects inherit Company assignments" +msgstr "Projekti dedujejo zadolžitve iz družbe" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__role_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "Role" +msgstr "Vloga" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_role.py:0 +#, python-format +msgid "Role \"%s\" conflicts with another role due to same name." +msgstr "Vloga \"%s\" je v konfliktu z drugo vlogo z istim nazivom." + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_company_uniq +msgid "Role with such name already exists in the company!" +msgstr "Vloga s takim nazivom že obstaja v sklopu družbe!" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Roles & Assignments" +msgstr "Vloge in zadolžitve" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__message_has_sms_error +#, fuzzy +msgid "SMS Delivery error" +msgstr "Napaka ob dostavi sporočila" + +#. module: project_role +#: model_terms:ir.ui.view,arch_db:project_role.res_config_settings_view_form +msgid "Setup project roles" +msgstr "Nastavi projektne vloge" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_role_name_nocompany_uniq +msgid "Shared role with such name already exists!" +msgstr "Vloga v souporabi s takim nazivom že obstaja!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__user_id +#: model_terms:ir.ui.view,arch_db:project_role.project_assignment_search +msgid "User" +msgstr "Uporabnik" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." +msgstr "" + +#. module: project_role +#. odoo-python +#: code:addons/project_role/models/project_assignment.py:0 +#, python-format +msgid "User %(USER)s can not be assigned to role %(ROLE)s." +msgstr "" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_company_role_user_uniq +msgid "User may be assigned per role only once within a company!" +msgstr "Uporabniku se lahko dodeli določena vloga le enkrat v sklopu družbe!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_project_role_user_uniq +msgid "User may be assigned per role only once within a project!" +msgstr "Uporabniku se lahko dodeli določena vloga le enkrat v sklopu projekta!" + +#. module: project_role +#: model:ir.model.constraint,message:project_role.constraint_project_assignment_nocompany_role_user_uniq +msgid "User may be assigned per role only once!" +msgstr "Uporabniku se lahko dodeli določeno vlogo le enkrat!" + +#. module: project_role +#: model:ir.model.fields,field_description:project_role.field_project_assignment__website_message_ids +msgid "Website Messages" +msgstr "Sporočila spletne strani" + +#. module: project_role +#: model:ir.model.fields,help:project_role.field_project_assignment__website_message_ids +msgid "Website communication history" +msgstr "Kronologija komunikacij spletne strani" + +#, python-format +#~ msgid "%s as %s" +#~ msgstr "%s kot %s" + +#, python-format +#~ msgid "%s as %s in %s" +#~ msgstr "%s kot %s v %s" + +#, python-format +#~ msgid "%s as %s on %s" +#~ msgstr "%s kot %s na %s" + +#, python-format +#~ msgid "Assignment %s conflicts with another assignment: %s" +#~ msgstr "Zadolžitev %s je v konfliktu z zadolžitvijo: %s" + +#~ msgid "Followers (Channels)" +#~ msgstr "Sledilci (kanali)" + +#~ msgid "Inactive" +#~ msgstr "Neaktivno" + +#~ msgid "Inherit assignments" +#~ msgstr "Deduj zadolžitve" + +#~ msgid "Limit role to assignments" +#~ msgstr "Omeji vlogo na zadolžitve" + +#~ msgid "Number of unread messages" +#~ msgstr "Število neprebranih sporočil" + +#~ msgid "Unread Messages" +#~ msgstr "Neprebrana sporočila" + +#~ msgid "Unread Messages Counter" +#~ msgstr "Št. neprebranih sporočil" + +#, python-format +#~ msgid "User %s can not be assigned to role %s on %s." +#~ msgstr "Uporabniku %s ni mogoče dodeliti vloge %s na %s." + +#, python-format +#~ msgid "User %s can not be assigned to role %s." +#~ msgstr "Uporabniku %s ni mogoče dodeliti vloge %s." + +#~ msgid "If checked new messages require your attention." +#~ msgstr "Če označeno pomeni, da nova sporočila zahtevajo vašo pozornost." + +#~ msgid "WBS element" +#~ msgstr "Projektni člen" + +#~ msgid "You cannot create recursive roles." +#~ msgstr "Rekurzivne vloge niso dovoljene." diff --git a/project_role/models/__init__.py b/project_role/models/__init__.py new file mode 100644 index 0000000..84f6330 --- /dev/null +++ b/project_role/models/__init__.py @@ -0,0 +1,7 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from . import res_config_settings +from . import res_company +from . import project_role +from . import project_assignment +from . import project_project diff --git a/project_role/models/project_assignment.py b/project_role/models/project_assignment.py new file mode 100644 index 0000000..95525cd --- /dev/null +++ b/project_role/models/project_assignment.py @@ -0,0 +1,157 @@ +# Copyright 2018-2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import _, api, fields, models +from odoo.exceptions import ValidationError + + +class ProjectAssignment(models.Model): + _name = "project.assignment" + _description = "Project Assignment" + _inherit = ["mail.thread"] + + active = fields.Boolean( + default=True, + ) + name = fields.Char( + compute="_compute_name", + store=True, + index=True, + ) + company_id = fields.Many2one( + comodel_name="res.company", + string="Company", + default=lambda self: self.env.company, + ondelete="cascade", + ) + project_id = fields.Many2one( + comodel_name="project.project", + string="Project", + ondelete="cascade", + ) + role_id = fields.Many2one( + comodel_name="project.role", + string="Role", + required=True, + ondelete="restrict", + ) + user_id = fields.Many2one( + comodel_name="res.users", + string="User", + required=True, + ondelete="restrict", + ) + + _sql_constraints = [ + ( + "project_role_user_uniq", + "UNIQUE (project_id, role_id, user_id)", + "User may be assigned per role only once within a project!", + ), + ( + "company_role_user_uniq", + ( + "EXCLUDE (" + " company_id WITH =, role_id WITH =, user_id WITH =" + ") WHERE (" + " project_id IS NULL" + ")" + ), + "User may be assigned per role only once within a company!", + ), + ( + "nocompany_role_user_uniq", + ( + "EXCLUDE (role_id WITH =, user_id WITH =) WHERE (" + " project_id IS NULL AND company_id IS NULL" + ")" + ), + "User may be assigned per role only once!", + ), + ] + + @api.depends( + "company_id.name", + "project_id.name", + "role_id.name", + "user_id.name", + ) + def _compute_name(self): + for assignment in self: + if assignment.project_id: + assignment.name = _("%(USER)s as %(ROLE)s on %(PROJECT)s") % { + "USER": assignment.user_id.name, + "ROLE": assignment.role_id.name, + "PROJECT": assignment.project_id.name, + } + elif assignment.company_id: + assignment.name = _("%(USER)s as %(ROLE)s in %(PROJECT)s") % { + "USER": assignment.user_id.name, + "ROLE": assignment.role_id.name, + "PROJECT": assignment.company_id.name, + } + else: + assignment.name = _("%(USER)s as %(ROLE)s") % { + "USER": assignment.user_id.name, + "ROLE": assignment.role_id.name, + } + + def _get_conflicting_domain(self): + self.ensure_one() + return ( + [ + ("id", "!=", self.id), + ("role_id", "=", self.role_id.id), + ("user_id", "=", self.user_id.id), + ] + + ( + [("company_id", "in", [False, self.company_id.id])] + if self.company_id + else [] + ) + + ( + [("project_id", "in", [False, self.project_id.id])] + if self.project_id + else [] + ) + ) + + @api.constrains("company_id", "project_id", "role_id", "user_id") + def _check(self): + """ + Check if assignment conflicts with any already-existing assignment and + if specific role can be assigned at all (extension hook). + """ + for assignment in self: + conflicting_assignment = self.search( + assignment._get_conflicting_domain(), + limit=1, + ) + if conflicting_assignment: + raise ValidationError( + _( + "Assignment %(ASSIGNMENT)s conflicts with another assignment: " + "%(OTHER_ASSIGNMENT)s" + ) + % { + "ASSIGNMENT": assignment.name, + "OTHER_ASSIGNMENT": conflicting_assignment.name, + } + ) + if not assignment.role_id.can_assign( + assignment.user_id, assignment.project_id + ): + if assignment.project_id: + error = _( + "User %(USER)s can not be assigned to role %(ROLE)s on %(PROJECT)s." + ) % { + "USER": assignment.user_id.name, + "ROLE": assignment.role_id.name, + "PROJECT": assignment.project_id.name, + } + else: + error = _("User %(USER)s can not be assigned to role %(ROLE)s.") % { + "USER": assignment.user_id.name, + "ROLE": assignment.role_id.name, + } + raise ValidationError(error) diff --git a/project_role/models/project_project.py b/project_role/models/project_project.py new file mode 100644 index 0000000..c611e7f --- /dev/null +++ b/project_role/models/project_project.py @@ -0,0 +1,57 @@ +# Copyright 2018-2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import api, fields, models + + +class ProjectProject(models.Model): + _inherit = "project.project" + + assignment_ids = fields.One2many( + string="Project Assignments", + comodel_name="project.assignment", + inverse_name="project_id", + tracking=True, + ) + inherit_assignments = fields.Boolean( + default=lambda self: self._default_inherit_assignments(), + ) + limit_role_to_assignments = fields.Boolean( + default=lambda self: self._default_limit_role_to_assignments(), + ) + + @api.model + def _default_inherit_assignments(self): + company = self.env["res.company"].browse( + self._context.get("company_id", self.env.company.id) + ) + return company.project_inherit_assignments + + @api.model + def _default_limit_role_to_assignments(self): + company = self.env["res.company"].browse( + self._context.get("company_id", self.env.company.id) + ) + return company.project_limit_role_to_assignments + + def _project_role_create_assignment_values(self, vals_list): + """Complete values with default assignments from company""" + company_ids = [v["company_id"] for v in vals_list if v.get("company_id")] + companies = self.env["res.company"].browse(company_ids) + for values in vals_list: + company = None + if values.get("company_id"): + company = companies.filtered(lambda c: c.id == values["company_id"]) + if company and "inherit_assignments" not in values: + values["inherit_assignments"] = company.project_inherit_assignments + + if company and "limit_role_to_assignments" not in values: + values[ + "limit_role_to_assignments" + ] = company.project_limit_role_to_assignments + return vals_list + + @api.model_create_multi + def create(self, vals_list): + vals_list = self._project_role_create_assignment_values(vals_list) + return super().create(vals_list) diff --git a/project_role/models/project_role.py b/project_role/models/project_role.py new file mode 100644 index 0000000..be06bf9 --- /dev/null +++ b/project_role/models/project_role.py @@ -0,0 +1,135 @@ +# Copyright 2018-2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import _, api, fields, models +from odoo.exceptions import ValidationError +from odoo.tools.translate import html_translate + + +class ProjectRole(models.Model): + _name = "project.role" + _description = "Project Role" + _parent_name = "parent_id" + _parent_store = True + _rec_name = "complete_name" + _order = "complete_name" + + active = fields.Boolean( + default=True, + ) + parent_path = fields.Char(index=True, unaccent=False) + parent_id = fields.Many2one( + string="Parent Role", + comodel_name="project.role", + index=True, + ondelete="cascade", + ) + child_ids = fields.One2many( + string="Child Roles", + comodel_name="project.role", + inverse_name="parent_id", + copy=True, + ) + complete_name = fields.Char( + compute="_compute_complete_name", store=True, recursive=True + ) + name = fields.Char( + translate=True, + required=True, + ) + description = fields.Html( + translate=html_translate, + ) + company_id = fields.Many2one( + comodel_name="res.company", + string="Company", + default=lambda self: self.env.company, + ondelete="cascade", + ) + + _sql_constraints = [ + ( + "name_company_uniq", + "UNIQUE (name, company_id)", + "Role with such name already exists in the company!", + ), + ( + "name_nocompany_uniq", + ("EXCLUDE (name WITH =) WHERE (" " company_id IS NULL" ")"), + "Shared role with such name already exists!", + ), + ] + + @api.constrains("name") + def _check_name(self): + for role in self: + if self.search( + [ + ("company_id", "=" if role.company_id else "!=", False), + ("name", "=", role.name), + ], + limit=1, + ): + raise ValidationError( + _('Role "%s" conflicts with another role due to same name.') + % (role.name,) + ) + + @api.depends("name", "parent_id.complete_name") + def _compute_complete_name(self): + for role in self: + if role.parent_id: + role.complete_name = _("%(parent)s / %(own)s") % { + "parent": role.parent_id.complete_name, + "own": role.name, + } + else: + role.complete_name = role.name + + @api.constrains("active") + def _check_active(self): + for role in self: + if ( + role.active + and role.parent_id + and role.parent_id not in self + and not role.parent_id.active + ): + raise ValidationError( + _("Please activate first parent role %s") + % (role.parent_id.complete_name,) + ) + + def can_assign(self, user_id, project_id): + """Extension point to check if user can be assigned to this role""" + self.ensure_one() + return self.active + + @api.model + def get_available_roles(self, user_id, project_id): + """ + Get domain on roles that can be assumed by given user on a specific + project, depending on company and project assignments configuration. + """ + if not user_id or not project_id: + return self + + if not project_id.limit_role_to_assignments: + if project_id.inherit_assignments: + domain = [("company_id", "in", [False, user_id.company_id.id])] + else: + domain = [("company_id", "=", user_id.company_id.id)] + return self.search(domain) + + domain = [("user_id", "=", user_id.id)] + if project_id.inherit_assignments: + domain += [ + ("project_id", "in", [False, project_id.id]), + ("company_id", "in", [False, user_id.company_id.id]), + ] + else: + domain += [ + ("project_id", "=", project_id.id), + ("company_id", "=", user_id.company_id.id), + ] + return self.env["project.assignment"].search(domain).mapped("role_id") diff --git a/project_role/models/res_company.py b/project_role/models/res_company.py new file mode 100644 index 0000000..0c21db8 --- /dev/null +++ b/project_role/models/res_company.py @@ -0,0 +1,17 @@ +# Copyright 2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class ResCompany(models.Model): + _inherit = "res.company" + + project_inherit_assignments = fields.Boolean( + string="Projects Inherit Assignments", + default=True, + ) + project_limit_role_to_assignments = fields.Boolean( + string="Limit Project Role to Assignments", + default=False, + ) diff --git a/project_role/models/res_config_settings.py b/project_role/models/res_config_settings.py new file mode 100644 index 0000000..d6e8b8e --- /dev/null +++ b/project_role/models/res_config_settings.py @@ -0,0 +1,17 @@ +# Copyright 2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class ResConfigSettings(models.TransientModel): + _inherit = "res.config.settings" + + project_inherit_assignments = fields.Boolean( + related="company_id.project_inherit_assignments", + readonly=False, + ) + project_limit_role_to_assignments = fields.Boolean( + related="company_id.project_limit_role_to_assignments", + readonly=False, + ) diff --git a/project_role/readme/CONFIGURE.rst b/project_role/readme/CONFIGURE.rst new file mode 100644 index 0000000..9fceb7b --- /dev/null +++ b/project_role/readme/CONFIGURE.rst @@ -0,0 +1,20 @@ +To configure the list of roles avalable: + +#. Go to *Project > Configuration > Project Roles* +#. Add/remove roles according to your business processes + +To manage assignments on particular project: + +#. Go to *Project > Projects* +#. Open project of interest +#. Click on *Assignments* smart-button +#. Add/remove assignments as needed + +To manage assignments: + +#. Go to *Project > Assignments* +#. Add/remove assignments as needed + +Also, it's recommended to consider using ``web_m2x_options`` module in order to +avoid unneeded creation of roles and projects using Quick Create action by +setting the ``web_m2x_options.create`` system parameter to ``False``. diff --git a/project_role/readme/CONTRIBUTORS.rst b/project_role/readme/CONTRIBUTORS.rst new file mode 100644 index 0000000..3071ef0 --- /dev/null +++ b/project_role/readme/CONTRIBUTORS.rst @@ -0,0 +1,6 @@ +* `CorporateHub `__ + + * Alexey Pelykh + +* Alfadil Mustafa +* Tharathip Chaweewongphan diff --git a/project_role/readme/DESCRIPTION.rst b/project_role/readme/DESCRIPTION.rst new file mode 100644 index 0000000..4082e1d --- /dev/null +++ b/project_role/readme/DESCRIPTION.rst @@ -0,0 +1,3 @@ +This module allows maintaining project roster based on roles and assignments. +List of roles is configured at company level, while assignments can be created +on project, company, and cross-company levels, with configurable inheritance. diff --git a/project_role/security/ir.model.access.csv b/project_role/security/ir.model.access.csv new file mode 100644 index 0000000..bcffac1 --- /dev/null +++ b/project_role/security/ir.model.access.csv @@ -0,0 +1,7 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_project_role_assignee,project.role,model_project_role,base.group_user,1,0,0,0 +access_project_role_user,project.role,model_project_role,project.group_project_user,1,0,0,0 +access_project_role_manager,project.role,model_project_role,base.group_system,1,1,1,1 +access_project_assignment_assignee,project.assignment,model_project_assignment,base.group_user,1,0,0,0 +access_project_assignment_user,project.assignment,model_project_assignment,project.group_project_user,1,0,0,0 +access_project_assignment_manager,project.assignment,model_project_assignment,project.group_project_manager,1,1,1,1 diff --git a/project_role/security/project_role.xml b/project_role/security/project_role.xml new file mode 100644 index 0000000..5096807 --- /dev/null +++ b/project_role/security/project_role.xml @@ -0,0 +1,23 @@ + + + + + Project Role multi-company + + + ['|',('company_id','=',False),('company_id','child_of',[user.company_id.id])] + + + Project Assignment multi-company + + + ['|',('company_id','=',False),('company_id','child_of',[user.company_id.id])] + + diff --git a/project_role/static/description/icon.png b/project_role/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..3a0328b516c4980e8e44cdb63fd945757ddd132d GIT binary patch literal 9455 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 z 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 Xviia!U7SGha1wx#SCgwmn*{w2TRX*I literal 0 HcmV?d00001 diff --git a/project_role/static/description/index.html b/project_role/static/description/index.html new file mode 100644 index 0000000..ce7139b --- /dev/null +++ b/project_role/static/description/index.html @@ -0,0 +1,452 @@ + + + + + + +Project Roles + + + +
+

Project Roles

+ + +

Beta License: AGPL-3 OCA/project Translate me on Weblate Try me on Runbot

+

This module allows maintaining project roster based on roles and assignments. +List of roles is configured at company level, while assignments can be created +on project, company, and cross-company levels, with configurable inheritance.

+

Table of contents

+ +
+

Configuration

+

To configure the list of roles avalable:

+
    +
  1. Go to Project > Configuration > Project Roles
  2. +
  3. Add/remove roles according to your business processes
  4. +
+

To manage assignments on particular project:

+
    +
  1. Go to Project > Projects
  2. +
  3. Open project of interest
  4. +
  5. Click on Assignments smart-button
  6. +
  7. Add/remove assignments as needed
  8. +
+

To manage assignments:

+
    +
  1. Go to Project > Assignments
  2. +
  3. Add/remove assignments as needed
  4. +
+

Also, it’s recommended to consider using web_m2x_options module in order to +avoid unneeded creation of roles and projects using Quick Create action by +setting the web_m2x_options.create system parameter to False.

+
+
+

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 smashing it by providing a detailed and welcomed +feedback.

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • CorporateHub
  • +
+
+
+

Contributors

+ +
+
+

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.

+

Current maintainer:

+

alexey-pelykh

+

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

+

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

+
+
+
+ + diff --git a/project_role/tests/__init__.py b/project_role/tests/__init__.py new file mode 100644 index 0000000..5560a00 --- /dev/null +++ b/project_role/tests/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from . import test_project_role diff --git a/project_role/tests/test_project_role.py b/project_role/tests/test_project_role.py new file mode 100644 index 0000000..e3eb7f8 --- /dev/null +++ b/project_role/tests/test_project_role.py @@ -0,0 +1,312 @@ +# Copyright 2018-2019 Brainbean Apps (https://brainbeanapps.com) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl.html). + +from unittest import mock + +from psycopg2 import IntegrityError + +from odoo.exceptions import UserError, ValidationError +from odoo.tests import common +from odoo.tools.misc import mute_logger + +_module_ns = "odoo.addons.project_role" +_project_role_class = _module_ns + ".models.project_role.ProjectRole" + + +class TestProjectRole(common.TransactionCase): + def setUp(self): + super().setUp() + + self.ResUsers = self.env["res.users"] + self.Company = self.env["res.company"] + self.Project = self.env["project.project"] + self.Role = self.env["project.role"] + self.Assignment = self.env["project.assignment"] + self.company_id = self.env.company + + def test_create_assignment(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + project = self.Project.create({"name": "Project"}) + role = self.Role.create({"name": "Role"}) + self.Assignment.create( + {"project_id": project.id, "role_id": role.id, "user_id": user.id} + ) + + self.assertEqual(self.Role.get_available_roles(user, project).ids, role.ids) + + def test_no_duplicate_assignment(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + project = self.Project.create({"name": "Project"}) + role = self.Role.create({"name": "Role"}) + self.Assignment.create( + {"project_id": project.id, "role_id": role.id, "user_id": user.id} + ) + + with self.assertRaises(IntegrityError), mute_logger("odoo.sql_db"): + self.Assignment.create( + {"project_id": project.id, "role_id": role.id, "user_id": user.id} + ) + + def test_restrict_assign(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + project = self.Project.create({"name": "Project"}) + role = self.Role.create({"name": "Role"}) + company_1 = self.Company.create({"name": "Company #1"}) + with mock.patch( + _project_role_class + ".can_assign", + return_value=False, + ): + with self.assertRaises(ValidationError): + self.Assignment.create( + {"project_id": project.id, "role_id": role.id, "user_id": user.id} + ) + with self.assertRaises(ValidationError): + self.Assignment.create( + {"role_id": role.id, "user_id": user.id, "company_id": company_1.id} + ) + with self.assertRaises(ValidationError): + self.Assignment.create( + { + "company_id": self.company_id.id, + "role_id": role.id, + "user_id": user.id, + } + ) + + def test_multicompany_roles(self): + company_1 = self.Company.create({"name": "Company #1"}) + self.Role.create({"name": "Role", "company_id": company_1.id}) + + company_2 = self.Company.create({"name": "Company #2"}) + self.Role.create({"name": "Role", "company_id": company_2.id}) + + def test_unique_crosscompany_role(self): + self.Role.create({"name": "Role", "company_id": False}) + + with self.assertRaises(ValidationError): + self.Role.create({"name": "Role"}) + + def test_nonconflicting_crosscompany_role(self): + self.Role.create({"name": "Role"}) + + with self.assertRaises(ValidationError): + self.Role.create({"name": "Role", "company_id": False}) + + def test_child_role(self): + parent_role = self.Role.create({"name": "Parent Role"}) + child_role = self.Role.create( + {"name": "Child Role", "parent_id": parent_role.id} + ) + + self.assertTrue(child_role.complete_name, "Parent Role / Child Role") + + with self.assertRaises(UserError): + parent_role.parent_id = child_role + + child_role.active = False + parent_role.active = False + with self.assertRaises(ValidationError): + child_role.active = True + + def test_companywide_assignments_1(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role = self.Role.create({"name": "Role"}) + + self.Assignment.create({"role_id": role.id, "user_id": user.id}) + + with self.assertRaises(IntegrityError), mute_logger("odoo.sql_db"): + self.Assignment.create({"role_id": role.id, "user_id": user.id}) + + def test_companywide_assignments_2(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role_1 = self.Role.create({"name": "Role 1"}) + role_2 = self.Role.create({"name": "Role 2"}) + project = self.Project.create({"name": "Project"}) + + self.Assignment.create({"role_id": role_1.id, "user_id": user.id}) + + with self.assertRaises(ValidationError): + self.Assignment.create( + {"role_id": role_1.id, "user_id": user.id, "project_id": project.id} + ) + + self.Assignment.create({"role_id": role_2.id, "user_id": user.id}) + + def test_companywide_assignments_3(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role_1 = self.Role.create({"name": "Role 1"}) + role_2 = self.Role.create({"name": "Role 2"}) + + self.Assignment.create({"role_id": role_1.id, "user_id": user.id}) + + self.Assignment.create({"role_id": role_2.id, "user_id": user.id}) + + def test_crosscompany_assignments_1(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role = self.Role.create({"name": "Role", "company_id": False}) + + self.Assignment.create( + {"role_id": role.id, "user_id": user.id, "company_id": False} + ) + + with self.assertRaises(ValidationError): + self.Assignment.with_context( + company_id=self.company_id.id, + ).create({"role_id": role.id, "user_id": user.id}) + + def test_crosscompany_assignments_2(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role = self.Role.create({"name": "Role", "company_id": False}) + project = self.Project.create({"name": "Project"}) + + self.Assignment.create( + {"role_id": role.id, "user_id": user.id, "company_id": False} + ) + + with self.assertRaises(ValidationError): + self.Assignment.with_context( + company_id=self.company_id.id, + ).create({"role_id": role.id, "user_id": user.id, "project_id": project.id}) + + def test_crosscompany_assignments_3(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role_1 = self.Role.create({"name": "Role 1", "company_id": False}) + role_2 = self.Role.create({"name": "Role 2", "company_id": False}) + + self.Assignment.create( + {"role_id": role_1.id, "user_id": user.id, "company_id": False} + ) + + self.Assignment.with_context( + company_id=self.company_id.id, + ).create({"role_id": role_2.id, "user_id": user.id}) + + def test_no_project(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + self.Role.create({"name": "Role"}) + self.assertFalse(self.Role.get_available_roles(user, False)) + + def test_inherit_assignments(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role = self.Role.create({"name": "Role"}) + project = self.Project.create( + {"name": "Project", "limit_role_to_assignments": True} + ) + self.Assignment.create({"role_id": role.id, "user_id": user.id}) + + self.assertEqual(self.Role.get_available_roles(user, project).ids, role.ids) + + project.inherit_assignments = False + self.assertFalse(self.Role.get_available_roles(user, project)) + + def test_limit_role_to_assignments(self): + user = self.ResUsers.sudo().create( + { + "name": "User", + "login": "user", + "email": "user@example.com", + "company_id": self.company_id.id, + } + ) + role = self.Role.create({"name": "Role"}) + project = self.Project.create({"name": "Project"}) + + self.assertEqual(self.Role.get_available_roles(user, project).ids, role.ids) + + project.inherit_assignments = False + self.assertEqual(self.Role.get_available_roles(user, project).ids, role.ids) + + def test_defaults(self): + company = self.Company.create( + { + "name": "Company", + "project_inherit_assignments": False, + "project_limit_role_to_assignments": True, + } + ) + project = self.Project.create({"name": "Project", "company_id": company.id}) + self.Role.create({"name": "Role"}) + self.assertEqual(project.company_id.id, company.id) + self.assertEqual( + project.inherit_assignments, company.project_inherit_assignments + ) + self.assertEqual( + project.limit_role_to_assignments, company.project_limit_role_to_assignments + ) diff --git a/project_role/views/project_assignment.xml b/project_role/views/project_assignment.xml new file mode 100644 index 0000000..4d58448 --- /dev/null +++ b/project_role/views/project_assignment.xml @@ -0,0 +1,198 @@ + + + + + project.assignment.form + project.assignment + +
+
+ +
+ + + + + + + + + + +
+ + +
+ +
+ + + project.assignment.tree + project.assignment + + + + + + + + + + + project.assignment.pivot + project.assignment + + + + + + + + + + + project.assignment.kanban + project.assignment + + + + + + + + +
+
+
+ +
+
+
+ + + +
+
+ + + +
+
+ + + +
+
+
+
+
+
+
+
+
+ + project.assignment.search + project.assignment + + + + + + + + + + + + + + + + + + + + + + Project Assignments + project.assignment + tree,kanban,form,pivot,graph + + {'search_default_groupby_project': 1} + + + Assignments + project.assignment + kanban,tree,form,pivot,graph + + {'default_project_id': active_id} + [('project_id','=',active_id)] + + + diff --git a/project_role/views/project_project.xml b/project_role/views/project_project.xml new file mode 100644 index 0000000..9812fd4 --- /dev/null +++ b/project_role/views/project_project.xml @@ -0,0 +1,29 @@ + + + + + project.project.form + project.project + + +
+
+ + + + + + +
+
+
diff --git a/project_role/views/project_role.xml b/project_role/views/project_role.xml new file mode 100644 index 0000000..188e76c --- /dev/null +++ b/project_role/views/project_role.xml @@ -0,0 +1,67 @@ + + + + + project.role.view.tree + project.role + + + + + + + + + project.role.view.form + project.role + +
+ +
+ + + + + + + + + + + + + + + + project.role.search + project.role + + + + + + + + + Project Roles + project.role + tree,form + + + diff --git a/project_role/views/res_config_settings.xml b/project_role/views/res_config_settings.xml new file mode 100644 index 0000000..fb59d4c --- /dev/null +++ b/project_role/views/res_config_settings.xml @@ -0,0 +1,93 @@ + + + + + res.config.settings.view.form.project_role + res.config.settings + + + +
+

Roles & Assignments

+
+
+
+
+
+ Project Roles + +
+ Configure set of roles, available on projects. +
+
+
+
+
+
+
+
+
+
+
+ +
+
+
+
+
+
+ +
+
+
+
+
+
+
+
+
+
diff --git a/website_membership_registration/__manifest__.py b/website_membership_registration/__manifest__.py index 085489b..2dedf62 100644 --- a/website_membership_registration/__manifest__.py +++ b/website_membership_registration/__manifest__.py @@ -24,6 +24,7 @@ "data": [ "data/ir_cron_data.xml", "data/mail_template_data.xml", + "views/snippets/snippets.xml", "views/hr_applicant_view.xml", "views/hr_employee_view.xml", "views/membership_section_view.xml", @@ -37,6 +38,9 @@ "website_membership_registration/static/src/js/website_membership_registration.js", "website_membership_registration/static/src/scss/website_membership_registration.scss", ], + "website.assets_wysiwyg": [ + "website_membership_registration/static/src/js/website_membership_registration.editor.js", + ], }, "demo": [ "data/product_demo.xml", diff --git a/website_membership_registration/controllers/main.py b/website_membership_registration/controllers/main.py index 3ad151c..8bc2f10 100644 --- a/website_membership_registration/controllers/main.py +++ b/website_membership_registration/controllers/main.py @@ -1,5 +1,8 @@ +import base64 import re +from werkzeug.exceptions import NotFound + from odoo import _, fields, http from odoo.exceptions import ValidationError from odoo.http import request @@ -35,6 +38,37 @@ def _validate_membership_email(self, email): return email, email_valid, error_message + def _validate_membership_cv(self, cv): + cv_valid = True + error_message = "" + cv_file = cv + if cv: + if ( + not request.website.membership_registration_cv_file_formats_supported + == "*" + ): + for ( + file_format + ) in request.website.membership_registration_cv_file_formats_supported.split( + "," + ): + if not cv.filename.endswith(file_format): + cv_valid = cv_file = False + error_message = _( + "Only %s files are accepted.", + request.website.membership_registration_cv_file_formats_supported, + ) + break + if cv_valid: + cv_file = cv.stream.read() + size = cv.stream.tell() + if size > ( + request.website.membership_registration_max_cv_file_size * 1048576 + ): + cv_valid = cv_file = False + error_message = _("File is too big.") + return cv_file, cv_valid, error_message + def _validate_membership_phone(self, phone): phone_valid = True if (not phone or re.match(r"^\+?[\d]+$", phone)) else False error_message = "" @@ -52,10 +86,13 @@ def _validate_membership_name(self, name): return name, name_valid, error_message def _validate_membership_nickname(self, nickname): - error_message = "" - nickname_valid = nickname and all(c.isalnum() or c.isspace() for c in nickname) - if not nickname_valid: - error_message = _("Nickname is empty or invalid.") + error_message, nickname_valid = "", True + if nickname: + nickname_valid = nickname and all( + c.isalnum() or c.isspace() for c in nickname + ) + if not nickname_valid: + error_message = _("Nickname is invalid.") return nickname, nickname_valid, error_message def _validate_membership_product(self, product_id): @@ -158,12 +195,15 @@ def _get_error_message_list(self, validation_data, error_data): error_list.append(error_data["member_country_id"]) if not validation_data["member_state_id"]: error_list.append(error_data["member_state_id"]) + if not validation_data["member_cv"]: + error_list.append(error_data["member_cv"]) return error_list def _get_partner_and_validation_data(self, post): partner_data = {} validation_data = {} error_data = {} + partner_data["website_description"] = post.get("website_description", "") ( partner_data["member_email"], validation_data["member_email"], @@ -184,6 +224,11 @@ def _get_partner_and_validation_data(self, post): validation_data["member_phone"], error_data["member_phone"], ) = self._validate_membership_phone(post["member_phone"]) + ( + partner_data["member_cv"], + validation_data["member_cv"], + error_data["member_cv"], + ) = self._validate_membership_cv(post.get("member_cv", False)) ( partner_data["application_date"], validation_data["application_date"], @@ -274,6 +319,7 @@ def _get_new_member_vals_dict(self, partner_data): "website_id": request.website.id, "company_id": request.env.company.id, "membership_origin": "website_form", + "website_description": partner_data["website_description"], } def _set_partner_membership_section(self, partner, partner_data): @@ -376,48 +422,10 @@ def _get_membership_form_page_vals( if "section_%s_collaborate" % c.id in old_data["section_data"]: sections_collaborate_checked.update({c.id: True}) old_data.pop("section_data") - - if request.website.membership_registration_page_background_type == "color": - background_style = ( - "background-color: %s !important;" - % request.website.membership_registration_page_background_color - ) - elif ( - request.website.membership_registration_page_background_type - == "gradient_radial" - ): - background_style = ( - "background-image: radial-gradient(circle farthest-side at 50%% 50%%, %s 0%%, %s 100%%) !important" - % ( - request.website.membership_registration_page_background_gradient_start, - request.website.membership_registration_page_background_gradient_end, - ) - ) - elif ( - request.website.membership_registration_page_background_type - == "gradient_linear" - ): - background_style = ( - "background-image: linear-gradient(135deg, %s 0%%, %s 100%%) !important" - % ( - request.website.membership_registration_page_background_gradient_start, - request.website.membership_registration_page_background_gradient_end, - ) - ) - elif request.website.membership_registration_page_background_type == "image": - background_style = ( - "background-image: url(data:image/jpg;base64,%s)" - % request.website.membership_registration_page_background_image.decode( - "utf-8" - ) - ) - else: - background_style = "" section_style = request.website.membership_registration_page_section_style if not errors: errors = {} res = { - "background_style": background_style, "is_logged": is_logged, "member_name": "", "member_nickname": "", @@ -430,6 +438,7 @@ def _get_membership_form_page_vals( "member_city": "", "member_country_id": "", "member_state_id": "", + "website_description": "", "country_id": request.env["res.country"], "state_id": request.env["res.country.state"], "member_publish": False, @@ -553,7 +562,16 @@ def post_membership_registration_form(self, **post): else: partner.write(partner_vals) self._set_partner_membership_section(partner, partner_data) - + if partner_data.get("member_cv"): + request.env["ir.attachment"].sudo().create( + { + "name": post["member_cv"].filename, + "res_model": "res.partner", + "res_id": partner.id, + "datas": base64.b64encode(partner_data.get("member_cv")), + "mimetype": "application/pdf", + } + ) sale_order = partner.create_membership_sale_order( product, product.list_price ) @@ -653,3 +671,38 @@ def apply_for_membership_verify(self, partner_id, token, email): return request.render( "website_membership_registration.membership_registration_verify_success_page" ) + + @http.route(["/membership-registration/config/website"], type="json", auth="user") + def _change_membership_registration_website_config(self, **options): + if not request.env.user.has_group("website.group_website_restricted_editor"): + raise NotFound() + + current_website = request.env["website"].get_current_website() + # Restrict options we can write to. + writable_fields = { + "membership_registration_page_section_style", + "membership_registration_max_cv_file_size", + "membership_registration_cv_file_formats_supported", + } + # Default section layout to list. + if ( + "membership_registration_page_section_style" in options + and not options["membership_registration_page_section_style"] + ): + options["membership_registration_page_section_style"] = "list" + # Default max cv file size to 3. + if ( + "membership_registration_max_cv_file_size" in options + and not options["membership_registration_max_cv_file_size"] + ): + options["membership_registration_max_cv_file_size"] = 3 + # Default file format supported to '.pdf'. + if ( + "membership_registration_cv_file_formats_supported" in options + and not options["membership_registration_cv_file_formats_supported"] + ): + options["membership_registration_cv_file_formats_supported"] = ".pdf" + + write_vals = {k: v for k, v in options.items() if k in writable_fields} + if write_vals: + current_website.write(write_vals) diff --git a/website_membership_registration/controllers/portal.py b/website_membership_registration/controllers/portal.py index 0c1e4bc..3074646 100644 --- a/website_membership_registration/controllers/portal.py +++ b/website_membership_registration/controllers/portal.py @@ -1,9 +1,10 @@ +from odoo import _ from odoo.http import request, route from odoo.addons.portal.controllers.portal import CustomerPortal -class CustomerPortal(CustomerPortal): +class CustomerPortalMembership(CustomerPortal): CustomerPortal.OPTIONAL_BILLING_FIELDS += ["nickname", "website_published"] @route() @@ -18,3 +19,14 @@ def account(self, redirect=None, **post): else: post["website_published"] = True return super().account(redirect=redirect, **post) + + def details_form_validate(self, data, partner_creation=False): + error, error_message = super( + CustomerPortalMembership, self + ).details_form_validate(data, partner_creation=partner_creation) + if data.get("nickname") and not ( + all(c.isalnum() or c.isspace() for c in data.get("nickname")) + ): + error["nickname"] = "error" + error_message.append(_("Nickname is invalid.")) + return error, error_message diff --git a/website_membership_registration/i18n/nl.po b/website_membership_registration/i18n/nl.po index 2580dd1..d90f94f 100644 --- a/website_membership_registration/i18n/nl.po +++ b/website_membership_registration/i18n/nl.po @@ -455,8 +455,8 @@ msgstr "Bijnaam" #. odoo-python #: code:addons/website_membership_registration/controllers/main.py:0 #, python-format -msgid "Nickname is empty or invalid." -msgstr "Bijnaam is leeg of ongeldig." +msgid "Nickname is invalid." +msgstr "Bijnaam is ongeldig." #. module: website_membership_registration #. odoo-python diff --git a/website_membership_registration/models/res_config_settings.py b/website_membership_registration/models/res_config_settings.py index a00e91f..8a8c454 100644 --- a/website_membership_registration/models/res_config_settings.py +++ b/website_membership_registration/models/res_config_settings.py @@ -22,34 +22,17 @@ class ResConfigSetting(models.TransientModel): readonly=False, ) - membership_registration_page_background_type = fields.Selection( - related="website_id.membership_registration_page_background_type", - readonly=False, - string="Background Type", - ) - - membership_registration_page_background_color = fields.Char( - related="website_id.membership_registration_page_background_color", - readonly=False, - string="Color", - ) - membership_registration_page_background_gradient_start = fields.Char( - related="website_id.membership_registration_page_background_gradient_start", - readonly=False, - string="Gradient Color Start", - ) - membership_registration_page_background_gradient_end = fields.Char( - related="website_id.membership_registration_page_background_gradient_end", + membership_registration_page_section_style = fields.Selection( + related="website_id.membership_registration_page_section_style", readonly=False, - string="Gradient Color End", ) - membership_registration_page_background_image = fields.Binary( - related="website_id.membership_registration_page_background_image", + membership_registration_max_cv_file_size = fields.Integer( + related="website_id.membership_registration_max_cv_file_size", readonly=False, ) - membership_registration_page_section_style = fields.Selection( - related="website_id.membership_registration_page_section_style", + membership_registration_cv_file_formats_supported = fields.Char( + related="website_id.membership_registration_cv_file_formats_supported", readonly=False, ) diff --git a/website_membership_registration/models/res_partner.py b/website_membership_registration/models/res_partner.py index 928aed1..f4714b4 100644 --- a/website_membership_registration/models/res_partner.py +++ b/website_membership_registration/models/res_partner.py @@ -143,7 +143,11 @@ def cleanup_unverified_members(self): ("email_verification_token", "!=", False), ] ) - partners.unlink() + partners_to_unlink = partners + for partner in partners: + if partner.invoice_ids: + partners_to_unlink -= partner + partners_to_unlink.unlink() @api.model def _generate_email_verification_token(self, partner_id, email): diff --git a/website_membership_registration/models/website.py b/website_membership_registration/models/website.py index 33080c6..8625036 100644 --- a/website_membership_registration/models/website.py +++ b/website_membership_registration/models/website.py @@ -13,26 +13,6 @@ class Website(models.Model): string="Cleanup unverified members after (days)", default=7 ) - membership_registration_page_background_type = fields.Selection( - [ - ("color", "Color"), - ("gradient_linear", "Linear-Gradient"), - ("gradient_radial", "Radial-Gradient"), - ("image", "Image"), - ], - string="Background Type", - ) - - membership_registration_page_background_color = fields.Char(string="Color") - membership_registration_page_background_gradient_start = fields.Char( - string="Gradient Color Start" - ) - membership_registration_page_background_gradient_end = fields.Char( - string="Gradient Color End" - ) - - membership_registration_page_background_image = fields.Binary() - membership_job_id = fields.Many2one("hr.job") membership_registration_page_section_style = fields.Selection( @@ -43,3 +23,9 @@ class Website(models.Model): string="Section View", default="list", ) + + allow_adding_bio_for_membership_registration = fields.Boolean(default=False) + + membership_registration_max_cv_file_size = fields.Integer(default=3) + + membership_registration_cv_file_formats_supported = fields.Char(default=".pdf") diff --git a/website_membership_registration/static/src/js/website_membership_registration.editor.js b/website_membership_registration/static/src/js/website_membership_registration.editor.js new file mode 100644 index 0000000..43a22d6 --- /dev/null +++ b/website_membership_registration/static/src/js/website_membership_registration.editor.js @@ -0,0 +1,86 @@ +odoo.define('website_membership_registration.editor', function (require) { +'use strict'; + +var options = require('web_editor.snippets.options'); +const FILE_EXTENSIONS = ['.txt','.csv','.tsv','.jpg', '.jpeg', '.jpe', '.png', '.svg', '.gif','.pdf','.xls','.xlsx','.doc','.docx','.ppt','.pptx']; + +options.registry.WebsiteMembershipRegistrationPage = options.Class.extend({ + /** + * @override + */ + start: function () { + this.max_cv_file_size = parseInt(this.$target.closest('[data-max-cv-file-size]').data('max-cv-file-size'), 10); + this.cv_file_formats = this.$target.closest('[data-cv-file-formats]').data('cv-file-formats'); + this.section_style = this.$target.closest('[data-section-style]').data('section-style'); + return this._super.apply(this, arguments); + }, + + setSectionStyle: function (previewMode, widgetValue) { + this.section_style = widgetValue; + this._rpc({ + route: '/membership-registration/config/website', + params: { + 'membership_registration_page_section_style': this.section_style, + }, + }); + }, + setMaxCvFileSize: function (previewMode, widgetValue) { + const max_cv_file_size = parseInt(widgetValue, 10); + if (!max_cv_file_size || max_cv_file_size < 1) { + return false; + } + return this._rpc({ + route: '/membership-registration/config/website', + params: { + 'membership_registration_max_cv_file_size': max_cv_file_size, + }, + }); + }, + setFileFormats: function (previewMode, widgetValue) { + if (widgetValue.trim() === "*") { + this.cv_file_formats = widgetValue; + } + else{ + var supported_file_formats=""; + var file_formats = widgetValue.split(","); + for (let i = 0; i < file_formats.length; i++) { + var file_format = file_formats[i].trim().toLowerCase(); + if (FILE_EXTENSIONS.includes(file_format)) + { + supported_file_formats += (file_format +','); + } + } + this.cv_file_formats = supported_file_formats.replace(/,\s*$/, ""); + } + this._rpc({ + route: '/membership-registration/config/website', + params: { + 'membership_registration_cv_file_formats_supported': this.cv_file_formats, + }, + }); + }, + /** + * @override + */ + _computeWidgetState: function (methodName) { + switch (methodName) { + case 'setSectionStyle': { + return this.section_style; + } + case 'setMaxCvFileSize': { + return this.max_cv_file_size; + } + case 'setFileFormats': { + return this.cv_file_formats; + } + } + return this._super(...arguments); + }, + _computeWidgetVisibility: function (widgetName) { + if (widgetName === 'cv_options') { + return this.$target[0].querySelector('#div_cv') + } + return this._super.apply(this, arguments); + }, +}); +}); diff --git a/website_membership_registration/templates/website.xml b/website_membership_registration/templates/website.xml index 941ceb9..4637823 100644 --- a/website_membership_registration/templates/website.xml +++ b/website_membership_registration/templates/website.xml @@ -2,17 +2,17 @@ +