Skip to Content
Menu
You need to be registered to interact with the community.
This question has been flagged
1 Odgovori
11457 Prikazi

I am using Odoo v.11.

I was trying to customize the search bar for my model, so that the user can look for a string matching the name or the description:

        <record model="ir.ui.view" id="course_search_view">
<field name="name">course.search</field>
<field name="model">openacademy.course</field>
<field name="arch" type="xml">
<search>
<field name="name"/>
                    <field name="description"/>
</search>
</field>
</record>


This seems to work, but the user has to specify if he's looking for the name or the description. Instead, I'd like that the user could search for a string, and the software should return every record matching that string in the name or description.

My idea was to define a computed field in the model, as the simple concatenation of field+" "+description:

    
text_data = fields.Char(string="Textual data", compute='_text_data')

    @api.depends('name', 'description')
def _text_data(self):
for r in self:
r.text_data = str(r.name)+" "+str(r.description)

...and setup the search box to look for that field:

        <record model="ir.ui.view" id="course_search_view">
<field name="name">course.search</field>
<field name="model">openacademy.course</field>
<field name="arch" type="xml">
<search>
<field name="text_data"/>
</search>
</field>
</record>


But this does not appear to work: the search always succeed, and all the records are returned even if the search string appears nowhere in the names and descriptions...

Am I doing something wrong?

Thanks in advance for any help.






Avatar
Opusti

And now,when i want to search  picking_ids.carrier_tracking_ref in sale order view, my search data is 

1,2,3,4 

likt it. how to support it?

I am use odoo 16


Thank you!

Best Answer

This is possible without needing to create a new field.

This is how Sales Order search works, searching for Sales Order Name, Client Order Reference or Customer:

<field name="name" 
string="Sales Order"
filter_domain="['|','|',('name','ilike',self),('client_order_ref','ilike',self),('partner_id','child_of',self)]"/>

Just put something similar in your XML file - "self" represents what the user enters.

https://github.com/odoo/odoo/blob/11.0/addons/sale/views/sale_views.xml#L431

Avatar
Opusti
Avtor

This looks great, thank you very much!

I also keep forgetting that domains are ORM objects and things like ('partner_id.name' , 'ilike' , self) can also be done. Love the way the ODOO search works!!!

Related Posts Odgovori Prikazi Aktivnost
0
nov. 18
3198
1
jul. 25
1117
1
feb. 25
1611
0
sep. 23
2578
2
jun. 23
4604