Contributors mailing list archives

contributors@odoo-community.org

Browse archives

Avatar

Group based editable tree vs form pop up edition?

by "Raphaël Valyi" <rvalyi@akretion.com> - 27/03/2024 17:16:18
Dear Odoo experts,

CONTEXT:
More and more we are being contacted by companies who already use Odoo in some countries and would like to use it in Brazil too using the multi-companies approach. For service companies it's nearly possible (and a no go for industries because still too many side effects to deal with).

As we isolated most of the fiscal craziness in the l10n_br_fiscal module with its own tables and UI, we can inject the Brazilian localization pretty smoothly in other modules (specially through our l10n_br_account module mediation).

PROBLEM:
What is still a problem is about half of the users in a Brazilian company need to check or even edit many fiscal parameters in orders lines or invoice lines (see screenshots).

So we used to force the popup form based edition for these lines, that is we inherit the tree element and remove the editable="bottom" attribute. 

This however is very invasive for the non Brazilian users (because it is slower, because they might have customized the tree view). It also causes friction with some other modules that expect the default inline tree edition.

To fix this I recently made a POC where we would have advanced Brazilian fiscal groups where users would see use these popup forms while many users would use the default inline tree edition.

The problem is that it was using the groups_id in ir.ui.view to enable or not the group based view selection. But this feature has been removed in Odoo v16 to make the view caching easier:

Do you have an alternative solution to suggest for v16? As views will be cached without group consideration I imagine the selection between editable tree and form will need to happen on the client side... 
I tried to add a groups=... on the attribute tag that overrides the editable property but it is not effective...

Do you know a simple Javascript approach?
Alternatively would could have a button in the tree that would open the form popup. Ideally that would be a Javascript action that doesn't require saving the form (a server side action would also have trouble finding a proper non inline form view to inherit). Such a Javascript button to switch the view could even be a generic OCA module. Any pointers on how to do it?

Thank you.


--
Raphaël Valyi
Founder and consultant

Follow-Ups