from openerp.osv import osv, fields
+# ================================== PROJET ================================= #
class Projet(osv.Model):
_name = "cmmi.projet"
+ _description = "Table des projets."
+
def _get_main_domain(self, cr, uid, ids, field_name=None, arg=None, context=None):
if type(ids) in (int, float):
ids = [ids]
break
else:
result[project.id] = "Any MOE is selected as main MOE yet"
+ return result
+
+ def _get_phases_selectionnees(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ result = {}
+ for projet in self.browse(cr, uid, ids, context=context):
+ res = []
+ for phase in projet.phases:
+ #import pdb; pdb.set_trace()
+ if phase.selectionne:
+ res.append(phase.id)
+ result[projet.id] = res
return result
_columns = {
"name": fields.char(string="Title", size=64, required=True),
"description": fields.text(string="Description"),
+ "use_chantier": fields.boolean(string="Utilisation de la notion de chantier ?"),
+ "use_palier": fields.boolean(string="Utilisation de la notion de palier ?"),
+
# Backrefs
"domains": fields.one2many("cmmi.projet.domaine",
"project_id",
"evolutions": fields.one2many("cmmi.evolution",
"projet_id",
string="Evolutions"),
- # TODO: faire un champs fonction qui renvoie uniquement les domaines sélectionnés
-
+
# Champs fonction rapatriant les mo ou domaine principaux
"moe_id": fields.function(_get_main_moe,
type="string",
"main_domain": fields.function(_get_main_domain,
type="string",
string="Domaine principal"),
+ "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 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]
+# =============================== 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 {'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 {'value': {'main': True}}
+
+# =============================== PROJET PHASE ============================== #
class ProjetPhase(osv.Model):
_name = "cmmi.projet.phase"
_description = "Rattachement des Phases aux projets"
- 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.phase_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,
+ "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",
}
+
+# ============================ 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]