diff --git a/README.md b/README.md index 0efde1c73e0..4b62afca2e4 100644 --- a/README.md +++ b/README.md @@ -28,6 +28,7 @@ addon | version | maintainers | summary [auditlog](auditlog/) | 18.0.2.0.9 | | Audit Log [auto_backup](auto_backup/) | 18.0.1.0.1 | | Backups database [autovacuum_message_attachment](autovacuum_message_attachment/) | 18.0.1.0.1 | florian-dacosta | Automatically delete old mail messages and attachments +[base_conditional_image](base_conditional_image/) | 18.0.1.0.0 | | This module extends the functionality to support conditional images [base_cron_exclusion](base_cron_exclusion/) | 18.0.1.0.1 | LoisRForgeFlow ChrisOForgeFlow | Allow you to select scheduled actions that should not run simultaneously. [base_exception](base_exception/) | 18.0.1.1.1 | hparfr sebastienbeau | This module provide an abstract model to manage customizable exceptions to be applied on different models (sale order, invoice, ...) [base_fontawesome](base_fontawesome/) | 18.0.2.0.0 | | Up to date Fontawesome resources. diff --git a/autovacuum_message_attachment/i18n/autovacuum_message_attachment.pot b/autovacuum_message_attachment/i18n/autovacuum_message_attachment.pot index edf2268fcfa..59c3ca3a548 100644 --- a/autovacuum_message_attachment/i18n/autovacuum_message_attachment.pot +++ b/autovacuum_message_attachment/i18n/autovacuum_message_attachment.pot @@ -135,6 +135,8 @@ msgstr "" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/autovacuum_message_attachment/i18n/ca.po b/autovacuum_message_attachment/i18n/ca.po index 1764d6e3bde..6653e92cd24 100644 --- a/autovacuum_message_attachment/i18n/ca.po +++ b/autovacuum_message_attachment/i18n/ca.po @@ -136,6 +136,8 @@ msgstr "" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/autovacuum_message_attachment/i18n/es.po b/autovacuum_message_attachment/i18n/es.po index 4c321589856..2e77563458f 100644 --- a/autovacuum_message_attachment/i18n/es.po +++ b/autovacuum_message_attachment/i18n/es.po @@ -138,6 +138,8 @@ msgstr "Todos" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/autovacuum_message_attachment/i18n/es_AR.po b/autovacuum_message_attachment/i18n/es_AR.po index b3667f0cb93..6f5cbba59cb 100644 --- a/autovacuum_message_attachment/i18n/es_AR.po +++ b/autovacuum_message_attachment/i18n/es_AR.po @@ -138,6 +138,8 @@ msgstr "Todos" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/autovacuum_message_attachment/i18n/fr.po b/autovacuum_message_attachment/i18n/fr.po index d7f73284848..2b05db501aa 100644 --- a/autovacuum_message_attachment/i18n/fr.po +++ b/autovacuum_message_attachment/i18n/fr.po @@ -138,6 +138,8 @@ msgstr "Tous" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/autovacuum_message_attachment/i18n/it.po b/autovacuum_message_attachment/i18n/it.po index de5f4cc70e0..dd6b561742f 100644 --- a/autovacuum_message_attachment/i18n/it.po +++ b/autovacuum_message_attachment/i18n/it.po @@ -138,6 +138,8 @@ msgstr "Tutti" #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_model__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_module__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_cleanup_purge_wizard_table__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image__assigned_attachment_ids +#: model:ir.model.fields,field_description:autovacuum_message_attachment.field_conditional_image_consumer_mixin__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_database_autovacuum_tuning__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_db_backup__assigned_attachment_ids #: model:ir.model.fields,field_description:autovacuum_message_attachment.field_decimal_precision__assigned_attachment_ids diff --git a/base_conditional_image/README.rst b/base_conditional_image/README.rst new file mode 100644 index 00000000000..fd3437945cc --- /dev/null +++ b/base_conditional_image/README.rst @@ -0,0 +1,141 @@ +.. image:: https://odoo-community.org/readme-banner-image + :target: https://odoo-community.org/get-involved?utm_source=readme + :alt: Odoo Community Association + +================== +Conditional Images +================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:a43e69abc9d533d059e3ba3612b938ea0ac06b4e7b766dd472382b3e631b7138 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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/license-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--tools-lightgray.png?logo=github + :target: https://github.com/OCA/server-tools/tree/18.0/base_conditional_image + :alt: OCA/server-tools +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/server-tools-18-0/server-tools-18-0-base_conditional_image + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/server-tools&target_branch=18.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module extends the functionality of any model to support +conditional images (based on the record attributes) and to manage them +either globally or by company. + +The main goal behind this module is to avoid storing the same image +multiple times. For example, for every partner, there is a related image +(most of the time, it's the default one). With this module properly set +up, it will be stored only one time and you can change it whenever you +want for all partners. + +**WARNING**: this module cannot be used on the same objects using the +module base_multi_image. + +**Table of contents** + +.. contents:: + :local: + +Installation +============ + +The sole purpose of this module is to add an abstract model to be +inherited. So, you will not notice any changes on install. + +To develop using this module, you have to inherit the abstract model +conditional.image.consumer.mixin to the model that needs the conditional +images: + +:: + + class ResPartner(models.Model): + _inherit = ['res.partner', 'conditional.image.consumer.mixin'] + _name = 'res.partner' + +Then, configure how the images will be selected for each record. + +Usage +===== + +Go to *Technical Settings > Settings > Images* to configure all the +images. You can define images for specific objects, depending on the +attributes and the company of the object. + +The selector should return a boolean expression. All fields of the +object are available to compute the result. + +The system will first try to match an image with a company set up, then +with the ones without a company. If your object does not have a +company_id field, this check will be ignored and only images without a +company will be used. + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* Camptocamp + +Contributors +------------ + +- `Camptocamp `__: + + - Patrick Tombez + - Denis Leemann + +- `Trobz `__: + + - Son Ho + +- `Heliconia Solutions Pvt. Ltd. `__ + + - Bhavesh Heliconia + +Other credits +------------- + +The migration of this module from 12.0 to 14.0 was financially supported +by Camptocamp + +Maintainers +----------- + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +This module is part of the `OCA/server-tools `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/base_conditional_image/__init__.py b/base_conditional_image/__init__.py new file mode 100644 index 00000000000..0650744f6bc --- /dev/null +++ b/base_conditional_image/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/base_conditional_image/__manifest__.py b/base_conditional_image/__manifest__.py new file mode 100644 index 00000000000..5403aa8c509 --- /dev/null +++ b/base_conditional_image/__manifest__.py @@ -0,0 +1,20 @@ +# Copyright 2019-2022 Camptocamp SA +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +{ + "name": "Conditional Images", + "summary": "This module extends the functionality to support conditional images", + "version": "18.0.1.0.0", + "author": "Camptocamp, Odoo Community Association (OCA)", + "license": "AGPL-3", + "category": "Misc", + "depends": [ + "base", + ], + "website": "https://github.com/OCA/server-tools", + "data": [ + "views/image_view.xml", + "security/ir.model.access.csv", + ], + "installable": True, +} diff --git a/base_conditional_image/i18n/base_conditional_image.pot b/base_conditional_image/i18n/base_conditional_image.pot new file mode 100644 index 00000000000..7f2e2b58eb9 --- /dev/null +++ b/base_conditional_image/i18n/base_conditional_image.pot @@ -0,0 +1,128 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_conditional_image +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 18.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_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__company_id +msgid "Company" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__company_id +msgid "" +"Company related check. If inherited object does not have a `company_id` " +"field, it will be ignored. The check will first take the records with a " +"company then, if no match is found, the ones without a company." +msgstr "" + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Conditional Image" +msgstr "" + +#. module: base_conditional_image +#: model:ir.actions.act_window,name:base_conditional_image.conditional_image_action +#: model:ir.ui.menu,name:base_conditional_image.conditional_image_menu +msgid "Conditional Images" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_uid +msgid "Created by" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_date +msgid "Created on" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__display_name +msgid "Display Name" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__id +msgid "ID" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1920 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1920 +msgid "Image" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1024 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1024 +msgid "Image 1024" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_128 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_128 +msgid "Image 128" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_256 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_256 +msgid "Image 256" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_512 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_512 +msgid "Image 512" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_date +msgid "Last Updated on" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image_consumer_mixin +msgid "Mixin for conditional images consumers" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__model_name +msgid "Model Name" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__name +msgid "Name" +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__selector +msgid "" +"Python expression used as selector when multiple images are usedfor the same" +" object. The variable `object` refers to the actual record on which the " +"expression will be executed. An empty expression will always return `True`." +msgstr "" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__selector +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Selector" +msgstr "" diff --git a/base_conditional_image/i18n/es_AR.po b/base_conditional_image/i18n/es_AR.po new file mode 100644 index 00000000000..5687d3431ba --- /dev/null +++ b/base_conditional_image/i18n/es_AR.po @@ -0,0 +1,144 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_conditional_image +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 15.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2022-10-09 22:36+0000\n" +"Last-Translator: Ignacio Buioli \n" +"Language-Team: none\n" +"Language: es_AR\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.3.2\n" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__company_id +msgid "Company" +msgstr "Compañía" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__company_id +msgid "" +"Company related check. If inherited object does not have a `company_id` " +"field, it will be ignored. The check will first take the records with a " +"company then, if no match is found, the ones without a company." +msgstr "" +"Verificación de compañía relacionada. Si el objeto heredado no tiene un " +"campo `company_id`, se ignorará. La verificación tomará primero los " +"registros con una compañía y luego, si no se encuentra ninguna coincidencia, " +"los que no tengan una compañía." + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Conditional Image" +msgstr "Imagen Condicional" + +#. module: base_conditional_image +#: model:ir.actions.act_window,name:base_conditional_image.conditional_image_action +#: model:ir.ui.menu,name:base_conditional_image.conditional_image_menu +msgid "Conditional Images" +msgstr "Imágenes Condicionales" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_uid +msgid "Created by" +msgstr "Creado por" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_date +msgid "Created on" +msgstr "Creado en" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__display_name +msgid "Display Name" +msgstr "Mostrar Nombre" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__id +msgid "ID" +msgstr "ID" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1920 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1920 +msgid "Image" +msgstr "Imagen" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1024 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1024 +msgid "Image 1024" +msgstr "Imagen 1024" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_128 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_128 +msgid "Image 128" +msgstr "Imagen 128" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_256 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_256 +msgid "Image 256" +msgstr "Imagen 256" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_512 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_512 +msgid "Image 512" +msgstr "Imagen 512" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image____last_update +msgid "Last Modified on" +msgstr "Última modificación en" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_uid +msgid "Last Updated by" +msgstr "Última actualización realizada por" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_date +msgid "Last Updated on" +msgstr "Última actualización el" + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image_consumer_mixin +msgid "Mixin for conditional images consumers" +msgstr "Mixin para consumidores de imágenes condicionales" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__model_name +msgid "Model Name" +msgstr "Nombre del Modelo" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__name +msgid "Name" +msgstr "Nombre" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__selector +msgid "" +"Python expression used as selector when multiple images are usedfor the same " +"object. The variable `object` refers to the actual record on which the " +"expression will be executed. An empty expression will always return `True`." +msgstr "" +"Expresión de Python utilizada como selector cuando se utilizan varias " +"imágenes para el mismo objeto. La variable `objet` se refiere al registro " +"real en el que se ejecutará la expresión. Una expresión vacía siempre " +"devolverá `True`." + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__selector +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Selector" +msgstr "Selector" diff --git a/base_conditional_image/i18n/it.po b/base_conditional_image/i18n/it.po new file mode 100644 index 00000000000..b5db7c3b6d0 --- /dev/null +++ b/base_conditional_image/i18n/it.po @@ -0,0 +1,144 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_conditional_image +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-10-24 09:06+0000\n" +"Last-Translator: mymage \n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 5.6.2\n" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__company_id +msgid "Company" +msgstr "Azienda" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__company_id +msgid "" +"Company related check. If inherited object does not have a `company_id` " +"field, it will be ignored. The check will first take the records with a " +"company then, if no match is found, the ones without a company." +msgstr "" +"Controllo correlato all'azienda. Se l'oggetto ereditato non ha un campo " +"`company_id`, verrà ignorato. Il controllo prenderà prima i record con " +"un'azienda, poi, se non viene trovata alcuna corrispondenza, quelli senza " +"azienda." + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Conditional Image" +msgstr "Immagine condizionale" + +#. module: base_conditional_image +#: model:ir.actions.act_window,name:base_conditional_image.conditional_image_action +#: model:ir.ui.menu,name:base_conditional_image.conditional_image_menu +msgid "Conditional Images" +msgstr "Immagini condizionali" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_uid +msgid "Created by" +msgstr "Creato da" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__create_date +msgid "Created on" +msgstr "Creato il" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__display_name +msgid "Display Name" +msgstr "Nome visualizzato" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__id +msgid "ID" +msgstr "ID" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1920 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1920 +msgid "Image" +msgstr "Immagine" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_1024 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_1024 +msgid "Image 1024" +msgstr "Immagine 1024" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_128 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_128 +msgid "Image 128" +msgstr "Immagine 128" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_256 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_256 +msgid "Image 256" +msgstr "Immagine 256" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__image_512 +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image_consumer_mixin__image_512 +msgid "Image 512" +msgstr "Immagine 512" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image____last_update +msgid "Last Modified on" +msgstr "Ultima modifica il" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_uid +msgid "Last Updated by" +msgstr "Ultimo aggiornamento di" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__write_date +msgid "Last Updated on" +msgstr "Ultimo aggiornamento il" + +#. module: base_conditional_image +#: model:ir.model,name:base_conditional_image.model_conditional_image_consumer_mixin +msgid "Mixin for conditional images consumers" +msgstr "Mixin per l'impiego delle immagini condizionale" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__model_name +msgid "Model Name" +msgstr "Nome modello" + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__name +msgid "Name" +msgstr "Nome" + +#. module: base_conditional_image +#: model:ir.model.fields,help:base_conditional_image.field_conditional_image__selector +msgid "" +"Python expression used as selector when multiple images are usedfor the same" +" object. The variable `object` refers to the actual record on which the " +"expression will be executed. An empty expression will always return `True`." +msgstr "" +"Espressione Python usata come selettore quando più immagini vengono usate " +"per lo stesso oggetto. La variabile `object` si riferisce al record " +"effettivo su cui verrà eseguita l'espressione. Un'espressione vuota " +"restituirà sempre `True`." + +#. module: base_conditional_image +#: model:ir.model.fields,field_description:base_conditional_image.field_conditional_image__selector +#: model_terms:ir.ui.view,arch_db:base_conditional_image.view_conditional_image_form +msgid "Selector" +msgstr "Selettore" diff --git a/base_conditional_image/models/__init__.py b/base_conditional_image/models/__init__.py new file mode 100644 index 00000000000..e3eb58ecae5 --- /dev/null +++ b/base_conditional_image/models/__init__.py @@ -0,0 +1,2 @@ +from . import conditional_image_consumer_mixin +from . import conditional_image diff --git a/base_conditional_image/models/conditional_image.py b/base_conditional_image/models/conditional_image.py new file mode 100644 index 00000000000..37ed3bb049e --- /dev/null +++ b/base_conditional_image/models/conditional_image.py @@ -0,0 +1,27 @@ +# Copyright 2022 Camptocamp SA +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +from odoo import fields, models + + +class ConditionalImage(models.Model): + _name = "conditional.image" + _description = "Conditional Image" + _inherit = ["image.mixin"] + + name = fields.Char(required=True) + model_name = fields.Char(required=True) + selector = fields.Text( + help="Python expression used as selector when multiple images are used" + "for the same object. The variable `object` refers " + "to the actual record on which the expression will be executed. " + "An empty expression will always return `True`.", + ) + company_id = fields.Many2one( + "res.company", + "Company", + help="Company related check. If inherited object does not have a " + "`company_id` field, it will be ignored. " + "The check will first take the records with a company then, " + "if no match is found, the ones without a company.", + ) diff --git a/base_conditional_image/models/conditional_image_consumer_mixin.py b/base_conditional_image/models/conditional_image_consumer_mixin.py new file mode 100644 index 00000000000..b07f7bf7fae --- /dev/null +++ b/base_conditional_image/models/conditional_image_consumer_mixin.py @@ -0,0 +1,67 @@ +# Copyright 2022 Camptocamp SA +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html) + +from odoo import fields, models +from odoo.tools.safe_eval import safe_eval + + +class ConditionalImageConsumerMixin(models.AbstractModel): + _name = "conditional.image.consumer.mixin" + _description = "Mixin for conditional images consumers" + _inherit = "image.mixin" + + image_1920 = fields.Image(compute="_compute_images", store=False, readonly=True) + image_1024 = fields.Image(compute="_compute_images", store=False, readonly=True) + image_512 = fields.Image(compute="_compute_images", store=False, readonly=True) + image_256 = fields.Image(compute="_compute_images", store=False, readonly=True) + image_128 = fields.Image(compute="_compute_images", store=False, readonly=True) + + def _conditional_image_evaluate_selector(self, conditional_image): + self.ensure_one() + if conditional_image.selector: + if ( + conditional_image.company_id == self.company_id + or self.company_id + and not conditional_image.company_id + ): + return bool( + safe_eval(conditional_image.selector or "True", {"object": self}) + ) + return False + + def _compute_images(self): + if "company_id" in self._fields: + search_clause = [("model_name", "=", self._name)] + else: + # If inherited object doesn't have a `company_id` field, + # remove the items with a company defined and the related checks + search_clause = [ + ("model_name", "=", self._name), + ("company_id", "=", False), + ] + + conditional_images = self.env["conditional.image"].search( + search_clause, order="company_id, selector" + ) + + for record in self: + images_found = conditional_images.filtered( + lambda record, img: record._conditional_image_evaluate_selector(img) + ) + values = { + "image_1920": False, + "image_1024": False, + "image_512": False, + "image_256": False, + "image_128": False, + } + if images_found: + image = images_found[0] + values = { + "image_1920": image.image_1920, + "image_1024": image.image_1024, + "image_512": image.image_512, + "image_256": image.image_256, + "image_128": image.image_128, + } + record.update(values) diff --git a/base_conditional_image/pyproject.toml b/base_conditional_image/pyproject.toml new file mode 100644 index 00000000000..4231d0cccb3 --- /dev/null +++ b/base_conditional_image/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/base_conditional_image/readme/CONTRIBUTORS.md b/base_conditional_image/readme/CONTRIBUTORS.md new file mode 100644 index 00000000000..b83fffd9fda --- /dev/null +++ b/base_conditional_image/readme/CONTRIBUTORS.md @@ -0,0 +1,8 @@ +- [Camptocamp](https://camptocamp.com/): + - Patrick Tombez \ + - Denis Leemann \ + +- [Trobz](https://trobz.com): + - Son Ho \ +- [Heliconia Solutions Pvt. Ltd.](https://www.heliconia.io) + - Bhavesh Heliconia diff --git a/base_conditional_image/readme/CREDITS.md b/base_conditional_image/readme/CREDITS.md new file mode 100644 index 00000000000..6184200e1b7 --- /dev/null +++ b/base_conditional_image/readme/CREDITS.md @@ -0,0 +1,2 @@ +The migration of this module from 12.0 to 14.0 was financially supported +by Camptocamp diff --git a/base_conditional_image/readme/DESCRIPTION.md b/base_conditional_image/readme/DESCRIPTION.md new file mode 100644 index 00000000000..58e05b18746 --- /dev/null +++ b/base_conditional_image/readme/DESCRIPTION.md @@ -0,0 +1,12 @@ +This module extends the functionality of any model to support +conditional images (based on the record attributes) and to manage them +either globally or by company. + +The main goal behind this module is to avoid storing the same image +multiple times. For example, for every partner, there is a related image +(most of the time, it's the default one). With this module properly set +up, it will be stored only one time and you can change it whenever you +want for all partners. + +**WARNING**: this module cannot be used on the same objects using the +module base_multi_image. diff --git a/base_conditional_image/readme/INSTALL.md b/base_conditional_image/readme/INSTALL.md new file mode 100644 index 00000000000..d6697f45708 --- /dev/null +++ b/base_conditional_image/readme/INSTALL.md @@ -0,0 +1,12 @@ +The sole purpose of this module is to add an abstract model to be +inherited. So, you will not notice any changes on install. + +To develop using this module, you have to inherit the abstract model +conditional.image.consumer.mixin to the model that needs the conditional +images: + + class ResPartner(models.Model): + _inherit = ['res.partner', 'conditional.image.consumer.mixin'] + _name = 'res.partner' + +Then, configure how the images will be selected for each record. diff --git a/base_conditional_image/readme/USAGE.md b/base_conditional_image/readme/USAGE.md new file mode 100644 index 00000000000..4072dc1dde0 --- /dev/null +++ b/base_conditional_image/readme/USAGE.md @@ -0,0 +1,11 @@ +Go to *Technical Settings \> Settings \> Images* to configure all the +images. You can define images for specific objects, depending on the +attributes and the company of the object. + +The selector should return a boolean expression. All fields of the +object are available to compute the result. + +The system will first try to match an image with a company set up, then +with the ones without a company. If your object does not have a +company_id field, this check will be ignored and only images without a +company will be used. diff --git a/base_conditional_image/security/ir.model.access.csv b/base_conditional_image/security/ir.model.access.csv new file mode 100644 index 00000000000..0d9ca2bc728 --- /dev/null +++ b/base_conditional_image/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_conditional_image,Conditional Image,base_conditional_image.model_conditional_image,base.group_no_one,1,1,1,1 +access_conditional_image_users,Conditional Image Users,base_conditional_image.model_conditional_image,base.group_user,1,0,0,0 diff --git a/base_conditional_image/static/description/icon.png b/base_conditional_image/static/description/icon.png new file mode 100644 index 00000000000..3a0328b516c Binary files /dev/null and b/base_conditional_image/static/description/icon.png differ diff --git a/base_conditional_image/static/description/index.html b/base_conditional_image/static/description/index.html new file mode 100644 index 00000000000..1a42e4b008a --- /dev/null +++ b/base_conditional_image/static/description/index.html @@ -0,0 +1,484 @@ + + + + + +README.rst + + + +
+ + + +Odoo Community Association + +
+

