X-Git-Url: http://git.inspyration.org/?a=blobdiff_plain;f=projet.py;h=8758a83fa14e19aab6a9027af075941ef797575b;hb=9cd9465271cb7dae51c38210bc2fcb81ed4b771e;hp=7defaf7b2b9f8ed934f088dac332471fb8bbac4d;hpb=8196a058cccc1ef7544c8e3b53a0e423d2974340;p=OpenERP%2Fcmmi.git diff --git a/projet.py b/projet.py index 7defaf7..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): @@ -69,9 +71,6 @@ class ProjetDomaine(osv.Model): return dict([(i, r.domaine_id.name) for i, r in zip(ids, self.browse(cr, uid, ids, context=context))]) - def _set_name(self, cr, uid, _id, name, value, arg=None, context=None): - self.write(cr, uid, _id, {name: value}, context) - _columns = { "name": fields.function(_get_name, type='char', @@ -83,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