+ "phases_selectionnees": fields.function(_get_phases_selectionnees,
+ type="one2many",
+ obj="cmmi.projet.phase",
+ string="Phases sélectionnées"),
+ }
+
+ _defaults = {
+ "use_chantier": True,
+ "use_palier": True,
+ }
+
+
+ def create(self, cr, uid, vals, context=None):
+ project_id = osv.Model.create(self, cr, uid, vals, context=context)
+
+ # Récupération des ids de toutes les phases
+ phase_model = self.pool.get("cmmi.phase")
+ phases_ids = phase_model.search(cr, uid, [])
+
+ # Création des relations
+ projet_phase_model = self.pool.get("cmmi.projet.phase")
+ for phase_id in phases_ids:
+ projet_phase_model.create(
+ cr,
+ uid,
+ {
+ 'projet_id': project_id,
+ 'phase_id': phase_id,
+ 'selectionne': False,
+ }
+ )
+
+ return project_id
+
+
+ def action_add_domain(self, cr, uid, ids, context=None):
+ pass
+
+ def action_add_moe(self, cr, uid, ids, context=None):
+ pass
+
+ def action_add_moa(self, cr, uid, ids, context=None):
+ pass
+
+
+
+# ============================= PROJET DOMAINE ============================== #
+class ProjetDomaine(osv.Model):
+
+ _name = "cmmi.projet.domaine"
+
+ _description = "Rattachement des domaines a un projet."
+
+ def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ if isinstance(ids, (int, long)):
+ ids = [ids]
+ #return {i: r.domaine_id.name for i, r in
+ # zip(ids, self.browse(cr, uid, ids, context=context))}
+ 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 du domaine"),
+ "main": fields.boolean(string="Domaine principal ?"),
+ "project_id": fields.many2one("cmmi.projet",
+ string="Projet"),
+ "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}}
+
+
+
+# =============================== PROJET MOE ================================ #
+class ProjetMoe(osv.Model):
+ _name = "cmmi.projet.moe"
+
+ _description = "Rattachement des MOEs au projet."
+
+ 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.moe_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, # Permet d'enregistrer le champ.
+ string="Nom de la MOE"),
+ "main": fields.boolean(string="MOE principale ?"),
+ "project_id": fields.many2one("cmmi.projet",
+ string="Projet",
+ required=True),
+ "moe_id": fields.many2one("cmmi.mo.moe",
+ string="MOE",
+ required=True),
+ }
+
+ def onchange_main(self, cr, uid, ids, project, moe, main, context=None):
+ if not main:
+ return {'value': {'main': True},
+ 'warning': {
+ 'title' : "Integrity Warning",
+ 'message' : "Une des MOE doit être la MOE principale",
+ }
+ }
+ ids = self.search(
+ cr,
+ uid,
+ [
+ ('project_id', '=', project),
+ ('moe_id', '!=', moe),
+ ],
+ context=context,
+ )
+ current_id = self.search(
+ cr,
+ uid,
+ [
+ ('project_id', '=', project),
+ ('moe_id', '=', moe),
+ ],
+ 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}}
+
+
+
+# =============================== PROJET MOA ================================ #
+class ProjetMoa(osv.Model):
+ _name = "cmmi.projet.moa"
+
+ _description = "Rattachement des MOAs a une projet."
+
+ 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.moa_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 MOA"),
+ "main": fields.boolean(string="MOA principale ?"),
+ "project_id": fields.many2one("cmmi.projet",
+ string="Projet",
+ required=True),
+ "moa_id": fields.many2one("cmmi.mo.moa",
+ string="MOA",
+ required=True),
+ }
+
+ def onchange_main(self, cr, uid, ids, project, moa, main, context=None):
+ if not main:
+ return {'value': {'main': True},
+ 'warning': {
+ 'title' : "Integrity Warning",
+ 'message' : "Une des MOA doit être la MOA principale",
+ }
+ }
+ ids = self.search(
+ cr,
+ uid,
+ [
+ ('project_id', '=', project),
+ ('moa_id', '!=', moa),
+ ],
+ context=context,
+ )
+ current_id = self.search(
+ cr,
+ uid,
+ [
+ ('project_id', '=', project),
+ ('moa_id', '=', moa),
+ ],
+ 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}}
+
+
+
+# =============================== PROJET PHASE ============================== #
+class ProjetPhase(osv.Model):
+ _name = "cmmi.projet.phase"
+
+ _description = "Rattachement des Phases aux projets"
+
+ _columns = {
+ "name": fields.related("phase_id",
+ "name",
+ read_only=True,
+ type="char",
+ relation="cmmi.phase",
+ string="Nom de la phase"),
+ "phase_id": fields.many2one("cmmi.phase",
+ string="Phase",
+ required=True),
+ "projet_id": fields.many2one("cmmi.projet",
+ string="Projet",
+ required=True),
+ "selectionne": fields.boolean(string="Phase sélectionnée ?"),
+ }
+
+
+
+# ============================ PROJET TEAM MEMBER =========================== #
+class ProjetTeammember(osv.Model):
+ _name = "cmmi.projet.teammember"
+
+ _description = "Rattachement des Team members a un projet."
+
+ def _get_partner_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ if isinstance(ids, (int, long)):
+ ids = [ids]
+ return dict([(i, r.partner_id.name) for i, r in
+ zip(ids, self.browse(cr, uid, ids, context=context))])
+
+ def _get_project_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ if isinstance(ids, (int, long)):
+ ids = [ids]
+ return dict([(i, r.projet_id.name) for i, r in
+ zip(ids, self.browse(cr, uid, ids, context=context))])
+
+ _columns = {
+ "name": fields.function(_get_partner_name,
+ type='char',
+ store=True,
+ string="Nom du partner"),
+ "projet_name": fields.function(_get_project_name,
+ type='char',
+ store=True,
+ string="Nom du projet"),
+ "affecte": fields.integer(string="Affecté à"),
+ "depuis": fields.date(string="Depuis"),
+ "jusqua": fields.date(string="Jusqu'à"),
+ "projet_id": fields.many2one("cmmi.projet",
+ string="Projet",
+ required=True),
+ "partner_id": fields.many2one("res.partner",
+ string="Team Member",
+ required=True),