Conditional Images

+ +

Beta License: AGPL-3 OCA/server-tools Translate me on Weblate Try me on Runboat

+

This module extends the functionality of any model to support +conditional images (based on the record attributes) and to manage them +either globally or by company.

+

The main goal behind this module is to avoid storing the same image +multiple times. For example, for every partner, there is a related image +(most of the time, it’s the default one). With this module properly set +up, it will be stored only one time and you can change it whenever you +want for all partners.

+

WARNING: this module cannot be used on the same objects using the +module base_multi_image.

+

Table of contents

+ +
+

Installation

+

The sole purpose of this module is to add an abstract model to be +inherited. So, you will not notice any changes on install.

+

To develop using this module, you have to inherit the abstract model +conditional.image.consumer.mixin to the model that needs the conditional +images:

+
+class ResPartner(models.Model):
+    _inherit = ['res.partner', 'conditional.image.consumer.mixin']
+    _name = 'res.partner'
+
+

Then, configure how the images will be selected for each record.

+
+
+

Usage

+

Go to Technical Settings > Settings > Images to configure all the +images. You can define images for specific objects, depending on the +attributes and the company of the object.

+

The selector should return a boolean expression. All fields of the +object are available to compute the result.

+

The system will first try to match an image with a company set up, then +with the ones without a company. If your object does not have a +company_id field, this check will be ignored and only images without a +company will be used.

