Skip to Content
Meniu
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
Această întrebare a fost marcată
4 Răspunsuri
4360 Vizualizări

Hello guys.

I have a compute field and then I would like to put a search for this field in a view.

I found the documentation in odoov13 that looks  possible :

upper_name = field.Char(compute='_compute_upper', search='_search_upper')

def _search_upper(self, operator, value):
    if operator == 'like':
        operator = 'ilike'
    return [('name', operator, value)]



Then I tried to apply on my code :

sub_state = fields.Char(compute='_get_substate', search='_search_sub_state')



def _get_substate(self):
for batch in self:
batch.sub_state = 'wait'

@api.model
def _search_sub_state(self, operator, operand):
return [('name', operator, operand)]


However I can see in the screen the custom filter with the sub_state but when I put a value there it is  returning nothing.

Do you would know what is missing on my code?

Thank you so much
    

Imagine profil
Abandonează
Cel mai bun răspuns

Hi,

Try to follow steps like in the below blog.

https://www.cybrosys.com/blog/how-to-add-a-search-filter-for-computed-fields-in-odoo-15

Regards

Imagine profil
Abandonează
Cel mai bun răspuns

Hello, 
Remove the @api.model above the _search_sub_state method.



Imagine profil
Abandonează
Cel mai bun răspuns

is your computed field stored? If it's not stored, the value only exists in the view, and not in the database where Odoo is searching.

Imagine profil
Abandonează
Related Posts Răspunsuri Vizualizări Activitate
1
iun. 25
15274
3
apr. 25
5394
1
nov. 24
1176
2
iul. 24
2292
0
feb. 24
28