Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
2e22397
Add module custom_image
Oct 2, 2018
a698d62
Apply suggestions from code review
p-tombez Nov 14, 2019
4a4e7bf
[FIX][12.0] base_conditional_image: Fix descriptions and strings
etobella Feb 20, 2020
c257564
base_conditional_image 12.0.1.0.1
OCA-git-bot Feb 20, 2020
32185c1
[IMP] base_conditional_image: black, isort, prettier
Dec 19, 2021
90205e3
[14.0][MIG] base_conditional_image: Migration to 14.0
Dec 20, 2021
4bf491b
[IMP] base_conditional_image: black, isort, prettier
leemannd Jul 12, 2022
e42b79b
[MIG] base_conditional_image: Migration to 15.0
leemannd Jul 12, 2022
d525614
Added translation using Weblate (Spanish (Argentina))
ibuioli Oct 9, 2022
297d18d
[MIG] base_conditional_image: Migration to 16
polqubiq Jun 5, 2023
837f12c
[UPD] Update base_conditional_image.pot
Sep 4, 2024
ec68d31
[BOT] post-merge updates
OCA-git-bot Sep 4, 2024
c18dd1f
Update translation files
weblate Sep 4, 2024
824e1ca
Added translation using Weblate (Italian)
mymage Sep 6, 2024
0c585fa
Translated using Weblate (Italian)
mymage Sep 9, 2024
982afa1
Translated using Weblate (Italian)
mymage Oct 24, 2024
6281cc4
[IMP] base_conditional_image: pre-commit auto fixes
BhaveshHeliconia Apr 4, 2025
354c730
[MIG] base_conditional_image: Migration to 18.0
BhaveshHeliconia Apr 4, 2025
79aabff
Translated using Weblate (Dutch)
bosd May 14, 2026
32b1b71
Translated using Weblate (Dutch)
bosd May 14, 2026
8b33ce1
Added translation using Weblate (Turkish)
bo-eska May 20, 2026
19854aa
Translated using Weblate (Turkish)
bo-eska May 20, 2026
dd8fb9e
Merge PR #3253 into 18.0
OCA-git-bot May 20, 2026
94d438e
[UPD] Update autovacuum_message_attachment.pot
May 20, 2026
3c53a03
[UPD] Update base_conditional_image.pot
May 20, 2026
d380ba5
[UPD] Update base_name_search_improved.pot
May 20, 2026
529187c
[BOT] post-merge updates
OCA-git-bot May 20, 2026
d19a616
Update translation files
weblate May 20, 2026
4c4f695
Update translation files
weblate May 20, 2026
9fcbf77
Translated using Weblate (Italian)
francesco-ooops May 20, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -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 | <a href='https://github.com/florian-dacosta'><img src='https://github.com/florian-dacosta.png' width='32' height='32' style='border-radius:50%;' alt='florian-dacosta'/></a> | 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 | <a href='https://github.com/LoisRForgeFlow'><img src='https://github.com/LoisRForgeFlow.png' width='32' height='32' style='border-radius:50%;' alt='LoisRForgeFlow'/></a> <a href='https://github.com/ChrisOForgeFlow'><img src='https://github.com/ChrisOForgeFlow.png' width='32' height='32' style='border-radius:50%;' alt='ChrisOForgeFlow'/></a> | Allow you to select scheduled actions that should not run simultaneously.
[base_exception](base_exception/) | 18.0.1.1.1 | <a href='https://github.com/hparfr'><img src='https://github.com/hparfr.png' width='32' height='32' style='border-radius:50%;' alt='hparfr'/></a> <a href='https://github.com/sebastienbeau'><img src='https://github.com/sebastienbeau.png' width='32' height='32' style='border-radius:50%;' alt='sebastienbeau'/></a> | 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.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 2 additions & 0 deletions autovacuum_message_attachment/i18n/ca.po
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 2 additions & 0 deletions autovacuum_message_attachment/i18n/es.po
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 2 additions & 0 deletions autovacuum_message_attachment/i18n/es_AR.po
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 2 additions & 0 deletions autovacuum_message_attachment/i18n/fr.po
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
2 changes: 2 additions & 0 deletions autovacuum_message_attachment/i18n/it.po
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
141 changes: 141 additions & 0 deletions base_conditional_image/README.rst
Original file line number Diff line number Diff line change
@@ -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 <https://github.com/OCA/server-tools/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 <https://github.com/OCA/server-tools/issues/new?body=module:%20base_conditional_image%0Aversion:%2018.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

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

Credits
=======

Authors
-------

* Camptocamp

Contributors
------------

- `Camptocamp <https://camptocamp.com/>`__:

- Patrick Tombez <patrick.tombez@camptocamp.com>
- Denis Leemann <denis.leemann@camptocamp.com>

- `Trobz <https://trobz.com>`__:

- Son Ho <sonhd@trobz.com>

- `Heliconia Solutions Pvt. Ltd. <https://www.heliconia.io>`__

- 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 <https://github.com/OCA/server-tools/tree/18.0/base_conditional_image>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
1 change: 1 addition & 0 deletions base_conditional_image/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
20 changes: 20 additions & 0 deletions base_conditional_image/__manifest__.py
Original file line number Diff line number Diff line change
@@ -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,
}
128 changes: 128 additions & 0 deletions base_conditional_image/i18n/base_conditional_image.pot
Original file line number Diff line number Diff line change
@@ -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 ""
Loading
Loading