diff --git a/.copier-answers.yml b/.copier-answers.yml index 22cdf06d..78a4e6d8 100644 --- a/.copier-answers.yml +++ b/.copier-answers.yml @@ -1,12 +1,13 @@ # Do NOT update manually; changes here will be overwritten by Copier -_commit: v1.1.4 +_commit: v1.3.6 _src_path: gh:oca/oca-addons-repo-template +ci: Travis dependency_installation_mode: PIP generate_requirements_txt: true include_wkhtmltopdf: false odoo_version: 14.0 rebel_module_groups: [] -repo_description: "TODO: add repo description." +repo_description: 'TODO: add repo description.' repo_name: server-backend repo_slug: server-backend travis_apt_packages: [] diff --git a/.eslintrc.yml b/.eslintrc.yml index 88f2881b..d4cc423c 100644 --- a/.eslintrc.yml +++ b/.eslintrc.yml @@ -1,10 +1,17 @@ env: browser: true + es6: true # See https://github.com/OCA/odoo-community.org/issues/37#issuecomment-470686449 parserOptions: ecmaVersion: 2017 +overrides: + - files: + - "**/*.esm.js" + parserOptions: + sourceType: module + # Globals available in Odoo that shouldn't produce errorings globals: _: readonly @@ -14,7 +21,7 @@ globals: moment: readonly odoo: readonly openerp: readonly - Promise: readonly + owl: readonly # Styling is handled by Prettier, so we only need to enable AST rules; # see https://github.com/OCA/maintainer-quality-tools/pull/618#issuecomment-558576890 diff --git a/.github/workflows/pre-commit.yml b/.github/workflows/pre-commit.yml index 335381cb..80ab1a21 100644 --- a/.github/workflows/pre-commit.yml +++ b/.github/workflows/pre-commit.yml @@ -10,4 +10,11 @@ jobs: steps: - uses: actions/checkout@v2 - uses: actions/setup-python@v2 + with: + # The pylint-odoo version we use here does not support python 3.10 + # https://github.com/OCA/oca-addons-repo-template/issues/80 + # We also need to pin to an older version of python for older odoo versions + # where we are not using black > 21. Older black versions won't work with + # Python 3.9.8+, and we can't bump black without reformatting. + python-version: "3.9.7" - uses: pre-commit/action@v2.0.0 diff --git a/.github/workflows/stale.yml b/.github/workflows/stale.yml new file mode 100644 index 00000000..1693a125 --- /dev/null +++ b/.github/workflows/stale.yml @@ -0,0 +1,69 @@ +name: Mark stale issues and pull requests + +on: + schedule: + - cron: "0 12 * * 0" + +jobs: + stale: + runs-on: ubuntu-latest + steps: + - name: Stale PRs and issues policy + uses: actions/stale@v4 + with: + repo-token: ${{ secrets.GITHUB_TOKEN }} + # General settings. + ascending: true + remove-stale-when-updated: true + # Pull Requests settings. + # 120+30 day stale policy for PRs + # * Except PRs marked as "no stale" + days-before-pr-stale: 120 + days-before-pr-close: 30 + exempt-pr-labels: "no stale" + stale-pr-label: "stale" + stale-pr-message: > + There hasn't been any activity on this pull request in the past 4 months, so + it has been marked as stale and it will be closed automatically if no + further activity occurs in the next 30 days. + + If you want this PR to never become stale, please ask a PSC member to apply + the "no stale" label. + # Issues settings. + # 180+30 day stale policy for open issues + # * Except Issues marked as "no stale" + days-before-issue-stale: 180 + days-before-issue-close: 30 + exempt-issue-labels: "no stale,needs more information" + stale-issue-label: "stale" + stale-issue-message: > + There hasn't been any activity on this issue in the past 6 months, so it has + been marked as stale and it will be closed automatically if no further + activity occurs in the next 30 days. + + If you want this issue to never become stale, please ask a PSC member to + apply the "no stale" label. + + # 15+30 day stale policy for issues pending more information + # * Issues that are pending more information + # * Except Issues marked as "no stale" + - name: Needs more information stale issues policy + uses: actions/stale@v4 + with: + repo-token: ${{ secrets.GITHUB_TOKEN }} + ascending: true + only-labels: "needs more information" + exempt-issue-labels: "no stale" + days-before-stale: 15 + days-before-close: 30 + days-before-pr-stale: -1 + days-before-pr-close: -1 + remove-stale-when-updated: true + stale-issue-label: "stale" + stale-issue-message: > + This issue needs more information and there hasn't been any activity + recently, so it has been marked as stale and it will be closed automatically + if no further activity occurs in the next 30 days. + + If you think this is a mistake, please ask a PSC member to remove the "needs + more information" label. diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 36d8c867..0a69b9e2 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -5,7 +5,7 @@ exclude: | # Files and folders generated by bots, to avoid loops ^setup/|/static/description/index\.html$| # We don't want to mess with tool-generated files - .svg$|/tests/([^/]+/)?cassettes/| + .svg$|/tests/([^/]+/)?cassettes/|^.copier-answers.yml$|^.github/| # Maybe reactivate this when all README files include prettier ignore tags? ^README\.md$| # Library files can have extraneous formatting (even minimized) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md deleted file mode 100644 index 9ac71fee..00000000 --- a/CONTRIBUTING.md +++ /dev/null @@ -1,10 +0,0 @@ -# OCA Guidelines - -Please follow the official guide from the -[OCA Guidelines page](https://odoo-community.org/page/contributing). - -## Project Specific Guidelines - - - -This project does not have specific coding guidelines. diff --git a/README.md b/README.md index 39749ef6..6a8c3f95 100644 --- a/README.md +++ b/README.md @@ -17,11 +17,13 @@ TODO: add repo description. Available addons ---------------- -addon | version | summary ---- | --- | --- -[base_import_match](base_import_match/) | 14.0.1.0.0 | Try to avoid duplicates before importing -[base_user_role](base_user_role/) | 14.0.2.1.1 | User roles -[base_user_role_company](base_user_role_company/) | 14.0.1.0.0 | User roles by company +addon | version | maintainers | summary +--- | --- | --- | --- +[base_global_discount](base_global_discount/) | 14.0.1.0.0 | | Base Global Discount +[base_import_match](base_import_match/) | 14.0.1.0.0 | | Try to avoid duplicates before importing +[base_user_role](base_user_role/) | 14.0.2.2.0 | [![sebalix](https://github.com/sebalix.png?size=30px)](https://github.com/sebalix) [![jcdrubay](https://github.com/jcdrubay.png?size=30px)](https://github.com/jcdrubay) [![novawish](https://github.com/novawish.png?size=30px)](https://github.com/novawish) | User roles +[base_user_role_company](base_user_role_company/) | 14.0.1.1.0 | | User roles by company +[base_user_role_profile](base_user_role_profile/) | 14.0.1.0.0 | | User profiles [//]: # (end addons) diff --git a/base_global_discount/README.rst b/base_global_discount/README.rst new file mode 100644 index 00000000..59d12dec --- /dev/null +++ b/base_global_discount/README.rst @@ -0,0 +1,103 @@ +==================== +Base Global Discount +==================== + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! 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%2Fserver--backend-lightgray.png?logo=github + :target: https://github.com/OCA/server-backend/tree/14.0/base_global_discount + :alt: OCA/server-backend +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/server-backend-14-0/server-backend-14-0-base_global_discount + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/253/14.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +Base module to have global discounts applied to either sales or purchases. It +doesn't do much for itself, so account_global_discount or +purchase_global_discount should be installed to benefit from it. + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +To use this module, you need to: + +#. Go to *Settings > Users*, choose yours and set *Manage Global Discounts*. +#. Go to *Settings > Parameters > Global Discounts* +#. Choose the discount scope (sales or purchases). +#. You can also restrict it to a certain company if needed. + +Usage +===== + +You can assign global discounts to partners as well. You'll need the proper +permission (*Manage Global Discounts*): + +#. Go to a partner that is a company. +#. Go to the *Sales & Purchases* tab. +#. In section sale, you can set sale discounts. +#. In section purchase, you can set purchase discounts. + +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 +~~~~~~~ + +* Tecnativa + +Contributors +~~~~~~~~~~~~ + +* `Tecnativa `_ + + * Pedro M. Baeza + * David Vidal + * Carlos Dauden + * Rafael Blasco + * Ernesto Tejeda +* Omar Castiñeira + +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/server-backend `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/base_global_discount/__init__.py b/base_global_discount/__init__.py new file mode 100644 index 00000000..0650744f --- /dev/null +++ b/base_global_discount/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/base_global_discount/__manifest__.py b/base_global_discount/__manifest__.py new file mode 100644 index 00000000..e277717e --- /dev/null +++ b/base_global_discount/__manifest__.py @@ -0,0 +1,20 @@ +# Copyright 2019 Tecnativa S.L. - David Vidal +# Copyright 2020 Xtendoo - Manuel Calero +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +{ + "name": "Base Global Discount", + "version": "14.0.1.0.0", + "category": "Base", + "author": "Tecnativa, Odoo Community Association (OCA)", + "website": "https://github.com/OCA/server-backend", + "license": "AGPL-3", + "depends": ["product"], + "data": [ + "security/security.xml", + "security/ir.model.access.csv", + "views/global_discount_views.xml", + "views/res_partner_views.xml", + ], + "application": False, + "installable": True, +} diff --git a/base_global_discount/i18n/base_global_discount.pot b/base_global_discount/i18n/base_global_discount.pot new file mode 100644 index 00000000..868b6ac3 --- /dev/null +++ b/base_global_discount/i18n/base_global_discount.pot @@ -0,0 +1,141 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_global_discount +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__company_id +msgid "Company" +msgstr "" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_res_partner +msgid "Contact" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_uid +msgid "Created by" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_date +msgid "Created on" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount +msgid "Discount" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__name +msgid "Discount Name" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount_scope +msgid "Discount Scope" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__display_name +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__display_name +msgid "Display Name" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,help:base_global_discount.field_global_discount__sequence +msgid "Gives the order to apply discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_global_discount +msgid "Global Discount" +msgstr "" + +#. module: base_global_discount +#: model:ir.actions.act_window,name:base_global_discount.action_global_discount_tree +#: model:ir.ui.menu,name:base_global_discount.menu_global_discount +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_form +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_tree +msgid "Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__id +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__id +msgid "ID" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount____last_update +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner____last_update +msgid "Last Modified on" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_date +msgid "Last Updated on" +msgstr "" + +#. module: base_global_discount +#: model:res.groups,name:base_global_discount.group_global_discount +msgid "Manage Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Purchase Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids_readonly +msgid "Purchase Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__purchase +msgid "Purchases" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Sale Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids_readonly +msgid "Sale Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__sale +msgid "Sales" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__sequence +msgid "Sequence" +msgstr "" diff --git a/base_global_discount/i18n/es.po b/base_global_discount/i18n/es.po new file mode 100644 index 00000000..4d3bb2bf --- /dev/null +++ b/base_global_discount/i18n/es.po @@ -0,0 +1,141 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_global_discount +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 11.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2019-08-23 06:22+0000\n" +"PO-Revision-Date: 2019-08-23 06:22+0000\n" +"Last-Translator: <>\n" +"Language-Team: \n" +"Language: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__company_id +msgid "Company" +msgstr "Compañía" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_res_partner +msgid "Contact" +msgstr "Contacto" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_uid +msgid "Created by" +msgstr "Creado por" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_date +msgid "Created on" +msgstr "Creado el" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount +msgid "Discount" +msgstr "Descuento" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__name +msgid "Discount Name" +msgstr "Nombre del descuento" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount_scope +msgid "Discount Scope" +msgstr "Ámbito del descuento" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__display_name +msgid "Display Name" +msgstr "Nombre mostrado" + +#. module: base_global_discount +#: model:ir.model.fields,help:base_global_discount.field_global_discount__sequence +msgid "Gives the order to apply discounts" +msgstr "Orden en el que se aplicarán los descuentos" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_global_discount +msgid "Global Discount" +msgstr "Descuento Global" + +#. module: base_global_discount +#: model:ir.actions.act_window,name:base_global_discount.action_global_discount_tree +#: model:ir.ui.menu,name:base_global_discount.menu_global_discount +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_form +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_tree +msgid "Global Discounts" +msgstr "Descuentos Globales" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__id +msgid "ID" +msgstr "ID" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount____last_update +msgid "Last Modified on" +msgstr "Última Modificación en" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_uid +msgid "Last Updated by" +msgstr "Última Actualización por" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_date +msgid "Last Updated on" +msgstr "Última Actualización el" + +#. module: base_global_discount +#: model:res.groups,name:base_global_discount.group_global_discount +msgid "Manage Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Purchase Global Discounts" +msgstr "Descuentos globales de compra" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids_readonly +msgid "Purchase Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__purchase +msgid "Purchases" +msgstr "Compras" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Sale Global Discounts" +msgstr "Descuentos de venta globales" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids_readonly +msgid "Sale Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__sale +msgid "Sales" +msgstr "Ventas" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__sequence +msgid "Sequence" +msgstr "Secuencia" diff --git a/base_global_discount/i18n/nl_NL.po b/base_global_discount/i18n/nl_NL.po new file mode 100644 index 00000000..212098ff --- /dev/null +++ b/base_global_discount/i18n/nl_NL.po @@ -0,0 +1,141 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_global_discount +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 13.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2021-01-29 11:44+0000\n" +"Last-Translator: Cas Vissers \n" +"Language-Team: none\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" +"X-Generator: Weblate 4.3.2\n" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__company_id +msgid "Company" +msgstr "Bedrijf" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_res_partner +msgid "Contact" +msgstr "Contact" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_uid +msgid "Created by" +msgstr "Aangemaakt door" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_date +msgid "Created on" +msgstr "Aangemaakt op" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount +msgid "Discount" +msgstr "Korting" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__name +msgid "Discount Name" +msgstr "Kortingsnaam" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount_scope +msgid "Discount Scope" +msgstr "Kortingsbereik" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__display_name +msgid "Display Name" +msgstr "Schermnaam" + +#. module: base_global_discount +#: model:ir.model.fields,help:base_global_discount.field_global_discount__sequence +msgid "Gives the order to apply discounts" +msgstr "Geeft de opdracht om kortingen toe te passen" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_global_discount +msgid "Global Discount" +msgstr "Algemene korting" + +#. module: base_global_discount +#: model:ir.actions.act_window,name:base_global_discount.action_global_discount_tree +#: model:ir.ui.menu,name:base_global_discount.menu_global_discount +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_form +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_tree +msgid "Global Discounts" +msgstr "Algemene korting" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__id +msgid "ID" +msgstr "ID" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount____last_update +msgid "Last Modified on" +msgstr "Laatst gewijzigd op" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_uid +msgid "Last Updated by" +msgstr "Laatst bijgewerkt door" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_date +msgid "Last Updated on" +msgstr "Laatst bijgewerkt op" + +#. module: base_global_discount +#: model:res.groups,name:base_global_discount.group_global_discount +msgid "Manage Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Purchase Global Discounts" +msgstr "Algemene inkoopkorting" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids_readonly +msgid "Purchase Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__purchase +msgid "Purchases" +msgstr "Inkopen" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Sale Global Discounts" +msgstr "Algemene verkoopkorting" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids_readonly +msgid "Sale Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__sale +msgid "Sales" +msgstr "Verkoop" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__sequence +msgid "Sequence" +msgstr "Volgorde" diff --git a/base_global_discount/i18n/pt.po b/base_global_discount/i18n/pt.po new file mode 100644 index 00000000..73ed8a20 --- /dev/null +++ b/base_global_discount/i18n/pt.po @@ -0,0 +1,141 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_global_discount +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2020-09-17 13:00+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 3.10\n" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__company_id +msgid "Company" +msgstr "Empresa" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_res_partner +msgid "Contact" +msgstr "Contacto" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_uid +msgid "Created by" +msgstr "Criado por" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__create_date +msgid "Created on" +msgstr "Criado em" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount +msgid "Discount" +msgstr "Desconto" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__name +msgid "Discount Name" +msgstr "Nome do Desconto" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__discount_scope +msgid "Discount Scope" +msgstr "Âmbito do Desconto" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__display_name +msgid "Display Name" +msgstr "Nome a Apresentar" + +#. module: base_global_discount +#: model:ir.model.fields,help:base_global_discount.field_global_discount__sequence +msgid "Gives the order to apply discounts" +msgstr "Dá a ordem de aplicação de descontos" + +#. module: base_global_discount +#: model:ir.model,name:base_global_discount.model_global_discount +msgid "Global Discount" +msgstr "Desconto Global" + +#. module: base_global_discount +#: model:ir.actions.act_window,name:base_global_discount.action_global_discount_tree +#: model:ir.ui.menu,name:base_global_discount.menu_global_discount +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_form +#: model_terms:ir.ui.view,arch_db:base_global_discount.global_discount_view_tree +msgid "Global Discounts" +msgstr "Descontos Globais" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__id +msgid "ID" +msgstr "ID" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount____last_update +msgid "Last Modified on" +msgstr "Última Modificação Em" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_uid +msgid "Last Updated by" +msgstr "Atualizado pela última vez por" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__write_date +msgid "Last Updated on" +msgstr "Atualizado pela última vez em" + +#. module: base_global_discount +#: model:res.groups,name:base_global_discount.group_global_discount +msgid "Manage Global Discounts" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Purchase Global Discounts" +msgstr "Descontos Globais de Compras" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__supplier_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__supplier_global_discount_ids_readonly +msgid "Purchase Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__purchase +msgid "Purchases" +msgstr "Compras" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids +#: model_terms:ir.ui.view,arch_db:base_global_discount.res_partner_form_view +msgid "Sale Global Discounts" +msgstr "Descontos Globais de Vendas" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_res_partner__customer_global_discount_ids_readonly +#: model:ir.model.fields,field_description:base_global_discount.field_res_users__customer_global_discount_ids_readonly +msgid "Sale Global Discounts (readonly)" +msgstr "" + +#. module: base_global_discount +#: model:ir.model.fields.selection,name:base_global_discount.selection__global_discount__discount_scope__sale +msgid "Sales" +msgstr "Vendas" + +#. module: base_global_discount +#: model:ir.model.fields,field_description:base_global_discount.field_global_discount__sequence +msgid "Sequence" +msgstr "Sequência" diff --git a/base_global_discount/models/__init__.py b/base_global_discount/models/__init__.py new file mode 100644 index 00000000..8a1089ed --- /dev/null +++ b/base_global_discount/models/__init__.py @@ -0,0 +1,2 @@ +from . import global_discount +from . import res_partner diff --git a/base_global_discount/models/global_discount.py b/base_global_discount/models/global_discount.py new file mode 100644 index 00000000..3ef61c2a --- /dev/null +++ b/base_global_discount/models/global_discount.py @@ -0,0 +1,44 @@ +# Copyright 2019 Tecnativa - David Vidal +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). +from odoo import fields, models + + +class GlobalDiscount(models.Model): + _name = "global.discount" + _description = "Global Discount" + _order = "sequence, id desc" + + sequence = fields.Integer(help="Gives the order to apply discounts") + name = fields.Char(string="Discount Name", required=True) + discount = fields.Float(digits="Discount", required=True, default=0.0) + discount_scope = fields.Selection( + selection=[("sale", "Sales"), ("purchase", "Purchases")], + default="sale", + required="True", + string="Discount Scope", + ) + company_id = fields.Many2one( + comodel_name="res.company", + string="Company", + default=lambda self: self.env.company, + ) + + def name_get(self): + result = [] + for one in self: + result.append((one.id, "{} ({:.2f}%)".format(one.name, one.discount))) + return result + + def _get_global_discount_vals(self, base, **kwargs): + """Prepare the dict of values to create to obtain the discounted + amount + + :param float base: the amount to discount + :return: dict with the discounted amount + """ + self.ensure_one() + return { + "global_discount": self, + "base": base, + "base_discounted": base * (1 - (self.discount / 100)), + } diff --git a/base_global_discount/models/res_partner.py b/base_global_discount/models/res_partner.py new file mode 100644 index 00000000..e95e29ad --- /dev/null +++ b/base_global_discount/models/res_partner.py @@ -0,0 +1,38 @@ +# Copyright 2019 Tecnativa - David Vidal +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). +from odoo import fields, models + + +class ResPartner(models.Model): + _inherit = "res.partner" + + customer_global_discount_ids = fields.Many2many( + comodel_name="global.discount", + relation="customer_global_discount_rel", + column1="partner_id", + column2="global_discount_id", + string="Sale Global Discounts", + domain=[("discount_scope", "=", "sale")], + ) + supplier_global_discount_ids = fields.Many2many( + comodel_name="global.discount", + relation="supplier_global_discount_rel", + column1="partner_id", + column2="global_discount_id", + string="Purchase Global Discounts", + domain=[("discount_scope", "=", "purchase")], + ) + # HACK: Looks like UI doesn't behave well with Many2many fields and + # negative groups when the same field is shown. In this case, we want to + # show the readonly version to any not in the global discount group. + # TODO: Check in future versions if it's fixed + customer_global_discount_ids_readonly = fields.Many2many( + string="Sale Global Discounts (readonly)", + related="customer_global_discount_ids", + readonly=True, + ) + supplier_global_discount_ids_readonly = fields.Many2many( + string="Purchase Global Discounts (readonly)", + related="supplier_global_discount_ids", + readonly=True, + ) diff --git a/base_global_discount/readme/CONFIGURE.rst b/base_global_discount/readme/CONFIGURE.rst new file mode 100644 index 00000000..bb80f62d --- /dev/null +++ b/base_global_discount/readme/CONFIGURE.rst @@ -0,0 +1,6 @@ +To use this module, you need to: + +#. Go to *Settings > Users*, choose yours and set *Manage Global Discounts*. +#. Go to *Settings > Parameters > Global Discounts* +#. Choose the discount scope (sales or purchases). +#. You can also restrict it to a certain company if needed. diff --git a/base_global_discount/readme/CONTRIBUTORS.rst b/base_global_discount/readme/CONTRIBUTORS.rst new file mode 100644 index 00000000..c4649cea --- /dev/null +++ b/base_global_discount/readme/CONTRIBUTORS.rst @@ -0,0 +1,8 @@ +* `Tecnativa `_ + + * Pedro M. Baeza + * David Vidal + * Carlos Dauden + * Rafael Blasco + * Ernesto Tejeda +* Omar Castiñeira diff --git a/base_global_discount/readme/DESCRIPTION.rst b/base_global_discount/readme/DESCRIPTION.rst new file mode 100644 index 00000000..7006b993 --- /dev/null +++ b/base_global_discount/readme/DESCRIPTION.rst @@ -0,0 +1,3 @@ +Base module to have global discounts applied to either sales or purchases. It +doesn't do much for itself, so account_global_discount or +purchase_global_discount should be installed to benefit from it. diff --git a/base_global_discount/readme/USAGE.rst b/base_global_discount/readme/USAGE.rst new file mode 100644 index 00000000..079332b7 --- /dev/null +++ b/base_global_discount/readme/USAGE.rst @@ -0,0 +1,7 @@ +You can assign global discounts to partners as well. You'll need the proper +permission (*Manage Global Discounts*): + +#. Go to a partner that is a company. +#. Go to the *Sales & Purchases* tab. +#. In section sale, you can set sale discounts. +#. In section purchase, you can set purchase discounts. diff --git a/base_global_discount/security/ir.model.access.csv b/base_global_discount/security/ir.model.access.csv new file mode 100644 index 00000000..e6e0d9fa --- /dev/null +++ b/base_global_discount/security/ir.model.access.csv @@ -0,0 +1,3 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_global_discount_user,Global Discount Users,model_global_discount,base.group_user,1,0,0,0 +access_global_discount_manager,Global Discount Manager,model_global_discount,base_global_discount.group_global_discount,1,1,1,1 diff --git a/base_global_discount/security/security.xml b/base_global_discount/security/security.xml new file mode 100644 index 00000000..234c7c0e --- /dev/null +++ b/base_global_discount/security/security.xml @@ -0,0 +1,20 @@ + + + + + Global Discount multi-company + + ['|',('company_id','=',False),('company_id', 'in', company_ids)] + + + + + + + Manage Global Discounts + + + diff --git a/base_global_discount/static/description/icon.png b/base_global_discount/static/description/icon.png new file mode 100644 index 00000000..3a0328b5 Binary files /dev/null and b/base_global_discount/static/description/icon.png differ diff --git a/base_global_discount/static/description/index.html b/base_global_discount/static/description/index.html new file mode 100644 index 00000000..27f06742 --- /dev/null +++ b/base_global_discount/static/description/index.html @@ -0,0 +1,124 @@ +
+
+
+

