from openerp.osv import osv, fields
+# ================================== PROJET ================================= #
class Projet(osv.Model):
_name = "cmmi.projet"
- _domains = {
- 'moe': [('role_mo_id.type_mo', '=', "MOE")],
- 'moa': [('role_mo_id.type_mo', '=', "MOA")],
- }
+ _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]
+
+ projects = self.browse(cr, uid, ids, context=context)
+
+ result = {}
+
+ for project in projects:
+ for domain in project.domains:
+ if domain.main:
+ result[project.id] = domain.name
+ break
+ else:
+ result[project.id] = "Any domain is selected as main domain yet"
+
+ return result
+
+
+ def _get_main_moa(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ if type(ids) in (int, float):
+ ids = [ids]
+
+ projects = self.browse(cr, uid, ids, context=context)
+
+ result = {}
+
+ for project in projects:
+ for moa in project.moa_ids:
+ if moa.main:
+ result[project.id] = moa.name
+ break
+ else:
+ result[project.id] = "Any MOA is selected as main MOA yet"
+
+ return result
+
+
+ def _get_main_moe(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ if type(ids) in (int, float):
+ ids = [ids]
+
+ projects = self.browse(cr, uid, ids, context=context)
+
+ result = {}
+
+ for project in projects:
+ for moe in project.moe_ids:
+ if moe.main:
+ result[project.id] = moe.name
+ 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"),
- "domaines": fields.one2many("cmmi.projet.domaine",
+ "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",
string="Domaines"),
- "structures": fields.many2many("cmmi.mo.structure",
- string="Structures"),
- "structures_moe": fields.many2many("cmmi.mo.structure",
- string="Structures",
- domain=_domains['moe']),
- "structures_moa": fields.many2many("cmmi.mo.structure",
- string="Structures",
- domain=_domains['moa']),
- "team_members": fields.many2many("cmmi.partner.teammember",
- "cmmi_projet_teammember_rel",
+ "moe_ids": fields.one2many("cmmi.projet.moe",
+ "project_id",
+ string="MOEs"),
+ "moa_ids": fields.one2many("cmmi.projet.moa",
+ "project_id",
+ string="MOAs"),
+ "team_members": fields.one2many("cmmi.projet.teammember",
"projet_id",
- "partner_id",
string="Team Members"),
"modules": fields.one2many("cmmi.description.module",
"projet_id",
"evolutions": fields.one2many("cmmi.evolution",
"projet_id",
string="Evolutions"),
- "moe_id": fields.many2one("cmmi.mo.moe", string="MoE", required=True),
- "moa_id": fields.many2one("cmmi.mo.moa", string="MoA", required=True),
- "main_domain": fields.many2one("cmmi.description.domaine",
+
+ # Champs fonction rapatriant les mo ou domaine principaux
+ "moe_id": fields.function(_get_main_moe,
+ type="string",
+ string="MOE principale"),
+ "moa_id": fields.function(_get_main_moa,
+ type="string",
+ string="MOA principale"),
+ "main_domain": fields.function(_get_main_domain,
+ type="string",
string="Domaine principal"),
- "main_structure": fields.many2one("cmmi.mo.structure",
- string="Structure principale"),
+ "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)
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]
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.moe"
+ _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)):
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"
- def _get_name(self, cr, uid, ids, field_name=None, arg=None, context=None):
+ _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.phase_id.name) for i, r in
+ 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_name,
+ "name": fields.function(_get_partner_name,
type='char',
store=True,
- string="Nom de la phase"),
- "selectionne": fields.boolean(string="Phase sélectionnée ?"),
+ 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),
- "phase_id": fields.many2one("cmmi.phase",
- string="Phase",
+ "partner_id": fields.many2one("res.partner",
+ string="Team Member",
required=True),
- }
\ No newline at end of file
+ }