+
+
+

Bug Tracker

+

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

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • Camptocamp
  • +
+
+
+

Contributors

+ +
+
+

Other credits

+

The migration of this module from 12.0 to 14.0 was financially supported +by Camptocamp

+
+
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

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

+

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

+

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

+
+
+
+
+ + diff --git a/base_conditional_image/views/image_view.xml b/base_conditional_image/views/image_view.xml new file mode 100644 index 00000000000..a5daabae26b --- /dev/null +++ b/base_conditional_image/views/image_view.xml @@ -0,0 +1,60 @@ + + + + conditional.image.tree + conditional.image + + + + + + + + + + + + conditional.image.form + conditional.image + +
+ + + + + + + + + + + + + +
+
+
+ + + Conditional Images + conditional.image + list,form + + + + Conditional Images + + + + +
diff --git a/base_multi_image/i18n/nl.po b/base_multi_image/i18n/nl.po index 1b97cfa4748..9309c869d5e 100644 --- a/base_multi_image/i18n/nl.po +++ b/base_multi_image/i18n/nl.po @@ -9,47 +9,50 @@ msgstr "" "Project-Id-Version: Odoo Server 10.0\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2017-12-01 02:10+0000\n" -"PO-Revision-Date: 2017-12-01 02:10+0000\n" -"Last-Translator: OCA Transbot , 2017\n" +"PO-Revision-Date: 2026-05-14 14:45+0000\n" +"Last-Translator: Bosd \n" "Language-Team: Dutch (https://www.transifex.com/oca/teams/23907/nl/)\n" "Language: nl\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: \n" -"Plural-Forms: nplurals=2; plural=(n != 1);\n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 5.15.2\n" #. module: base_multi_image #: model:ir.model,name:base_multi_image.model_base_multi_image_owner msgid " Wizard for base multi image " -msgstr "" +msgstr " Wizard voor basis multi-afbeeldingen " #. module: base_multi_image #: model:ir.model,name:base_multi_image.model_base_multi_image_image msgid " image model for multiple image functionality " -msgstr "" +msgstr " afbeeldingsmodel voor multi-afbeelding functionaliteit " #. module: base_multi_image #: code:addons/base_multi_image/models/image.py:0 #: model:ir.model.constraint,message:base_multi_image.constraint_base_multi_image_image_uniq_name_owner #, python-format msgid "A document can have only one image with the same name." -msgstr "" +msgstr "Een document kan slechts één afbeelding met dezelfde naam hebben." #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__attachment_id msgid "Attachment" -msgstr "" +msgstr "Bijlage" #. module: base_multi_image #: model_terms:ir.actions.act_window,help:base_multi_image.image_action msgid "Click to add an image attached to an specific record." msgstr "" +"Klik om een afbeelding toe te voegen die is gekoppeld aan een specifiek " +"record." #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__comments #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view msgid "Comments" -msgstr "" +msgstr "Opmerkingen" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__create_uid @@ -64,32 +67,32 @@ msgstr "Aangemaakt op" #. module: base_multi_image #: model:ir.model.fields.selection,name:base_multi_image.selection__base_multi_image_image__storage__db msgid "Database" -msgstr "" +msgstr "Database" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__display_name msgid "Display Name" -msgstr "Te tonen naam" +msgstr "Schermnaam" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__extension msgid "File extension" -msgstr "" +msgstr "Bestandsextensie" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__filename msgid "Filename" -msgstr "" +msgstr "Bestandsnaam" #. module: base_multi_image #: model:ir.model.fields.selection,name:base_multi_image.selection__base_multi_image_image__storage__filestore msgid "Filestore" -msgstr "" +msgstr "Bestandsopslag" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__image_main msgid "Full-sized image" -msgstr "" +msgstr "Volledige afbeelding" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__id @@ -99,33 +102,33 @@ msgstr "ID" #. module: base_multi_image #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view msgid "Image" -msgstr "" +msgstr "Afbeelding" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__path #: model:ir.model.fields,help:base_multi_image.field_base_multi_image_image__path msgid "Image path" -msgstr "" +msgstr "Afbeeldingspad" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__url msgid "Image remote URL" -msgstr "" +msgstr "Externe afbeeldings-URL" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__file_db_store msgid "Image stored in database" -msgstr "" +msgstr "Afbeelding opgeslagen in database" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__name msgid "Image title" -msgstr "" +msgstr "Afbeeldingstitel" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_owner__image_ids msgid "Images" -msgstr "" +msgstr "Afbeeldingen" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image____last_update @@ -147,17 +150,17 @@ msgstr "Laatst bijgewerkt op" #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_owner__image_main #, python-format msgid "Main image" -msgstr "" +msgstr "Hoofdafbeelding" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_owner__image_main_medium msgid "Medium image" -msgstr "" +msgstr "Middelgrote afbeelding" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__image_medium msgid "Medium-sized image" -msgstr "" +msgstr "Middelgrote afbeelding" #. module: base_multi_image #: model:ir.model.fields,help:base_multi_image.field_base_multi_image_image__image_medium @@ -171,7 +174,7 @@ msgstr "" #: model:ir.actions.act_window,name:base_multi_image.image_action #: model:ir.ui.menu,name:base_multi_image.image_menu msgid "Multi images" -msgstr "" +msgstr "Multi-afbeeldingen" #. module: base_multi_image #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view @@ -181,48 +184,48 @@ msgstr "Naam" #. module: base_multi_image #: model:ir.model.fields.selection,name:base_multi_image.selection__base_multi_image_image__storage__file msgid "OS file" -msgstr "" +msgstr "Besturingssysteembestand" #. module: base_multi_image #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view msgid "Options" -msgstr "" +msgstr "Opties" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__owner_id #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view msgid "Owner" -msgstr "" +msgstr "Eigenaar" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__owner_model msgid "Owner Model" -msgstr "" +msgstr "Eigenaarmodel" #. module: base_multi_image #: model_terms:ir.ui.view,arch_db:base_multi_image.image_form_view msgid "Preview" -msgstr "" +msgstr "Voorbeeld" #. module: base_multi_image #: model_terms:ir.ui.view,arch_db:base_multi_image.image_kanban_view msgid "Product Images" -msgstr "" +msgstr "Productafbeeldingen" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__owner_ref_id msgid "Referenced Owner" -msgstr "" +msgstr "Gerefereerde eigenaar" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__sequence msgid "Sequence" -msgstr "Reeks" +msgstr "Volgorde" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__show_technical msgid "Show Technical" -msgstr "" +msgstr "Toon technische details" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_owner__image_main_small @@ -244,24 +247,24 @@ msgstr "" #. module: base_multi_image #: model:ir.model.fields,field_description:base_multi_image.field_base_multi_image_image__storage msgid "Storage" -msgstr "" +msgstr "Opslag" #. module: base_multi_image #: model:ir.model.fields.selection,name:base_multi_image.selection__base_multi_image_image__storage__url msgid "URL" -msgstr "" +msgstr "URL" #. module: base_multi_image #: code:addons/base_multi_image/models/image.py:0 #, python-format msgid "You must provide a file path for the image." -msgstr "" +msgstr "U moet een bestandspad opgeven voor de afbeelding." #. module: base_multi_image #: code:addons/base_multi_image/models/image.py:0 #, python-format msgid "You must provide an URL for the image." -msgstr "" +msgstr "U moet een URL opgeven voor de afbeelding." #. module: base_multi_image #: code:addons/base_multi_image/models/image.py:0 diff --git a/base_name_search_improved/i18n/base_name_search_improved.pot b/base_name_search_improved/i18n/base_name_search_improved.pot index b82fc111c3e..6bb99ade4a0 100644 --- a/base_name_search_improved/i18n/base_name_search_improved.pot +++ b/base_name_search_improved/i18n/base_name_search_improved.pot @@ -209,6 +209,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/ca.po b/base_name_search_improved/i18n/ca.po index cc28057b011..478b8c2b838 100644 --- a/base_name_search_improved/i18n/ca.po +++ b/base_name_search_improved/i18n/ca.po @@ -224,6 +224,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/de.po b/base_name_search_improved/i18n/de.po index abef8c250ee..f5d0205b9e7 100644 --- a/base_name_search_improved/i18n/de.po +++ b/base_name_search_improved/i18n/de.po @@ -224,6 +224,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/es.po b/base_name_search_improved/i18n/es.po index 2ef869c9a15..084ddca3a89 100644 --- a/base_name_search_improved/i18n/es.po +++ b/base_name_search_improved/i18n/es.po @@ -250,6 +250,8 @@ msgstr "¿Búsqueda inteligente por nombre activada?" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/es_ES.po b/base_name_search_improved/i18n/es_ES.po index 8ce64f9084b..cef85fe50e3 100644 --- a/base_name_search_improved/i18n/es_ES.po +++ b/base_name_search_improved/i18n/es_ES.po @@ -224,6 +224,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/eu.po b/base_name_search_improved/i18n/eu.po index f932158c6bb..09a6b6346c1 100644 --- a/base_name_search_improved/i18n/eu.po +++ b/base_name_search_improved/i18n/eu.po @@ -222,6 +222,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/fi.po b/base_name_search_improved/i18n/fi.po index fe73336cd63..41ad521d6c6 100644 --- a/base_name_search_improved/i18n/fi.po +++ b/base_name_search_improved/i18n/fi.po @@ -222,6 +222,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/fr.po b/base_name_search_improved/i18n/fr.po index 6fa3d25283f..563adb27c74 100644 --- a/base_name_search_improved/i18n/fr.po +++ b/base_name_search_improved/i18n/fr.po @@ -222,6 +222,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/hr.po b/base_name_search_improved/i18n/hr.po index 9060cbdfa18..ee6067a084b 100644 --- a/base_name_search_improved/i18n/hr.po +++ b/base_name_search_improved/i18n/hr.po @@ -223,6 +223,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/hr_HR.po b/base_name_search_improved/i18n/hr_HR.po index 53dae688618..21a6c227184 100644 --- a/base_name_search_improved/i18n/hr_HR.po +++ b/base_name_search_improved/i18n/hr_HR.po @@ -224,6 +224,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/it.po b/base_name_search_improved/i18n/it.po index 914a6bebe52..fbec49a0b4d 100644 --- a/base_name_search_improved/i18n/it.po +++ b/base_name_search_improved/i18n/it.po @@ -248,6 +248,8 @@ msgstr "Ricerca nome intelligente abilitata?" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/nb_NO.po b/base_name_search_improved/i18n/nb_NO.po index fa97ff8da28..34cb3af9cab 100644 --- a/base_name_search_improved/i18n/nb_NO.po +++ b/base_name_search_improved/i18n/nb_NO.po @@ -223,6 +223,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/nl.po b/base_name_search_improved/i18n/nl.po index c545fb181d9..2482f8b6874 100644 --- a/base_name_search_improved/i18n/nl.po +++ b/base_name_search_improved/i18n/nl.po @@ -222,6 +222,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/pt_BR.po b/base_name_search_improved/i18n/pt_BR.po index bcbb689e65a..46c1343db06 100644 --- a/base_name_search_improved/i18n/pt_BR.po +++ b/base_name_search_improved/i18n/pt_BR.po @@ -225,6 +225,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/sl.po b/base_name_search_improved/i18n/sl.po index 1e9b5720c7c..ddf9e64fed7 100644 --- a/base_name_search_improved/i18n/sl.po +++ b/base_name_search_improved/i18n/sl.po @@ -224,6 +224,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/tr.po b/base_name_search_improved/i18n/tr.po index 25416f48bad..0bf816ab5a8 100644 --- a/base_name_search_improved/i18n/tr.po +++ b/base_name_search_improved/i18n/tr.po @@ -235,6 +235,8 @@ msgstr "Akıllı İsim Araması Etkin mi?" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/tr_TR.po b/base_name_search_improved/i18n/tr_TR.po index cd2616913f6..043155f4b81 100644 --- a/base_name_search_improved/i18n/tr_TR.po +++ b/base_name_search_improved/i18n/tr_TR.po @@ -223,6 +223,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_name_search_improved/i18n/zh_CN.po b/base_name_search_improved/i18n/zh_CN.po index d950dbd729d..3255292d841 100644 --- a/base_name_search_improved/i18n/zh_CN.po +++ b/base_name_search_improved/i18n/zh_CN.po @@ -223,6 +223,8 @@ msgstr "" #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_own__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_user__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_change_password_wizard__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image__smart_search +#: model:ir.model.fields,field_description:base_name_search_improved.field_conditional_image_consumer_mixin__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_decimal_precision__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_digest__smart_search #: model:ir.model.fields,field_description:base_name_search_improved.field_digest_tip__smart_search diff --git a/base_partition/i18n/tr.po b/base_partition/i18n/tr.po new file mode 100644 index 00000000000..4f86f42c263 --- /dev/null +++ b/base_partition/i18n/tr.po @@ -0,0 +1,32 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_partition +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 18.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2026-05-20 11:37+0000\n" +"Last-Translator: Betül Öğmen \n" +"Language-Team: none\n" +"Language: tr\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 5.15.2\n" + +#. module: base_partition +#: model:ir.model,name:base_partition.model_base +msgid "Base" +msgstr "Temel" + +#. module: base_partition +#. odoo-python +#: code:addons/base_partition/models/models.py:0 +msgid "" +"Either set up a '_default_batch_size' on the model or provide a batch_size " +"parameter." +msgstr "" +"Ya model üzerinde '_default_batch_size' ayarlayın ya da bir batch_size " +"parametresi sağlayın." diff --git a/base_search_fuzzy/i18n/nl.po b/base_search_fuzzy/i18n/nl.po index 13a522d3100..06a68c72ae2 100644 --- a/base_search_fuzzy/i18n/nl.po +++ b/base_search_fuzzy/i18n/nl.po @@ -9,14 +9,15 @@ msgstr "" "Project-Id-Version: Odoo Server 10.0c\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2017-01-14 04:21+0000\n" -"PO-Revision-Date: 2017-01-14 04:21+0000\n" -"Last-Translator: OCA Transbot , 2017\n" +"PO-Revision-Date: 2026-05-14 14:45+0000\n" +"Last-Translator: Bosd \n" "Language-Team: Dutch (https://www.transifex.com/oca/teams/23907/nl/)\n" "Language: nl\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: \n" -"Plural-Forms: nplurals=2; plural=(n != 1);\n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 5.15.2\n" #. module: base_search_fuzzy #: model:ir.model.fields,help:base_search_fuzzy.field_trgm_index__index_type @@ -25,6 +26,9 @@ msgid "" "search index type.See: https://www.postgresql.org/docs/current/textsearch-" "indexes.html" msgstr "" +"Citaat uit de PostgreSQL-documentatie: GIN-indexen zijn het voorkeurstype " +"voor tekstzoekindexen. Zie: https://www.postgresql.org/docs/current/" +"textsearch-indexes.html" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__create_uid @@ -39,7 +43,7 @@ msgstr "Aangemaakt op" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__display_name msgid "Display Name" -msgstr "Te tonen naam" +msgstr "Schermnaam" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__field_id @@ -49,12 +53,12 @@ msgstr "Veld" #. module: base_search_fuzzy #: model:ir.model.fields.selection,name:base_search_fuzzy.selection__trgm_index__index_type__gin msgid "GIN" -msgstr "" +msgstr "GIN" #. module: base_search_fuzzy #: model:ir.model.fields.selection,name:base_search_fuzzy.selection__trgm_index__index_type__gist msgid "GiST" -msgstr "" +msgstr "GiST" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__id @@ -64,12 +68,12 @@ msgstr "ID" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__index_name msgid "Index Name" -msgstr "" +msgstr "Indexnaam" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__index_type msgid "Index Type" -msgstr "" +msgstr "Indextype" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index____last_update @@ -89,7 +93,7 @@ msgstr "Laatst bijgewerkt op" #. module: base_search_fuzzy #: model:ir.model.fields,field_description:base_search_fuzzy.field_trgm_index__smart_search msgid "Smart Search" -msgstr "" +msgstr "Slim zoeken" #. module: base_search_fuzzy #: model:ir.model.fields,help:base_search_fuzzy.field_trgm_index__index_name @@ -99,22 +103,26 @@ msgid "" "this index is reused. If the index is located in another table then a number " "is added at the end of the index name." msgstr "" +"De indexnaam wordt automatisch gegenereerd als veldnaam_indextype_idx. Als " +"de index al bestaat en de index zich in dezelfde tabel bevindt, wordt deze " +"index hergebruikt. Als de index zich in een andere tabel bevindt, wordt een " +"nummer toegevoegd aan het einde van de indexnaam." #. module: base_search_fuzzy #. odoo-python #: code:addons/base_search_fuzzy/models/trgm_index.py:0 #, python-format msgid "The pg_trgm extension does not exists or cannot be installed." -msgstr "" +msgstr "De pg_trgm-extensie bestaat niet of kan niet worden geïnstalleerd." #. module: base_search_fuzzy #: model:ir.actions.act_window,name:base_search_fuzzy.trgm_index_action #: model:ir.model,name:base_search_fuzzy.model_trgm_index #: model:ir.ui.menu,name:base_search_fuzzy.trgm_index_menu msgid "Trigram Index" -msgstr "" +msgstr "Trigram-index" #. module: base_search_fuzzy #: model:ir.model.fields,help:base_search_fuzzy.field_trgm_index__field_id msgid "You can either select a field of type \"text\" or \"char\"." -msgstr "" +msgstr "U kunt een veld selecteren van het type \"text\" of \"char\"." diff --git a/module_auto_update/i18n/it.po b/module_auto_update/i18n/it.po index a0f41a4abcc..ff2f611a1fd 100644 --- a/module_auto_update/i18n/it.po +++ b/module_auto_update/i18n/it.po @@ -9,21 +9,21 @@ msgstr "" "Project-Id-Version: Odoo Server 10.0\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2017-07-21 02:43+0000\n" -"PO-Revision-Date: 2024-05-03 16:34+0000\n" -"Last-Translator: mymage \n" +"PO-Revision-Date: 2026-05-20 14:50+0000\n" +"Last-Translator: Francesco Foresti \n" "Language-Team: Italian (https://www.transifex.com/oca/teams/23907/it/)\n" "Language: it\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: \n" "Plural-Forms: nplurals=2; plural=n != 1;\n" -"X-Generator: Weblate 4.17\n" +"X-Generator: Weblate 5.15.2\n" #. module: module_auto_update #: model:ir.actions.server,name:module_auto_update.ir_module_module_upgrade_changed_checksum #: model:ir.ui.menu,name:module_auto_update.menu_ir_module_module_upgrade_changed_checksum msgid "Auto-Upgrade Modules" -msgstr "Aggiorna Moduli Automaticamente" +msgstr "Aggiorna moduli automaticamente" #. module: module_auto_update #. odoo-python diff --git a/setup/_metapackage/pyproject.toml b/setup/_metapackage/pyproject.toml index 25d7fe2e438..783bf6d717f 100644 --- a/setup/_metapackage/pyproject.toml +++ b/setup/_metapackage/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "odoo-addons-oca-server-tools" -version = "18.0.20260430.0" +version = "18.0.20260520.0" dependencies = [ "odoo-addon-attachment_delete_restrict==18.0.*", "odoo-addon-attachment_queue==18.0.*", @@ -9,6 +9,7 @@ dependencies = [ "odoo-addon-auditlog==18.0.*", "odoo-addon-auto_backup==18.0.*", "odoo-addon-autovacuum_message_attachment==18.0.*", + "odoo-addon-base_conditional_image==18.0.*", "odoo-addon-base_cron_exclusion==18.0.*", "odoo-addon-base_exception==18.0.*", "odoo-addon-base_fontawesome==18.0.*",