Module name

+

This module was written to extend the functionality of ... to support ... and allow you to ...

+
+
+
+ +
+
+
+

Installation

+
+
+

To install this module, you need to: +

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Configuration

+
+
+

To configure this module, you need to: +

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Usage

+
+
+

To use this module, you need to: +

    +
  • ...
  • +
+

+

For further information, please visit: +

+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Known issues / Roadmap

+
+
+

+

    +
  • ...
  • +
+

+
+
+
+ + + +
+
+
+
+ +
+
+
+

Credits

+
+
+

Contributors

+ +
+
+

Maintainer

+

+ This module is maintained by the OCA.
+ 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.
+ To contribute to this module, please visit http://odoo-community.org.
+ +

+
+
+
diff --git a/base_global_discount/tests/__init__.py b/base_global_discount/tests/__init__.py new file mode 100644 index 00000000..e9199cd7 --- /dev/null +++ b/base_global_discount/tests/__init__.py @@ -0,0 +1 @@ +from . import test_global_discount diff --git a/base_global_discount/tests/test_global_discount.py b/base_global_discount/tests/test_global_discount.py new file mode 100644 index 00000000..47ddd834 --- /dev/null +++ b/base_global_discount/tests/test_global_discount.py @@ -0,0 +1,29 @@ +# Copyright 2019 Tecnativa - David Vidal +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo.tests import common + + +class TestGlobalDiscount(common.SavepointCase): + @classmethod + def setUpClass(cls): + super().setUpClass() + cls.global_discount_obj = cls.env["global.discount"] + cls.global_discount_1 = cls.global_discount_obj.create( + {"name": "Test Discount 1", "discount_scope": "sale", "discount": 20} + ) + cls.global_discount_2 = cls.global_discount_obj.create( + {"name": "Test Discount 2", "discount_scope": "sale", "discount": 30} + ) + + def test_01_global_discounts(self): + """Chain two discounts of different types""" + discount_vals = self.global_discount_1._get_global_discount_vals(100.0) + self.assertAlmostEqual(discount_vals["base_discounted"], 80.0) + discount_vals = self.global_discount_2._get_global_discount_vals( + discount_vals["base_discounted"] + ) + self.assertAlmostEqual(discount_vals["base_discounted"], 56.0) + + def test_02_display_name(self): + """Test that the name is computed fine""" + self.assertTrue("%)" in self.global_discount_1.display_name) diff --git a/base_global_discount/views/global_discount_views.xml b/base_global_discount/views/global_discount_views.xml new file mode 100644 index 00000000..fd22e925 --- /dev/null +++ b/base_global_discount/views/global_discount_views.xml @@ -0,0 +1,47 @@ + + + + + global.discount + + + + + + + + + + + + global.discount + +
+ + + + + + + + + +
+
+
+ + Global Discounts + ir.actions.act_window + global.discount + tree,form + + +
diff --git a/base_global_discount/views/res_partner_views.xml b/base_global_discount/views/res_partner_views.xml new file mode 100644 index 00000000..95d49ee2 --- /dev/null +++ b/base_global_discount/views/res_partner_views.xml @@ -0,0 +1,43 @@ + + + + + res.partner + + + + + + + + + + + + + diff --git a/base_import_match/i18n/vi_VN.po b/base_import_match/i18n/vi_VN.po index 0aba310d..8ee56f68 100644 --- a/base_import_match/i18n/vi_VN.po +++ b/base_import_match/i18n/vi_VN.po @@ -9,25 +9,26 @@ msgstr "" "Project-Id-Version: Odoo Server 9.0c\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2016-12-23 21:53+0000\n" -"PO-Revision-Date: 2016-12-23 21:53+0000\n" -"Last-Translator: OCA Transbot , 2016\n" -"Language-Team: Vietnamese (Viet Nam) (https://www.transifex.com/oca/" -"teams/23907/vi_VN/)\n" +"PO-Revision-Date: 2021-09-25 14:34+0000\n" +"Last-Translator: Mi Di \n" +"Language-Team: Vietnamese (Viet Nam) (https://www.transifex.com/oca/teams/" +"23907/vi_VN/)\n" "Language: vi_VN\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.3.2\n" #. module: base_import_match #: model:ir.model,name:base_import_match.model_base msgid "Base" -msgstr "" +msgstr "Cơ sở (Base)" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__conditional msgid "Conditional" -msgstr "" +msgstr "Điều kiện" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__create_uid @@ -44,53 +45,54 @@ msgstr "Tạo vào" #. module: base_import_match #: model:ir.model,name:base_import_match.model_base_import_match msgid "Deduplicate settings prior to CSV imports." -msgstr "" +msgstr "Thiết lập các quy tắc chống trùng lặp dữ liệu trước khi import CSV." #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__display_name #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__display_name msgid "Display Name" -msgstr "" +msgstr "Tên hiển thị" #. module: base_import_match #: model:ir.model.fields,help:base_import_match.field_base_import_match_field__conditional msgid "Enable if you want to use this field only in some conditions." msgstr "" +"Kích hoạt nếu bạn muốn sử dụng trường thông tin này trong một số điều kiện." #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__field_id msgid "Field" -msgstr "" +msgstr "Trường thông tin" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__name msgid "Field Name" -msgstr "" +msgstr "Tên trường thông tin" #. module: base_import_match #: model:ir.model,name:base_import_match.model_base_import_match_field msgid "Field import match definition" -msgstr "" +msgstr "Trường thông tin được import khớp với phần định nghĩa" #. module: base_import_match #: model:ir.model.fields,help:base_import_match.field_base_import_match_field__field_id msgid "Field that will be part of an unique key." -msgstr "" +msgstr "Trường thông tin thuộc một phần của unique key." #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__field_ids msgid "Fields" -msgstr "" +msgstr "Các trường thông tin" #. module: base_import_match #: model:ir.model.fields,help:base_import_match.field_base_import_match__field_ids msgid "Fields that will define an unique key." -msgstr "" +msgstr "Các trường thông tin sẽ định nghĩa ra một unique key." #. module: base_import_match #: model_terms:ir.ui.view,arch_db:base_import_match.match_search_view msgid "Group By" -msgstr "" +msgstr "Quy hoạch theo nhóm" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__id @@ -106,6 +108,10 @@ msgid "" "comparison is case-sensitive so if you set 'True', it will NOT match '1' nor " "'true', only EXACTLY 'True'." msgstr "" +"Nếu giá trị import không phải là giá trị này, toàn bộ luật so khớp sẽ bị " +"discard. Bạn cần lưu ý, dữ liệu này luôn được coi là string, việc so sánh " +"chúng có liên quan đến chữ viết hoa và viết thường. Do đó, nếu bạn đặt giá " +"trị là 'True', nó sẽ không match được với giá trị '1' hoặc 'true'." #. module: base_import_match #: model:ir.actions.act_window,name:base_import_match.match_action @@ -114,24 +120,24 @@ msgstr "" #: model_terms:ir.ui.view,arch_db:base_import_match.match_search_view #: model_terms:ir.ui.view,arch_db:base_import_match.match_tree_view msgid "Import Match" -msgstr "" +msgstr "Dữ liệu import khớp" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__imported_value msgid "Imported Value" -msgstr "" +msgstr "Giá trị đã được import" #. module: base_import_match #: model:ir.model.fields,help:base_import_match.field_base_import_match__model_id #: model:ir.model.fields,help:base_import_match.field_base_import_match_field__model_id msgid "In this model you will apply the match." -msgstr "" +msgstr "Trong model này, bạn sẽ áp dụng quy tắc so khớp (match)." #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match____last_update #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field____last_update msgid "Last Modified on" -msgstr "" +msgstr "Chỉnh sửa lần cuối vào" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__write_uid @@ -148,19 +154,19 @@ msgstr "Cập nhật lần cuối vào" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__match_id msgid "Match" -msgstr "" +msgstr "So khớp (match)" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__model_id #: model:ir.model.fields,field_description:base_import_match.field_base_import_match_field__model_id #: model_terms:ir.ui.view,arch_db:base_import_match.match_search_view msgid "Model" -msgstr "" +msgstr "Mô hình (model)" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__model_name msgid "Model name" -msgstr "" +msgstr "Tên mô hình (model)" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__name @@ -170,4 +176,4 @@ msgstr "Tên" #. module: base_import_match #: model:ir.model.fields,field_description:base_import_match.field_base_import_match__sequence msgid "Sequence" -msgstr "" +msgstr "Phân đoạn (sequence)" diff --git a/base_user_role/__manifest__.py b/base_user_role/__manifest__.py index 0caa83ae..86c235ab 100644 --- a/base_user_role/__manifest__.py +++ b/base_user_role/__manifest__.py @@ -4,7 +4,7 @@ { "name": "User roles", - "version": "14.0.2.1.1", + "version": "14.0.2.2.0", "category": "Tools", "author": "ABF OSIELL, Odoo Community Association (OCA)", "license": "LGPL-3", diff --git a/base_user_role/i18n/am.po b/base_user_role/i18n/am.po index 64efddeb..196f30f0 100644 --- a/base_user_role/i18n/am.po +++ b/base_user_role/i18n/am.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/ar.po b/base_user_role/i18n/ar.po index 21ad21be..fef3e1fe 100644 --- a/base_user_role/i18n/ar.po +++ b/base_user_role/i18n/ar.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/base_user_role.pot b/base_user_role/i18n/base_user_role.pot index 9212a7ed..9b827406 100644 --- a/base_user_role/i18n/base_user_role.pot +++ b/base_user_role/i18n/base_user_role.pot @@ -48,6 +48,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -105,7 +110,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/bg.po b/base_user_role/i18n/bg.po index 04fa3b45..e4bdec9f 100644 --- a/base_user_role/i18n/bg.po +++ b/base_user_role/i18n/bg.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/bs.po b/base_user_role/i18n/bs.po index c0a190c1..22b09e33 100644 --- a/base_user_role/i18n/bs.po +++ b/base_user_role/i18n/bs.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/ca.po b/base_user_role/i18n/ca.po index 452f9c8a..05387c6a 100644 --- a/base_user_role/i18n/ca.po +++ b/base_user_role/i18n/ca.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/cs.po b/base_user_role/i18n/cs.po index 13bbbf7a..d5962f1c 100644 --- a/base_user_role/i18n/cs.po +++ b/base_user_role/i18n/cs.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/da.po b/base_user_role/i18n/da.po index 079c2c55..5cc3d9d4 100644 --- a/base_user_role/i18n/da.po +++ b/base_user_role/i18n/da.po @@ -56,6 +56,11 @@ msgstr "Tilhørende gruppe" msgid "Color Index" msgstr "Farve indeks" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Kommentar" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -115,7 +120,6 @@ msgid "Inherits" msgstr "Arver" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -239,9 +243,6 @@ msgstr "Bruger af denne gruppe arver automatisk disse grupper" msgid "Views" msgstr "Oversigter" -#~ msgid "Comment" -#~ msgstr "Kommentar" - #~ msgid "If checked, this group is usable as a portal." #~ msgstr "Hvis slået til kan denne gruppe anvendes som portal." diff --git a/base_user_role/i18n/de.po b/base_user_role/i18n/de.po index 150eee93..17f7023e 100644 --- a/base_user_role/i18n/de.po +++ b/base_user_role/i18n/de.po @@ -56,6 +56,11 @@ msgstr "Zugewiesene Gruppe" msgid "Color Index" msgstr "Farbindex" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Bemerkung" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -113,7 +118,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -236,6 +240,3 @@ msgstr "" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Ansichten" - -#~ msgid "Comment" -#~ msgstr "Bemerkung" diff --git a/base_user_role/i18n/el_GR.po b/base_user_role/i18n/el_GR.po index 29314dc7..2f8bbadd 100644 --- a/base_user_role/i18n/el_GR.po +++ b/base_user_role/i18n/el_GR.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/en_GB.po b/base_user_role/i18n/en_GB.po index 8f00ae46..0a3d3509 100644 --- a/base_user_role/i18n/en_GB.po +++ b/base_user_role/i18n/en_GB.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es.po b/base_user_role/i18n/es.po index e0e81d8b..432c5647 100644 --- a/base_user_role/i18n/es.po +++ b/base_user_role/i18n/es.po @@ -57,6 +57,11 @@ msgstr "Categoría del grupo asociado" msgid "Color Index" msgstr "Índice Color" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Comentarios" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -116,7 +121,6 @@ msgid "Inherits" msgstr "Heredados" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "Notas internas" @@ -239,6 +243,3 @@ msgstr "Los usuarios de este grupo automáticamente heredan esos grupos" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Vistas" - -#~ msgid "Comment" -#~ msgstr "Comentarios" diff --git a/base_user_role/i18n/es_AR.po b/base_user_role/i18n/es_AR.po index 4d84f2db..93d60349 100644 --- a/base_user_role/i18n/es_AR.po +++ b/base_user_role/i18n/es_AR.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_CL.po b/base_user_role/i18n/es_CL.po index 8236229e..c3c00227 100644 --- a/base_user_role/i18n/es_CL.po +++ b/base_user_role/i18n/es_CL.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_CO.po b/base_user_role/i18n/es_CO.po index 4ce3c103..d8a81429 100644 --- a/base_user_role/i18n/es_CO.po +++ b/base_user_role/i18n/es_CO.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_CR.po b/base_user_role/i18n/es_CR.po index edd03556..1c2c52a5 100644 --- a/base_user_role/i18n/es_CR.po +++ b/base_user_role/i18n/es_CR.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_DO.po b/base_user_role/i18n/es_DO.po index e3fc96c6..2c10139a 100644 --- a/base_user_role/i18n/es_DO.po +++ b/base_user_role/i18n/es_DO.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_EC.po b/base_user_role/i18n/es_EC.po index 71e66fcf..3d776aeb 100644 --- a/base_user_role/i18n/es_EC.po +++ b/base_user_role/i18n/es_EC.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_ES.po b/base_user_role/i18n/es_ES.po index 56dc177a..990ede9c 100644 --- a/base_user_role/i18n/es_ES.po +++ b/base_user_role/i18n/es_ES.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_MX.po b/base_user_role/i18n/es_MX.po index e57df238..7b529bde 100644 --- a/base_user_role/i18n/es_MX.po +++ b/base_user_role/i18n/es_MX.po @@ -55,6 +55,11 @@ msgstr "Categoría del grupo asociado" msgid "Color Index" msgstr "Indice de color" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Comentario" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -114,7 +119,6 @@ msgid "Inherits" msgstr "Hereda" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -242,6 +246,3 @@ msgstr "Vistas" #~ msgid "User \"{}\" does not have access to the company \"{}\"" #~ msgstr "El usuario \"{}\" no tiene acceso a la empresa \"{}\"" - -#~ msgid "Comment" -#~ msgstr "Comentario" diff --git a/base_user_role/i18n/es_PE.po b/base_user_role/i18n/es_PE.po index 90e197a9..379be09f 100644 --- a/base_user_role/i18n/es_PE.po +++ b/base_user_role/i18n/es_PE.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_PY.po b/base_user_role/i18n/es_PY.po index b8be3f37..45196dcc 100644 --- a/base_user_role/i18n/es_PY.po +++ b/base_user_role/i18n/es_PY.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/es_VE.po b/base_user_role/i18n/es_VE.po index 912893a8..afba3365 100644 --- a/base_user_role/i18n/es_VE.po +++ b/base_user_role/i18n/es_VE.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/et.po b/base_user_role/i18n/et.po index a0e233cf..4053c4cc 100644 --- a/base_user_role/i18n/et.po +++ b/base_user_role/i18n/et.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/eu.po b/base_user_role/i18n/eu.po index 7860c756..a150e9cc 100644 --- a/base_user_role/i18n/eu.po +++ b/base_user_role/i18n/eu.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/fa.po b/base_user_role/i18n/fa.po index 39b733b5..5e797720 100644 --- a/base_user_role/i18n/fa.po +++ b/base_user_role/i18n/fa.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/fi.po b/base_user_role/i18n/fi.po index c3fd8183..a6e48b72 100644 --- a/base_user_role/i18n/fi.po +++ b/base_user_role/i18n/fi.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/fr.po b/base_user_role/i18n/fr.po index 74a0d61d..5ac68fb3 100644 --- a/base_user_role/i18n/fr.po +++ b/base_user_role/i18n/fr.po @@ -55,6 +55,11 @@ msgstr "Catégorie du groupe associé" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Comment" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "Inherits" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -235,6 +239,3 @@ msgstr "Users of this group automatically inherit those groups" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Vues" - -#~ msgid "Comment" -#~ msgstr "Comment" diff --git a/base_user_role/i18n/fr_CA.po b/base_user_role/i18n/fr_CA.po index 3230b00e..3e1b2cc7 100644 --- a/base_user_role/i18n/fr_CA.po +++ b/base_user_role/i18n/fr_CA.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/fr_CH.po b/base_user_role/i18n/fr_CH.po index 5055094e..e2694772 100644 --- a/base_user_role/i18n/fr_CH.po +++ b/base_user_role/i18n/fr_CH.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/fr_FR.po b/base_user_role/i18n/fr_FR.po index f63a9272..fe3479d5 100644 --- a/base_user_role/i18n/fr_FR.po +++ b/base_user_role/i18n/fr_FR.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/gl.po b/base_user_role/i18n/gl.po index c7e2a3b2..0dcdb9a2 100644 --- a/base_user_role/i18n/gl.po +++ b/base_user_role/i18n/gl.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/gl_ES.po b/base_user_role/i18n/gl_ES.po index f3d2469c..a2b071ac 100644 --- a/base_user_role/i18n/gl_ES.po +++ b/base_user_role/i18n/gl_ES.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/he.po b/base_user_role/i18n/he.po index 70c1b208..eb9a989f 100644 --- a/base_user_role/i18n/he.po +++ b/base_user_role/i18n/he.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/hr.po b/base_user_role/i18n/hr.po index 73ddeffe..2806e598 100644 --- a/base_user_role/i18n/hr.po +++ b/base_user_role/i18n/hr.po @@ -57,6 +57,11 @@ msgstr "Pridružena grupa" msgid "Color Index" msgstr "Index boje" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Komentar" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -116,7 +121,6 @@ msgid "Inherits" msgstr "Nasljeđuje" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -240,6 +244,3 @@ msgstr "Korisnici ove grupe automatski nasljeđuju ove grupe" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Pregled" - -#~ msgid "Comment" -#~ msgstr "Komentar" diff --git a/base_user_role/i18n/hr_HR.po b/base_user_role/i18n/hr_HR.po index 658af8c1..47817682 100644 --- a/base_user_role/i18n/hr_HR.po +++ b/base_user_role/i18n/hr_HR.po @@ -56,6 +56,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -113,7 +118,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/hu.po b/base_user_role/i18n/hu.po index 8dccd68b..0ffbc1e2 100644 --- a/base_user_role/i18n/hu.po +++ b/base_user_role/i18n/hu.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/id.po b/base_user_role/i18n/id.po index b27490ea..2d5ab788 100644 --- a/base_user_role/i18n/id.po +++ b/base_user_role/i18n/id.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/it.po b/base_user_role/i18n/it.po index d8c759d7..9885b274 100644 --- a/base_user_role/i18n/it.po +++ b/base_user_role/i18n/it.po @@ -12,49 +12,55 @@ msgstr "" "Project-Id-Version: Odoo Server 10.0c\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2016-12-17 02:07+0000\n" -"PO-Revision-Date: 2016-12-17 02:07+0000\n" -"Last-Translator: Nicola Malcontenti , 2016\n" +"PO-Revision-Date: 2022-02-15 19:16+0000\n" +"Last-Translator: Riccardo Bellanova \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" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.3.2\n" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__model_access msgid "Access Controls" -msgstr "" +msgstr "Controlli di accesso" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__menu_access msgid "Access Menu" -msgstr "" +msgstr "Menu d'accesso" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__category_id msgid "Application" -msgstr "" +msgstr "Applicazione" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__group_category_id msgid "Associated category" -msgstr "" +msgstr "Categoria associata" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__group_id msgid "Associated group" -msgstr "" +msgstr "Gruppo associato" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__group_category_id msgid "Associated group's category" -msgstr "" +msgstr "Categoria del gruppo associato" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__color msgid "Color Index" -msgstr "" +msgstr "Indice del colore" + +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Commento" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid @@ -88,12 +94,14 @@ msgstr "Da" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__full_name msgid "Group Name" -msgstr "" +msgstr "Nome del gruppo" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__share msgid "Group created to set access rights for sharing data with some users." msgstr "" +"Gruppo creato per impostare i diritti di accesso per la condivisione dei " +"dati con alcuni utenti." #. module: base_user_role #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form @@ -110,13 +118,12 @@ msgstr "ID" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__implied_ids msgid "Inherits" -msgstr "" +msgstr "Eredita" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" -msgstr "" +msgstr "Note interne" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users____last_update @@ -129,13 +136,13 @@ msgstr "Ultima modifica il" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__write_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__write_uid msgid "Last Updated by" -msgstr "Last Updated by" +msgstr "Ultimo aggiornamento da" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__write_date #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__write_date msgid "Last Updated on" -msgstr "Last Updated on" +msgstr "Ultimo aggiornamento il" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__name @@ -145,13 +152,13 @@ msgstr "Nome" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__role_id msgid "Role" -msgstr "" +msgstr "Ruolo" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users__role_line_ids #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__line_ids msgid "Role lines" -msgstr "" +msgstr "Righe del ruolo" #. module: base_user_role #: model:ir.actions.act_window,name:base_user_role.action_res_users_role_tree @@ -160,22 +167,22 @@ msgstr "" #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_form_inherit #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_search msgid "Roles" -msgstr "" +msgstr "Ruoli" #. module: base_user_role #: model:ir.model.constraint,message:base_user_role.constraint_res_users_role_line_user_role_uniq msgid "Roles can be assigned to a user only once at a time" -msgstr "" +msgstr "I ruoli possono essere assegnati all'utente solo uno alla volta" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__rule_groups msgid "Rules" -msgstr "" +msgstr "Ruoli" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__share msgid "Share Group" -msgstr "" +msgstr "Gruppo per la condivisione dei dati" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__date_to @@ -185,14 +192,14 @@ msgstr "A" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__trans_implied_ids msgid "Transitively inherits" -msgstr "" +msgstr "Eredita transitivamente" #. module: base_user_role #: model:ir.actions.server,name:base_user_role.cron_update_users_ir_actions_server #: model:ir.cron,cron_name:base_user_role.cron_update_users #: model:ir.cron,name:base_user_role.cron_update_users msgid "Update user roles" -msgstr "" +msgstr "Aggiorna i ruoli dell'utente" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__user_id @@ -202,12 +209,12 @@ msgstr "Utente" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users_role msgid "User role" -msgstr "" +msgstr "Ruolo utente" #. module: base_user_role #: model:ir.module.category,name:base_user_role.ir_module_category_role msgid "User roles" -msgstr "" +msgstr "Ruoli utente" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users @@ -219,23 +226,19 @@ msgstr "Utenti" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users_role_line msgid "Users associated to a role" -msgstr "" +msgstr "Utenti associati al ruolo" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__user_ids -#, fuzzy msgid "Users list" -msgstr "Utenti" +msgstr "Lista utenti" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__implied_ids msgid "Users of this group automatically inherit those groups" -msgstr "" +msgstr "Gli utenti di questo gruppo ereditano automaticamente quei gruppi" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Viste" - -#~ msgid "Comment" -#~ msgstr "Coomento" diff --git a/base_user_role/i18n/ja.po b/base_user_role/i18n/ja.po index e6c276db..e35d7b40 100644 --- a/base_user_role/i18n/ja.po +++ b/base_user_role/i18n/ja.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/ko.po b/base_user_role/i18n/ko.po index 0915193d..7d1765b5 100644 --- a/base_user_role/i18n/ko.po +++ b/base_user_role/i18n/ko.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/lt.po b/base_user_role/i18n/lt.po index 8c91f45e..bba3dd88 100644 --- a/base_user_role/i18n/lt.po +++ b/base_user_role/i18n/lt.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/lt_LT.po b/base_user_role/i18n/lt_LT.po index 8c26f8eb..bdbd83e4 100644 --- a/base_user_role/i18n/lt_LT.po +++ b/base_user_role/i18n/lt_LT.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/lv.po b/base_user_role/i18n/lv.po index 655b271a..9f79b4fc 100644 --- a/base_user_role/i18n/lv.po +++ b/base_user_role/i18n/lv.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/mk.po b/base_user_role/i18n/mk.po index 97daefc4..9d0cb253 100644 --- a/base_user_role/i18n/mk.po +++ b/base_user_role/i18n/mk.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/mn.po b/base_user_role/i18n/mn.po index d35b362f..d9e3e0fe 100644 --- a/base_user_role/i18n/mn.po +++ b/base_user_role/i18n/mn.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/nb.po b/base_user_role/i18n/nb.po index 69b6e2e5..b31c9089 100644 --- a/base_user_role/i18n/nb.po +++ b/base_user_role/i18n/nb.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/nb_NO.po b/base_user_role/i18n/nb_NO.po index 17fce83e..ef0ce4f8 100644 --- a/base_user_role/i18n/nb_NO.po +++ b/base_user_role/i18n/nb_NO.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/nl.po b/base_user_role/i18n/nl.po index d935db1d..af0e6ed4 100644 --- a/base_user_role/i18n/nl.po +++ b/base_user_role/i18n/nl.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Opmerking" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -234,6 +238,3 @@ msgstr "" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "" - -#~ msgid "Comment" -#~ msgstr "Opmerking" diff --git a/base_user_role/i18n/nl_BE.po b/base_user_role/i18n/nl_BE.po index d83c6696..18bd2298 100644 --- a/base_user_role/i18n/nl_BE.po +++ b/base_user_role/i18n/nl_BE.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/nl_NL.po b/base_user_role/i18n/nl_NL.po index dd4483a8..d91f8e37 100644 --- a/base_user_role/i18n/nl_NL.po +++ b/base_user_role/i18n/nl_NL.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "Kleurindex" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Commentaar" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -234,6 +238,3 @@ msgstr "" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "" - -#~ msgid "Comment" -#~ msgstr "Commentaar" diff --git a/base_user_role/i18n/pl.po b/base_user_role/i18n/pl.po index 67b8f37b..3a8f1cb4 100644 --- a/base_user_role/i18n/pl.po +++ b/base_user_role/i18n/pl.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/pt.po b/base_user_role/i18n/pt.po index e86466f7..21e6283a 100644 --- a/base_user_role/i18n/pt.po +++ b/base_user_role/i18n/pt.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/pt_BR.po b/base_user_role/i18n/pt_BR.po index c6dc4f42..8789ec0a 100644 --- a/base_user_role/i18n/pt_BR.po +++ b/base_user_role/i18n/pt_BR.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/pt_PT.po b/base_user_role/i18n/pt_PT.po index f46f4f96..09370deb 100644 --- a/base_user_role/i18n/pt_PT.po +++ b/base_user_role/i18n/pt_PT.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/ro.po b/base_user_role/i18n/ro.po index eb623d34..2705bad9 100644 --- a/base_user_role/i18n/ro.po +++ b/base_user_role/i18n/ro.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/ru.po b/base_user_role/i18n/ru.po index 13d845ac..3a9fc2b1 100644 --- a/base_user_role/i18n/ru.po +++ b/base_user_role/i18n/ru.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/sk.po b/base_user_role/i18n/sk.po index 04b2c429..462b4a18 100644 --- a/base_user_role/i18n/sk.po +++ b/base_user_role/i18n/sk.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/sl.po b/base_user_role/i18n/sl.po index 17912b2c..8661821a 100644 --- a/base_user_role/i18n/sl.po +++ b/base_user_role/i18n/sl.po @@ -56,6 +56,11 @@ msgstr "Povezana skupina" msgid "Color Index" msgstr "Barvni indeks" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "Komentar" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -113,7 +118,6 @@ msgid "Inherits" msgstr "Podeduje" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" @@ -237,6 +241,3 @@ msgstr "Uporabniki v tej skupini samodejno podedujejo te skupine" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access msgid "Views" msgstr "Prikazi" - -#~ msgid "Comment" -#~ msgstr "Komentar" diff --git a/base_user_role/i18n/sr.po b/base_user_role/i18n/sr.po index 4d49bf5f..715be490 100644 --- a/base_user_role/i18n/sr.po +++ b/base_user_role/i18n/sr.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/sr@latin.po b/base_user_role/i18n/sr@latin.po index 05462dfb..ba5de094 100644 --- a/base_user_role/i18n/sr@latin.po +++ b/base_user_role/i18n/sr@latin.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/sv.po b/base_user_role/i18n/sv.po index 49f7710a..75887232 100644 --- a/base_user_role/i18n/sv.po +++ b/base_user_role/i18n/sv.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/th.po b/base_user_role/i18n/th.po index 8ca0aa11..4ca64c43 100644 --- a/base_user_role/i18n/th.po +++ b/base_user_role/i18n/th.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/tr.po b/base_user_role/i18n/tr.po index efa6d386..a62da1ad 100644 --- a/base_user_role/i18n/tr.po +++ b/base_user_role/i18n/tr.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/tr_TR.po b/base_user_role/i18n/tr_TR.po index 55539afd..021b6989 100644 --- a/base_user_role/i18n/tr_TR.po +++ b/base_user_role/i18n/tr_TR.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/uk.po b/base_user_role/i18n/uk.po index b4601bb4..1650a107 100644 --- a/base_user_role/i18n/uk.po +++ b/base_user_role/i18n/uk.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/vi.po b/base_user_role/i18n/vi.po index 975e4d0a..acb51231 100644 --- a/base_user_role/i18n/vi.po +++ b/base_user_role/i18n/vi.po @@ -53,6 +53,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -110,7 +115,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/vi_VN.po b/base_user_role/i18n/vi_VN.po index 22bf93f9..928b4cb1 100644 --- a/base_user_role/i18n/vi_VN.po +++ b/base_user_role/i18n/vi_VN.po @@ -9,8 +9,8 @@ msgstr "" "Project-Id-Version: Odoo Server 10.0c\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2016-12-17 02:07+0000\n" -"PO-Revision-Date: 2016-12-17 02:07+0000\n" -"Last-Translator: OCA Transbot , 2016\n" +"PO-Revision-Date: 2021-09-25 14:34+0000\n" +"Last-Translator: Mi Di \n" "Language-Team: Vietnamese (Viet Nam) (https://www.transifex.com/oca/" "teams/23907/vi_VN/)\n" "Language: vi_VN\n" @@ -18,11 +18,12 @@ msgstr "" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: \n" "Plural-Forms: nplurals=1; plural=0;\n" +"X-Generator: Weblate 4.3.2\n" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__model_access msgid "Access Controls" -msgstr "" +msgstr "Kiểm soát quyền truy cập" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__menu_access @@ -32,26 +33,31 @@ msgstr "" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__category_id msgid "Application" -msgstr "" +msgstr "Ứng dụng" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__group_category_id msgid "Associated category" -msgstr "" +msgstr "Danh mục được liên kết" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__group_id msgid "Associated group" -msgstr "" +msgstr "Nhóm được liên kết" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__group_category_id msgid "Associated group's category" -msgstr "" +msgstr "Phân loại của nhóm được liên kết" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__color msgid "Color Index" +msgstr "Danh mục màu" + +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" msgstr "" #. module: base_user_role @@ -71,32 +77,34 @@ msgstr "Tạo vào" #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__display_name #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__display_name msgid "Display Name" -msgstr "" +msgstr "Tên hiển thị" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__is_enabled msgid "Enabled" -msgstr "" +msgstr "Được kích hoạt" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__date_from msgid "From" -msgstr "" +msgstr "Từ" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__full_name msgid "Group Name" -msgstr "" +msgstr "Tên nhóm" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__share msgid "Group created to set access rights for sharing data with some users." msgstr "" +"Nhóm này được tạo để thiết đặt quyền truy cập cho việc chia sẻ dữ liệu với " +"một số người dùng." #. module: base_user_role #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Groups" -msgstr "" +msgstr "Các nhóm" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users__id @@ -108,20 +116,19 @@ msgstr "ID" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__implied_ids msgid "Inherits" -msgstr "" +msgstr "Kế thừa từ" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" -msgstr "" +msgstr "Ghi chú nội bộ" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users____last_update #: model:ir.model.fields,field_description:base_user_role.field_res_users_role____last_update #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line____last_update msgid "Last Modified on" -msgstr "" +msgstr "Chỉnh sửa lần cuối vào" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__write_uid @@ -143,7 +150,7 @@ msgstr "Tên" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__role_id msgid "Role" -msgstr "" +msgstr "Vai trò" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users__role_line_ids @@ -163,22 +170,22 @@ msgstr "" #. module: base_user_role #: model:ir.model.constraint,message:base_user_role.constraint_res_users_role_line_user_role_uniq msgid "Roles can be assigned to a user only once at a time" -msgstr "" +msgstr "Vai trò chỉ được gán cho người dùng một lần tại một thời điểm" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__rule_groups msgid "Rules" -msgstr "" +msgstr "Tập luật" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__share msgid "Share Group" -msgstr "" +msgstr "Nhóm chia sẻ" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__date_to msgid "To" -msgstr "" +msgstr "Tới" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__trans_implied_ids @@ -190,44 +197,44 @@ msgstr "" #: model:ir.cron,cron_name:base_user_role.cron_update_users #: model:ir.cron,name:base_user_role.cron_update_users msgid "Update user roles" -msgstr "" +msgstr "Cập nhật vai trò người dùng" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__user_id msgid "User" -msgstr "" +msgstr "Người dùng" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users_role msgid "User role" -msgstr "" +msgstr "Vai trò người dùng" #. module: base_user_role #: model:ir.module.category,name:base_user_role.ir_module_category_role msgid "User roles" -msgstr "" +msgstr "Danh sách vai trò người dùng" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__users #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Users" -msgstr "" +msgstr "Danh sách người dùng" #. module: base_user_role #: model:ir.model,name:base_user_role.model_res_users_role_line msgid "Users associated to a role" -msgstr "" +msgstr "Người dùng được gán vào role" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__user_ids msgid "Users list" -msgstr "" +msgstr "Danh sách người dùng" #. module: base_user_role #: model:ir.model.fields,help:base_user_role.field_res_users_role__implied_ids msgid "Users of this group automatically inherit those groups" -msgstr "" +msgstr "Người dùng của nhóm này sẽ tự động kế thừa từ các nhóm khác" #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__view_access diff --git a/base_user_role/i18n/zh_CN.po b/base_user_role/i18n/zh_CN.po index ce36a685..6307a801 100644 --- a/base_user_role/i18n/zh_CN.po +++ b/base_user_role/i18n/zh_CN.po @@ -55,6 +55,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -112,7 +117,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/i18n/zh_TW.po b/base_user_role/i18n/zh_TW.po index 541a093e..e4dae8a1 100644 --- a/base_user_role/i18n/zh_TW.po +++ b/base_user_role/i18n/zh_TW.po @@ -54,6 +54,11 @@ msgstr "" msgid "Color Index" msgstr "" +#. module: base_user_role +#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment +msgid "Comment" +msgstr "" + #. module: base_user_role #: model:ir.model.fields,field_description:base_user_role.field_res_users_role__create_uid #: model:ir.model.fields,field_description:base_user_role.field_res_users_role_line__create_uid @@ -111,7 +116,6 @@ msgid "Inherits" msgstr "" #. module: base_user_role -#: model:ir.model.fields,field_description:base_user_role.field_res_users_role__comment #: model_terms:ir.ui.view,arch_db:base_user_role.view_res_users_role_form msgid "Internal Notes" msgstr "" diff --git a/base_user_role/models/role.py b/base_user_role/models/role.py index 65df6f6f..caa08a83 100644 --- a/base_user_role/models/role.py +++ b/base_user_role/models/role.py @@ -33,9 +33,6 @@ class ResUsersRole(models.Model): help="Associated group's category", readonly=False, ) - comment = fields.Html( - string="Internal Notes", - ) @api.depends("line_ids.user_id") def _compute_user_ids(self): diff --git a/base_user_role/tests/test_user_role.py b/base_user_role/tests/test_user_role.py index ad1d5c3b..5c05b82a 100644 --- a/base_user_role/tests/test_user_role.py +++ b/base_user_role/tests/test_user_role.py @@ -104,11 +104,9 @@ class TestUserRole(TransactionCase): self.assertEqual(user_group_ids, role_group_ids) def test_role_unlink(self): - # Get role1 groups - role1_group_ids = self.role1_id.implied_ids.ids - role1_group_ids.append(self.role1_id.group_id.id) - role1_group_ids = sorted(set(role1_group_ids)) - + # Get role1 and role2 groups + role1_groups = self.role1_id.implied_ids | self.role1_id.group_id + role2_groups = self.role2_id.implied_ids | self.role2_id.group_id # Configure the user with role1 and role2 self.user_id.write( { @@ -118,21 +116,24 @@ class TestUserRole(TransactionCase): ] } ) + # Check user has groups from role1 and role2 + self.assertLessEqual(role1_groups, self.user_id.groups_id) + self.assertLessEqual(role2_groups, self.user_id.groups_id) # Remove role2 self.role2_id.unlink() - user_group_ids = sorted({group.id for group in self.user_id.groups_id}) - self.assertEqual(user_group_ids, role1_group_ids) + # Check user has groups from only role1 + self.assertLessEqual(role1_groups, self.user_id.groups_id) + self.assertFalse(role2_groups <= self.user_id.groups_id) # Remove role1 self.role1_id.unlink() - user_group_ids = sorted({group.id for group in self.user_id.groups_id}) - self.assertEqual(user_group_ids, []) + # Check user has no groups from role1 and role2 + self.assertFalse(role1_groups <= self.user_id.groups_id) + self.assertFalse(role2_groups <= self.user_id.groups_id) def test_role_line_unlink(self): - # Get role1 groups - role1_group_ids = self.role1_id.implied_ids.ids - role1_group_ids.append(self.role1_id.group_id.id) - role1_group_ids = sorted(set(role1_group_ids)) - + # Get role1 and role2 groups + role1_groups = self.role1_id.implied_ids | self.role1_id.group_id + role2_groups = self.role2_id.implied_ids | self.role2_id.group_id # Configure the user with role1 and role2 self.user_id.write( { @@ -142,18 +143,23 @@ class TestUserRole(TransactionCase): ] } ) + # Check user has groups from role1 and role2 + self.assertLessEqual(role1_groups, self.user_id.groups_id) + self.assertLessEqual(role2_groups, self.user_id.groups_id) # Remove role2 from the user self.user_id.role_line_ids.filtered( lambda l: l.role_id.id == self.role2_id.id ).unlink() - user_group_ids = sorted({group.id for group in self.user_id.groups_id}) - self.assertEqual(user_group_ids, role1_group_ids) + # Check user has groups from only role1 + self.assertLessEqual(role1_groups, self.user_id.groups_id) + self.assertFalse(role2_groups <= self.user_id.groups_id) # Remove role1 from the user self.user_id.role_line_ids.filtered( lambda l: l.role_id.id == self.role1_id.id ).unlink() - user_group_ids = sorted({group.id for group in self.user_id.groups_id}) - self.assertEqual(user_group_ids, []) + # Check user has no groups from role1 and role2 + self.assertFalse(role1_groups <= self.user_id.groups_id) + self.assertFalse(role2_groups <= self.user_id.groups_id) def test_default_user_roles(self): self.default_user.write( diff --git a/base_user_role_company/__manifest__.py b/base_user_role_company/__manifest__.py index 5b1af098..8e306b5c 100644 --- a/base_user_role_company/__manifest__.py +++ b/base_user_role_company/__manifest__.py @@ -3,7 +3,7 @@ { "name": "User roles by company", - "version": "14.0.1.0.0", + "version": "14.0.1.1.0", "category": "Tools", "author": "Open Source Integrators, Odoo Community Association (OCA)", "license": "AGPL-3", diff --git a/base_user_role_company/i18n/it.po b/base_user_role_company/i18n/it.po new file mode 100644 index 00000000..f28ab71a --- /dev/null +++ b/base_user_role_company/i18n/it.po @@ -0,0 +1,83 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_user_role_company +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2022-02-15 16:16+0000\n" +"Last-Translator: Riccardo Bellanova \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.3.2\n" + +#. module: base_user_role_company +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users_role_line__active_role +msgid "Active Role" +msgstr "Ruolo attivo" + +#. module: base_user_role_company +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users_role_line__company_id +msgid "Company" +msgstr "Azienda" + +#. module: base_user_role_company +#: model:ir.model.fields,field_description:base_user_role_company.field_ir_http__display_name +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users__display_name +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users_role_line__display_name +msgid "Display Name" +msgstr "Nome visualizzato" + +#. module: base_user_role_company +#: model:ir.model,name:base_user_role_company.model_ir_http +msgid "HTTP Routing" +msgstr "Rotta HTTP" + +#. module: base_user_role_company +#: model:ir.model.fields,field_description:base_user_role_company.field_ir_http__id +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users__id +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users_role_line__id +msgid "ID" +msgstr "ID" + +#. module: base_user_role_company +#: model:ir.model.fields,help:base_user_role_company.field_res_users_role_line__company_id +msgid "" +"If set, this role only applies when this is the main company selected. " +"Otherwise it applies to all companies." +msgstr "" +"Se impostato, questo ruolo si applica solo quando questa è l'azienda " +"principale selezionata. Altrimenti vale per tutte le aziende." + +#. module: base_user_role_company +#: model:ir.model.fields,field_description:base_user_role_company.field_ir_http____last_update +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users____last_update +#: model:ir.model.fields,field_description:base_user_role_company.field_res_users_role_line____last_update +msgid "Last Modified on" +msgstr "Ultima modifica il" + +#. module: base_user_role_company +#: model:ir.model.constraint,message:base_user_role_company.constraint_res_users_role_line_user_role_uniq +msgid "Roles can be assigned to a user only once at a time" +msgstr "I ruoli possono essere assegnati all'utente solo uno alla volta" + +#. module: base_user_role_company +#: code:addons/base_user_role_company/models/role.py:0 +#, python-format +msgid "User \"{}\" does not have access to the company \"{}\"" +msgstr "L'utente \"{}\" non ha l'accesso all'azienda \"{}\"" + +#. module: base_user_role_company +#: model:ir.model,name:base_user_role_company.model_res_users +msgid "Users" +msgstr "Utenti" + +#. module: base_user_role_company +#: model:ir.model,name:base_user_role_company.model_res_users_role_line +msgid "Users associated to a role" +msgstr "Utenti associati al ruolo" diff --git a/base_user_role_company/views/role.xml b/base_user_role_company/views/role.xml index bfcb01e8..89bd80ad 100644 --- a/base_user_role_company/views/role.xml +++ b/base_user_role_company/views/role.xml @@ -5,10 +5,13 @@ res.users - + - + diff --git a/base_user_role_profile/README.rst b/base_user_role_profile/README.rst new file mode 100644 index 00000000..af7aac25 --- /dev/null +++ b/base_user_role_profile/README.rst @@ -0,0 +1,93 @@ +============= +User profiles +============= + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! 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%2Fserver--backend-lightgray.png?logo=github + :target: https://github.com/OCA/server-backend/tree/14.0/base_user_role_profile + :alt: OCA/server-backend +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/server-backend-14-0/server-backend-14-0-base_user_role_profile + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/253/14.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +Extending the base_user_role module, this one adds the notion of profiles. Effectively profiles act as an additional filter to how the roles are used. + +This allows users to switch their permission groups dynamically. This can be useful for example to: + - finer grain control on menu and model permissions (with record rules this becomes very flexible) + - break down complicated menus into simpler ones + - easily restrict users accidentally editing or creating records in O2M fields and in general misusing the interface, instead of excessively explaining things to them + +When you define a role, you have the possibility to link it to a profile. Roles are applied to users in the following way: + - Apply user's roles without profiles in any case + - Apply user's roles that are linked to the currently selected profile + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +Go to Configuration / Users / Profiles and create a profile. Go to Configuration / Users / Roles and define some role lines with profiles. + +Usage +===== + +Once you have set up at least one profile for a user, use the widget in the top bar to switch user profiles. Note that it is possible to use no profile; in this case, the user will only get the roles that always apply (i.e the ones with no profile_id). + +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 +~~~~~~~ + +* Akretion + +Contributors +~~~~~~~~~~~~ + +* Kevin Khao +* Sébastien Beau + +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/server-backend `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/base_user_role_profile/__init__.py b/base_user_role_profile/__init__.py new file mode 100644 index 00000000..cc6b6354 --- /dev/null +++ b/base_user_role_profile/__init__.py @@ -0,0 +1,2 @@ +from . import models +from .hooks import post_init_hook diff --git a/base_user_role_profile/__manifest__.py b/base_user_role_profile/__manifest__.py new file mode 100644 index 00000000..22a34689 --- /dev/null +++ b/base_user_role_profile/__manifest__.py @@ -0,0 +1,22 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "User profiles", + "version": "14.0.1.0.0", + "category": "Tools", + "author": "Akretion, Odoo Community Association (OCA)", + "license": "AGPL-3", + "website": "https://github.com/OCA/server-backend", + "depends": ["base_user_role", "web"], + "post_init_hook": "post_init_hook", + "data": [ + "data/data.xml", + "security/ir.model.access.csv", + "views/user.xml", + "views/role.xml", + "views/profile.xml", + "views/assets.xml", + ], + "qweb": ["static/src/xml/templates.xml"], + "installable": True, +} diff --git a/base_user_role_profile/data/data.xml b/base_user_role_profile/data/data.xml new file mode 100644 index 00000000..ea7778aa --- /dev/null +++ b/base_user_role_profile/data/data.xml @@ -0,0 +1,6 @@ + + + + No profile + + diff --git a/base_user_role_profile/hooks.py b/base_user_role_profile/hooks.py new file mode 100644 index 00000000..f6b145f2 --- /dev/null +++ b/base_user_role_profile/hooks.py @@ -0,0 +1,12 @@ +# Copyright 2020 Akretion (https://www.akretion.com). +# @author Pierrick Brun +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import SUPERUSER_ID, api + + +def post_init_hook(cr, registry): + env = api.Environment(cr, SUPERUSER_ID, {}) + env["res.users"].search([("profile_id", "=", False)]).profile_id = env.ref( + "base_user_role_profile.default_profile" + ) diff --git a/base_user_role_profile/i18n/base_user_role_profile.pot b/base_user_role_profile/i18n/base_user_role_profile.pot new file mode 100644 index 00000000..689ca697 --- /dev/null +++ b/base_user_role_profile/i18n/base_user_role_profile.pot @@ -0,0 +1,123 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_user_role_profile +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__user_ids +msgid "Allowed users" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__create_uid +msgid "Created by" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__create_date +msgid "Created on" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users__profile_id +msgid "Current profile" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users__profile_ids +msgid "Currently allowed profiles" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_ir_http__display_name +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users__display_name +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__display_name +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role__display_name +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role_line__display_name +msgid "Display Name" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model,name:base_user_role_profile.model_ir_http +msgid "HTTP Routing" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_ir_http__id +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users__id +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__id +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role__id +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role_line__id +msgid "ID" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_ir_http____last_update +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users____last_update +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile____last_update +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role____last_update +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role_line____last_update +msgid "Last Modified on" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__write_date +msgid "Last Updated on" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__name +msgid "Name" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role__profile_id +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_role_line__profile_id +msgid "Profile" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model,name:base_user_role_profile.model_res_users_profile +msgid "Role profile" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model.fields,field_description:base_user_role_profile.field_res_users_profile__role_ids +msgid "Roles" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.actions.act_window,name:base_user_role_profile.action_res_users_profile_tree +#: model:ir.ui.menu,name:base_user_role_profile.menu_action_res_users_profile_tree +msgid "User Profiles" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model,name:base_user_role_profile.model_res_users_role +msgid "User role" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model,name:base_user_role_profile.model_res_users +msgid "Users" +msgstr "" + +#. module: base_user_role_profile +#: model:ir.model,name:base_user_role_profile.model_res_users_role_line +msgid "Users associated to a role" +msgstr "" diff --git a/base_user_role_profile/models/__init__.py b/base_user_role_profile/models/__init__.py new file mode 100644 index 00000000..12328c7d --- /dev/null +++ b/base_user_role_profile/models/__init__.py @@ -0,0 +1,4 @@ +from . import profile +from . import user +from . import role +from . import ir_http diff --git a/base_user_role_profile/models/ir_http.py b/base_user_role_profile/models/ir_http.py new file mode 100644 index 00000000..90de7a04 --- /dev/null +++ b/base_user_role_profile/models/ir_http.py @@ -0,0 +1,22 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo import models +from odoo.http import request + + +class Http(models.AbstractModel): + _inherit = "ir.http" + + def session_info(self): # pragma: no cover + result = super().session_info() + user = request.env.user + allowed_profiles = [(profile.id, profile.name) for profile in user.profile_ids] + if len(allowed_profiles) > 1: + current_profile = (user.profile_id.id, user.profile_id.name) + result["user_profiles"] = { + "current_profile": current_profile, + "allowed_profiles": allowed_profiles, + } + else: + result["user_profiles"] = False + result["profile_id"] = user.profile_id.id if request.session.uid else None + return result diff --git a/base_user_role_profile/models/profile.py b/base_user_role_profile/models/profile.py new file mode 100644 index 00000000..d1f2818a --- /dev/null +++ b/base_user_role_profile/models/profile.py @@ -0,0 +1,19 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo import fields, models + + +class ResUsersProfile(models.Model): + _name = "res.users.profile" + _description = "Role profile" + + name = fields.Char("Name") + user_ids = fields.Many2many( + "res.users", string="Allowed users", compute="_compute_user_ids" + ) + role_ids = fields.One2many("res.users.role", "profile_id", string="Roles") + + def _compute_user_ids(self): + for rec in self: + rec.user_ids = self.env["res.users"].search( + [("profile_ids", "in", rec.ids)] + ) diff --git a/base_user_role_profile/models/role.py b/base_user_role_profile/models/role.py new file mode 100644 index 00000000..7c7777a7 --- /dev/null +++ b/base_user_role_profile/models/role.py @@ -0,0 +1,17 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo import fields, models + + +class ResUsersRole(models.Model): + _inherit = "res.users.role" + + profile_id = fields.Many2one( + "res.users.profile", + "Profile", + ) + + +class ResUsersRoleLine(models.Model): + _inherit = "res.users.role.line" + + profile_id = fields.Many2one(related="role_id.profile_id") diff --git a/base_user_role_profile/models/user.py b/base_user_role_profile/models/user.py new file mode 100644 index 00000000..181494e2 --- /dev/null +++ b/base_user_role_profile/models/user.py @@ -0,0 +1,75 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo import api, fields, models + + +class ResUsers(models.Model): + _inherit = "res.users" + + def _get_default_profile(self): + return self.env.ref( + "base_user_role_profile.default_profile", raise_if_not_found=False + ) + + profile_id = fields.Many2one( + "res.users.profile", + "Current profile", + default=lambda self: self._get_default_profile(), + ) + + profile_ids = fields.Many2many( + "res.users.profile", + string="Currently allowed profiles", + ) + + def _get_action_root_menu(self): + # used JS-side. Reload the client; open the first available root menu + menu = self.env["ir.ui.menu"].search([("parent_id", "=", False)])[:1] + return { + "type": "ir.actions.client", + "tag": "reload", + "params": {"menu_id": menu.id}, + } + + def action_profile_change(self, vals): + self.write(vals) + return self._get_action_root_menu() + + @api.model + def create(self, vals): + new_record = super().create(vals) + if vals.get("role_line_ids"): + new_record.sudo()._compute_profile_ids() + return new_record + + def write(self, vals): + # inspired by base/models/res_users.py l. 491 + if self == self.env.user and vals.get("profile_id"): + self.sudo().write({"profile_id": vals["profile_id"]}) + del vals["profile_id"] + res = super().write(vals) + if vals.get("profile_id") or vals.get("role_line_ids"): + self.sudo()._compute_profile_ids() + return res + + def _get_enabled_roles(self): + res = super()._get_enabled_roles() + res = res.filtered( + lambda r: not r.profile_id or (r.profile_id.id == r.user_id.profile_id.id) + ) + return res + + def _update_profile_id(self): + default_profile = self._get_default_profile() + if not self.profile_ids: + if self.profile_id != default_profile: + self.profile_id = default_profile + elif self.profile_id not in self.profile_ids: + self.write({"profile_id": self.profile_ids[0].id}) + + def _compute_profile_ids(self): + for rec in self: + role_lines = rec.role_line_ids + profiles = role_lines.mapped("profile_id") + rec.profile_ids = profiles + # set defaults in case applicable profile changes + rec._update_profile_id() diff --git a/base_user_role_profile/readme/CONFIGURE.rst b/base_user_role_profile/readme/CONFIGURE.rst new file mode 100644 index 00000000..d45c6d31 --- /dev/null +++ b/base_user_role_profile/readme/CONFIGURE.rst @@ -0,0 +1 @@ +Go to Configuration / Users / Profiles and create a profile. Go to Configuration / Users / Roles and define some role lines with profiles. diff --git a/base_user_role_profile/readme/CONTRIBUTORS.rst b/base_user_role_profile/readme/CONTRIBUTORS.rst new file mode 100644 index 00000000..79f515ed --- /dev/null +++ b/base_user_role_profile/readme/CONTRIBUTORS.rst @@ -0,0 +1,2 @@ +* Kevin Khao +* Sébastien Beau diff --git a/base_user_role_profile/readme/DESCRIPTION.rst b/base_user_role_profile/readme/DESCRIPTION.rst new file mode 100644 index 00000000..5eab5362 --- /dev/null +++ b/base_user_role_profile/readme/DESCRIPTION.rst @@ -0,0 +1,10 @@ +Extending the base_user_role module, this one adds the notion of profiles. Effectively profiles act as an additional filter to how the roles are used. + +This allows users to switch their permission groups dynamically. This can be useful for example to: + - finer grain control on menu and model permissions (with record rules this becomes very flexible) + - break down complicated menus into simpler ones + - easily restrict users accidentally editing or creating records in O2M fields and in general misusing the interface, instead of excessively explaining things to them + +When you define a role, you have the possibility to link it to a profile. Roles are applied to users in the following way: + - Apply user's roles without profiles in any case + - Apply user's roles that are linked to the currently selected profile diff --git a/base_user_role_profile/readme/USAGE.rst b/base_user_role_profile/readme/USAGE.rst new file mode 100644 index 00000000..b76ca9ea --- /dev/null +++ b/base_user_role_profile/readme/USAGE.rst @@ -0,0 +1 @@ +Once you have set up at least one profile for a user, use the widget in the top bar to switch user profiles. Note that it is possible to use no profile; in this case, the user will only get the roles that always apply (i.e the ones with no profile_id). diff --git a/base_user_role_profile/security/ir.model.access.csv b/base_user_role_profile/security/ir.model.access.csv new file mode 100644 index 00000000..acb21834 --- /dev/null +++ b/base_user_role_profile/security/ir.model.access.csv @@ -0,0 +1,3 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_res_users_profile,access_res_users_profile,model_res_users_profile,base.group_user,1,0,0,0 +access_res_users_role_line_users,access_res_users_role_line,model_res_users_role_line,base.group_user,1,0,0,0 diff --git a/base_user_role_profile/static/description/icon.png b/base_user_role_profile/static/description/icon.png new file mode 100644 index 00000000..4a8a6d74 Binary files /dev/null and b/base_user_role_profile/static/description/icon.png differ diff --git a/base_user_role_profile/static/description/index.html b/base_user_role_profile/static/description/index.html new file mode 100644 index 00000000..cb493ece --- /dev/null +++ b/base_user_role_profile/static/description/index.html @@ -0,0 +1,445 @@ + + + + + + +User profiles + + + +
+

