Passa al contenuto
Menu
È necessario essere registrati per interagire con la community.
La domanda è stata contrassegnata
2 Risposte
8606 Visualizzazioni

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
Abbandona
Risposta migliore

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
Abbandona
Risposta migliore

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


Avatar
Abbandona
Post correlati Risposte Visualizzazioni Attività
0
apr 17
6712
1
dic 19
9920
2
apr 24
2802
3
ott 22
21293
1
lug 20
8714