X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=projet.py;h=8758a83fa14e19aab6a9027af075941ef797575b;hb=9cd9465271cb7dae51c38210bc2fcb81ed4b771e;hp=1e1038d505d04bd696dc8be4875a8875cc935d2a;hpb=2f6c2cf41fa00107bfb118ebae2df008ff526c7e;p=OpenERP%2Fcmmi.git diff --git a/projet.py b/projet.py index 1e1038d..8758a83 100644 --- a/projet.py +++ b/projet.py @@ -56,6 +56,8 @@ class Projet(osv.Model): string="Structure principale"), } + def action_add_domain(self, cr, uid, ids, context=None): + pass class ProjetDomaine(osv.Model): @@ -80,3 +82,57 @@ class ProjetDomaine(osv.Model): "domaine_id": fields.many2one("cmmi.description.domaine", string="Domaine"), } + + def onchange_main(self, cr, uid, ids, project, domaine, main, context=None): + if not main: + return {'value': {'main': True}, + 'warning': { + 'title' : "Integrity Warning", + 'message' : "One of the domains should be the main domain", + } + } + ids = self.search( + cr, + uid, + [ + ('project_id', '=', project), + ('domaine_id', '!=', domaine), + ], + context=context, + ) + current_id = self.search( + cr, + uid, + [ + ('project_id', '=', project), + ('domaine_id', '=', domaine), + ], + context=context, + ) + self.write(cr, uid, ids, {'main': False}, context=context) + self.write(cr, uid, current_id, {'main': True}, context=context) + + return {'value': {'main': True}} + + + +class ProjetMoe(osv.Model): + _name = "cmmi.projet.moe" + + def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None): + if isinstance(ids, (int, long)): + ids = [ids] + return dict([(i, r.domaine_id.name) for i, r in + zip(ids, self.browse(cr, uid, ids, context=context))]) + + _columns = { + "name": fields.function(_get_name, + type='char', + store=True, + string="Nom de la MOE"), + "main": fields.boolean(string="MOE principale ?"), + "project_id": fields.many2one("cmmi.projet", + string="Projet"), + "moe_id": fields.many2one("cmmi.mo.moe", + string="MOE"), + } \ No newline at end of file