User profiles

+ + +

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

+

Extending the base_user_role module, this one adds the notion of profiles. Effectively profiles act as an additional filter to how the roles are used.

+
+
This allows users to switch their permission groups dynamically. This can be useful for example to:
+
    +
  • finer grain control on menu and model permissions (with record rules this becomes very flexible)
  • +
  • break down complicated menus into simpler ones
  • +
  • easily restrict users accidentally editing or creating records in O2M fields and in general misusing the interface, instead of excessively explaining things to them
  • +
+
+
When you define a role, you have the possibility to link it to a profile. Roles are applied to users in the following way:
+
    +
  • Apply user’s roles without profiles in any case
  • +
  • Apply user’s roles that are linked to the currently selected profile
  • +
+
+
+

Table of contents

+ +
+

Configuration

+

Go to Configuration / Users / Profiles and create a profile. Go to Configuration / Users / Roles and define some role lines with profiles.

+
+
+

Usage

+

Once you have set up at least one profile for a user, use the widget in the top bar to switch user profiles. Note that it is possible to use no profile; in this case, the user will only get the roles that always apply (i.e the ones with no profile_id).

+
+
+

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

+
    +
  • Akretion
  • +
+
+
+

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/server-backend project on GitHub.

+

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

+
+
+
+ + diff --git a/base_user_role_profile/tests/__init__.py b/base_user_role_profile/tests/__init__.py new file mode 100644 index 00000000..f8c808c7 --- /dev/null +++ b/base_user_role_profile/tests/__init__.py @@ -0,0 +1 @@ +from . import test_user_role diff --git a/base_user_role_profile/tests/test_user_role.py b/base_user_role_profile/tests/test_user_role.py new file mode 100644 index 00000000..44830c4b --- /dev/null +++ b/base_user_role_profile/tests/test_user_role.py @@ -0,0 +1,112 @@ +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). +from odoo.tests.common import TransactionCase + + +class TestUserProfile(TransactionCase): + def _helper_unpack_groups_role(self, role): + role_group_ids = role.trans_implied_ids.ids + role_group_ids.append(role.group_id.id) + return sorted(set(role_group_ids)) + + def _helper_unpack_groups_group(self, group): + group_ids = group.trans_implied_ids.ids + group_ids.append(group.id) + return sorted(set(group_ids)) + + def setUp(self): + super().setUp() + self.user_model = self.env["res.users"] + self.role_model = self.env["res.users.role"] + + self.default_user = self.env.ref("base.default_user") + user_vals = { + "name": "USER TEST (ROLES)", + "login": "user_test_roles", + } + self.user_id = self.user_model.create(user_vals) + + self.profile1_id = self.env["res.users.profile"].create({"name": "profile1"}) + self.profile2_id = self.env["res.users.profile"].create({"name": "profile2"}) + + # role 1 + self.group_user_id = self.env.ref("base.group_user") + self.group_no_one_id = self.env.ref("base.group_no_one") + + # role 2 + self.group_system_id = self.env.ref("base.group_system") + self.group_multi_company_id = self.env.ref("base.group_multi_company") + + # role 3 + self.group_erp_manager_id = self.env.ref("base.group_erp_manager") + self.group_partner_manager_id = self.env.ref("base.group_partner_manager") + + # roles 1 and 2 have a profile, role 3 no profile + vals = { + "name": "ROLE_1", + "implied_ids": [(6, 0, [self.group_user_id.id, self.group_no_one_id.id])], + "profile_id": self.profile1_id.id, + } + self.role1_id = self.role_model.create(vals) + self.role1_group_ids = self._helper_unpack_groups_role(self.role1_id) + + vals = { + "name": "ROLE_2", + "implied_ids": [ + ( + 6, + 0, + [self.group_system_id.id, self.group_multi_company_id.id], + ) + ], + "profile_id": self.profile2_id.id, + } + self.role2_id = self.role_model.create(vals) + self.role2_group_ids = self._helper_unpack_groups_role(self.role2_id) + + vals = { + "name": "ROLE_3", + "implied_ids": [ + ( + 6, + 0, + [ + self.group_erp_manager_id.id, + self.group_partner_manager_id.id, + ], + ) + ], + } + self.role3_id = self.role_model.create(vals) + self.role3_group_ids = self._helper_unpack_groups_role(self.role3_id) + + def test_filter_by_profile(self): + line1_vals = {"role_id": self.role1_id.id, "user_id": self.user_id.id} + self.user_id.write({"role_line_ids": [(0, 0, line1_vals)]}) + line2_vals = {"role_id": self.role2_id.id, "user_id": self.user_id.id} + self.user_id.write({"role_line_ids": [(0, 0, line2_vals)]}) + self.assertEqual(self.user_id.profile_ids, self.profile1_id + self.profile2_id) + self.assertEqual(self.user_id.profile_id, self.profile1_id) + self.user_id.action_profile_change({"profile_id": self.profile1_id.id}) + + user_group_ids = sorted({group.id for group in self.user_id.groups_id}) + expected_group_ids = sorted(set(self.role1_group_ids)) + self.assertEqual(user_group_ids, expected_group_ids) + + self.user_id.action_profile_change({"profile_id": self.profile2_id.id}) + + user_group_ids = sorted({group.id for group in self.user_id.groups_id}) + expected_group_ids = sorted(set(self.role2_group_ids)) + self.assertEqual(user_group_ids, expected_group_ids) + + def test_allow_by_noprofile(self): + line1_vals = {"role_id": self.role1_id.id, "user_id": self.user_id.id} + self.user_id.write({"role_line_ids": [(0, 0, line1_vals)]}) + line2_vals = {"role_id": self.role3_id.id, "user_id": self.user_id.id} + self.user_id.write({"role_line_ids": [(0, 0, line2_vals)]}) + self.assertEqual(self.user_id.profile_ids, self.profile1_id) + user_group_ids = [] + for group in self.user_id.groups_id: + user_group_ids += self._helper_unpack_groups_group(group) + user_group_ids = set(user_group_ids) + expected_groups = set(self.role1_group_ids + self.role3_group_ids) + self.assertEqual(user_group_ids, expected_groups) diff --git a/base_user_role_profile/views/assets.xml b/base_user_role_profile/views/assets.xml new file mode 100644 index 00000000..d5683038 --- /dev/null +++ b/base_user_role_profile/views/assets.xml @@ -0,0 +1,15 @@ + + +