Taula de continguts

Pràctica en Django: Projectes d'investigació d'un institut de recerca

A la UB cada vegada es duen a terme més projectes de recerca per part del personal investigador de la universistat. Per tal de facilitar la gestió dels projectes i de l'assignació de personal ens demanen implementar un sistema que permeti fer el següent:

  1. Gestionar projectes i investigadors (operacions CRUD)
  2. Una pàgina per consultar el personal investigador d'un projecte.
  3. Una pàgina per consultar el detall d'hores imputades a cada projecte, per persona investigadora

Per tal minimitzar el temps de desenvolupament, utilitzarem el framework web Django i el seu admin panel.

El model de l'aplicació

Un investigador es caracteritza de moment només per un nom i un cognom.

Un projecte té un títol i un pressupost. També volem saber quin personal investigador hi està assignat i quin és l'investigador principal del projecte. El personal investigador pot estar assignat a diferents projectes a la vegada. De cada assignació en volem guardar la data d'inici i final.

, , , , , , , , ,

Crear el projecte

Aneu a l'article Django, creeu un projecte nou amb el seu Virtualenv.

Crear el model

Per començar cal crear el model (fitxer models.py) amb les següents classes:

Crea la classe Investigador al fitxer models.py. Recorda que del personal investigador en sabem com a mínim el nom i el cognom. Pots afegir altres atributs si ho consideres convenient.

Proposta implementació Project
Un projecte té associat un investigador principal (pi) que ha de ser un investigador. Si donem de baixa un investigador del nostre institut de recerca que està com a pi en un projecte, el projecte s'ha de quedar sense invertigador principal. Per altra banda, volem que la classe per gestionar les assignacions del personal investigador als projectes es digui Assignments, per tant caldrà indicar aquest nom al escriure la relació M2M (Many to Many).
models.py
class Project(models.Model):
    #completar amb les altres propietats
    investigators = models.ManyToManyField('Investigator',through='Assignment')
    pi = models.ForeignKey('Investigator', on_delete=models.SET_NULL, null=True, related_name='led_projects')
 

Cal completar el model amb la classe Assignment, per poder guardar la data d'entrada i sortida d'un investigador a un determinat projecte.

Proposta implementació Assignment
No s'ha de poder esborrar un projecte si té personal assignat o un investigador si aquest està assignat a algun projecte.
models.py
class Assignment(models.Model):
	project = models.ForeignKey(Project, on_delete=models.RESTRICT)
	investigator = models.ForeignKey(Investigator, on_delete=models.RESTRICT)
	datein = models.DateField()
	dateout = models.DateField(null=True, blank=True)
 


1. Gestionar projectes i investigadors (operacions CRUD)

Per poder visualitzar investigadors al taulell d'aministració cal registrar el model al fitxer admin.py

admin.py
from .models import Investigator
admin.site.register(Investigator)

Fes visible al panell d'administració els projectes.
Per tal de visualitzar la llista de projectes i investigadors cal que implementis el mètode:

__str__()

El panell d'administració per a gestionar projectes i investigadors ha de quedar de la següent manera:

2. Pàgina per consultar el personal investigador d'un projecte

3. Pàgina per consultar el detall d'hores imputades