Skip to Content
Menu
This question has been flagged
2 Replies
8588 Zobrazenia

i have a many2one field. It is in a line(part of tree for one2many.)
<tree string="PLD" editable="bottom">                              
<field name="priority_set" />                        
<field name="shop_id"  domain="[('is_shop', '=', True),('usage','=','internal')]"    options="{'no_open':True,'no_create':1,'no_create_edit':1}" />          //shop_id = fields.many2one('stock.location')                    
<field name="temp_id"      options="{'no_open':True,'no_create':1,'no_create_edit':1}" />                          
</tree>
i want to select a shop for 1st line. In the 2nd line, the selected shop value should not be shown in the many2one dropdown. How can it be done?

Avatar
Zrušiť
Best Answer

this is from a custom application but does the job you want out of box in odoo way.

be careful: when you do changes on one2many columns with it, you might erase data!


in views

<record id="view_fc_animal_form" model="ir.ui.view">
<field name="name">fc.animal.tree</field>
<field name="model">fc.animal</field>
<field name="priority">4</field>
<field name="arch" type="xml">
<form string="Animals">
<sheet>
<group>
<field name="species_id" on_change="onchange_species_id(species_id, context)" options="{'no_create': True}"/>
</group>
<group>
<field name="breed_id" domain="[('species_id','=',species_id)]" options="{'no_create': True}" attrs="{'disabled': True}"/>
</group>


<group>
<group>
<!-- this is a sample for Selection/Boolean column. -->
<field name="gender" on_change="onchange_gender(gender, context)"/>

</group>

<group attrs="{'invisible': [('gender','not in', ('male', 'female'))]}">
<field name="castrated" attrs="{'invisible': [('gender','in', ('female'))]}"/>
<field name="sterilized" attrs="{'invisible': [('gender','in', ('male'))]}"/>
</group>
</group>
</sheet>
</form>
</field>
</record>


in model.

class Animal(models.Model):
_name = 'fc.animal'

# columns
species_id = fields.Many2one('fc.species', string='Species', index=True, required=True)
breed_id = fields.Many2one('fc.breed', string='Breed', index=True)

def onchange_species_id(self, cr, uid, ids, species_id, context=None):
if not species_id:
return {'value': {'species_id': False, 'breed_id': False}}

return {'value': {'breed_id': False}}


Avatar
Zrušiť
Best Answer

I was searching solution for the similar problem. Did you solve it yet?


Avatar
Zrušiť
Related Posts Replies Zobrazenia Aktivita
0
apr 17
6700
1
dec 19
9912
2
apr 24
2785
3
okt 22
21286
1
júl 20
8671