mirror of
https://codeberg.org/Mo8it/AdvLabDB.git
synced 2024-12-20 23:41:20 +00:00
Changed PartExperiment to SemesterExperiment
This commit is contained in:
parent
6e153d9c09
commit
d30945461b
5 changed files with 63 additions and 64 deletions
File diff suppressed because one or more lines are too long
|
@ -20,7 +20,7 @@ from advlabdb.models import (
|
||||||
Group,
|
Group,
|
||||||
GroupExperiment,
|
GroupExperiment,
|
||||||
Part,
|
Part,
|
||||||
PartExperiment,
|
SemesterExperiment,
|
||||||
PartStudent,
|
PartStudent,
|
||||||
Role,
|
Role,
|
||||||
Semester,
|
Semester,
|
||||||
|
@ -106,7 +106,7 @@ class SemesterView(SecureModelView):
|
||||||
can_edit = False
|
can_edit = False
|
||||||
|
|
||||||
column_list = ["label", "parts"]
|
column_list = ["label", "parts"]
|
||||||
form_columns = ["semester_label", "year", "create_parts", "transfer_assistants"]
|
form_columns = ["semester_label", "year", "transfer_parts", "transfer_semester_experiments", "transfer_assistants"]
|
||||||
|
|
||||||
semesterLabels = ["WS", "SS"]
|
semesterLabels = ["WS", "SS"]
|
||||||
form_extra_fields = {
|
form_extra_fields = {
|
||||||
|
@ -114,13 +114,14 @@ class SemesterView(SecureModelView):
|
||||||
"Semester", choices=list(zip(semesterLabels, semesterLabels)), validators=[DataRequired()]
|
"Semester", choices=list(zip(semesterLabels, semesterLabels)), validators=[DataRequired()]
|
||||||
),
|
),
|
||||||
"year": TextField("Year", validators=[DataRequired()]),
|
"year": TextField("Year", validators=[DataRequired()]),
|
||||||
"create_parts": BooleanField(
|
"transfer_parts": BooleanField(
|
||||||
"Create parts:"
|
"Transfer parts from your current semester",
|
||||||
+ ", ".join(getConfig("partLabels"))
|
|
||||||
+ " and transfer part experiments from your current active semester:",
|
|
||||||
default=True,
|
default=True,
|
||||||
),
|
),
|
||||||
"transfer_assistants": BooleanField("Transfer Assistants from your current active semester:", default=False),
|
"transfer_semester_experiments": BooleanField(
|
||||||
|
"Transfer Semester Experiemnts from your current semester", default=True
|
||||||
|
),
|
||||||
|
"transfer_assistants": BooleanField("Transfer Assistants from your current active semester", default=True),
|
||||||
}
|
}
|
||||||
|
|
||||||
def create_model(self, form):
|
def create_model(self, form):
|
||||||
|
@ -147,22 +148,22 @@ class SemesterView(SecureModelView):
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
oldSemesterParts = userActiveSemester().parts
|
oldSemester = userActiveSemester()
|
||||||
|
|
||||||
setUserActiveSemester(model.id)
|
setUserActiveSemester(model.id)
|
||||||
|
|
||||||
if form.create_parts.data:
|
if form.transfer_parts.data:
|
||||||
model.createParts()
|
model.transferParts(oldSemester)
|
||||||
|
|
||||||
|
if form.transfer_semester_experiments.data:
|
||||||
try:
|
try:
|
||||||
for part in oldSemesterParts:
|
for semesterExperiment in oldSemester.semester_experiments:
|
||||||
for partExperiment in part.part_experiments:
|
newSemesterExperiment = SemesterExperiment(
|
||||||
newPartExperiment = PartExperiment(
|
experiment=semesterExperiment.experiment, semester=userActiveSemester()
|
||||||
experiment=partExperiment.experiment, part=partFromLabelInUserActiveSemester(part.label)
|
)
|
||||||
)
|
if form.transfer_assistants.data:
|
||||||
if form.transfer_assistants.data:
|
newSemesterExperiment.assistants = semesterExperiment.assistants
|
||||||
newPartExperiment.assistants = partExperiment.assistants
|
self.session.add(newSemesterExperiment)
|
||||||
self.session.add(newPartExperiment)
|
|
||||||
self.session.commit()
|
self.session.commit()
|
||||||
except Exception as ex:
|
except Exception as ex:
|
||||||
flash(ex, "error")
|
flash(ex, "error")
|
||||||
|
@ -172,12 +173,9 @@ class SemesterView(SecureModelView):
|
||||||
|
|
||||||
class PartView(SecureModelView):
|
class PartView(SecureModelView):
|
||||||
can_view_details = True
|
can_view_details = True
|
||||||
column_details_list = ["label", "semester", "part_experiments", "part_students", "groups"]
|
column_details_list = ["label", "semester", "part_students", "groups"]
|
||||||
form_columns = ["label", "semester"]
|
form_columns = ["label", "semester"]
|
||||||
|
|
||||||
partLabels = getConfig("partLabels")
|
|
||||||
form_choices = {"label": list(zip(partLabels, partLabels))}
|
|
||||||
|
|
||||||
def get_query(self):
|
def get_query(self):
|
||||||
return super().get_query().filter(Part.id.in_([part.id for part in userActiveSemester().parts]))
|
return super().get_query().filter(Part.id.in_([part.id for part in userActiveSemester().parts]))
|
||||||
|
|
||||||
|
@ -337,26 +335,23 @@ class ExperimentView(SecureModelView):
|
||||||
column_list = ["number", "name", "deprecated"]
|
column_list = ["number", "name", "deprecated"]
|
||||||
|
|
||||||
|
|
||||||
class PartExperimentView(SecureModelView):
|
class SemesterExperimentView(SecureModelView):
|
||||||
column_list = ["experiment", "part", "assistants"]
|
column_list = ["experiment", "semester", "assistants"]
|
||||||
|
|
||||||
partLabels = getConfig("partLabels")
|
|
||||||
column_filters = ["part"]
|
|
||||||
|
|
||||||
def get_query(self):
|
def get_query(self):
|
||||||
return super().get_query().filter(PartExperiment.part_id.in_([part.id for part in userActiveSemester().parts]))
|
return super().get_query().filter(SemesterExperiment.semester == userActiveSemester())
|
||||||
|
|
||||||
def get_count_query(self):
|
def get_count_query(self):
|
||||||
return (
|
return (
|
||||||
self.session.query(func.count("*"))
|
self.session.query(func.count("*"))
|
||||||
.select_from(self.model)
|
.select_from(self.model)
|
||||||
.filter(PartExperiment.part_id.in_([part.id for part in userActiveSemester().parts]))
|
.filter(SemesterExperiment.semester == userActiveSemester())
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class AssistantView(SecureModelView):
|
class AssistantView(SecureModelView):
|
||||||
can_view_details = True
|
can_view_details = True
|
||||||
column_list = ["first_name", "last_name", "email", "user", "part_experiments"]
|
column_list = ["first_name", "last_name", "email", "user", "semester_experiments"]
|
||||||
column_details_list = column_list + [
|
column_details_list = column_list + [
|
||||||
"phone_number",
|
"phone_number",
|
||||||
"mobile_phone_number",
|
"mobile_phone_number",
|
||||||
|
@ -371,10 +366,8 @@ class AssistantView(SecureModelView):
|
||||||
|
|
||||||
class GroupExperimentView(SecureModelView):
|
class GroupExperimentView(SecureModelView):
|
||||||
class CreateForm(Form):
|
class CreateForm(Form):
|
||||||
def partExperimentQueryFactory():
|
def semesterExperimentQueryFactory():
|
||||||
return PartExperiment.query.filter(
|
return SemesterExperiment.query.filter(SemesterExperiment.semester == userActiveSemester())
|
||||||
PartExperiment.part_id.in_([part.id for part in userActiveSemester().parts])
|
|
||||||
)
|
|
||||||
|
|
||||||
def assistantQueryFactory():
|
def assistantQueryFactory():
|
||||||
return Assistant.query.filter(
|
return Assistant.query.filter(
|
||||||
|
@ -384,9 +377,9 @@ class GroupExperimentView(SecureModelView):
|
||||||
group = QuerySelectField(
|
group = QuerySelectField(
|
||||||
"Group", query_factory=groupQueryFactory, validators=[DataRequired()], allow_blank=True, blank_text="-"
|
"Group", query_factory=groupQueryFactory, validators=[DataRequired()], allow_blank=True, blank_text="-"
|
||||||
)
|
)
|
||||||
part_experiment = QuerySelectField(
|
semester_experiment = QuerySelectField(
|
||||||
"Part Experiment",
|
"Semester Experiment",
|
||||||
query_factory=partExperimentQueryFactory,
|
query_factory=semesterExperimentQueryFactory,
|
||||||
validators=[DataRequired()],
|
validators=[DataRequired()],
|
||||||
allow_blank=True,
|
allow_blank=True,
|
||||||
blank_text="-",
|
blank_text="-",
|
||||||
|
@ -414,8 +407,8 @@ class GroupExperimentView(SecureModelView):
|
||||||
|
|
||||||
form = CreateForm
|
form = CreateForm
|
||||||
|
|
||||||
column_list = ["group", "part_experiment", "appointments", "experiment_marks"]
|
column_list = ["group", "semester_experiment", "appointments", "experiment_marks"]
|
||||||
column_filters = ["group", "part_experiment.experiment", "appointments"]
|
column_filters = ["group", "semester_experiment.experiment", "appointments"]
|
||||||
|
|
||||||
def get_query(self):
|
def get_query(self):
|
||||||
return (
|
return (
|
||||||
|
@ -455,7 +448,7 @@ admin.add_view(PartStudentView(PartStudent, db.session))
|
||||||
admin.add_view(GroupView(Group, db.session))
|
admin.add_view(GroupView(Group, db.session))
|
||||||
admin.add_view(GroupExperimentView(GroupExperiment, db.session))
|
admin.add_view(GroupExperimentView(GroupExperiment, db.session))
|
||||||
admin.add_view(ExperimentView(Experiment, db.session))
|
admin.add_view(ExperimentView(Experiment, db.session))
|
||||||
admin.add_view(PartExperimentView(PartExperiment, db.session))
|
admin.add_view(SemesterExperimentView(SemesterExperiment, db.session))
|
||||||
admin.add_view(AssistantView(Assistant, db.session))
|
admin.add_view(AssistantView(Assistant, db.session))
|
||||||
admin.add_view(AppointmentView(Appointment, db.session))
|
admin.add_view(AppointmentView(Appointment, db.session))
|
||||||
admin.add_view(PartView(Part, db.session))
|
admin.add_view(PartView(Part, db.session))
|
||||||
|
@ -465,7 +458,7 @@ admin.add_view(UserView(User, db.session))
|
||||||
admin.add_view(RoleView(Role, db.session))
|
admin.add_view(RoleView(Role, db.session))
|
||||||
|
|
||||||
with app.app_context():
|
with app.app_context():
|
||||||
semesters = Semester.query.all()[::-1]
|
semesters = Semester.query.order_by(Semester.id)
|
||||||
for semester in semesters:
|
for semester in semesters:
|
||||||
admin.add_link(
|
admin.add_link(
|
||||||
MenuLink(
|
MenuLink(
|
||||||
|
|
|
@ -58,7 +58,7 @@ class Group(db.Model):
|
||||||
class GroupExperiment(db.Model):
|
class GroupExperiment(db.Model):
|
||||||
# An experiment specified to a group
|
# An experiment specified to a group
|
||||||
id = db.Column(db.Integer, primary_key=True)
|
id = db.Column(db.Integer, primary_key=True)
|
||||||
part_experiment_id = db.Column(db.Integer, db.ForeignKey("part_experiment.id"), nullable=False)
|
semester_experiment_id = db.Column(db.Integer, db.ForeignKey("semester_experiment.id"), nullable=False)
|
||||||
group_id = db.Column(db.Integer, db.ForeignKey("group.id"), nullable=False)
|
group_id = db.Column(db.Integer, db.ForeignKey("group.id"), nullable=False)
|
||||||
appointments = db.relationship("Appointment", backref="group_experiment", lazy=True)
|
appointments = db.relationship("Appointment", backref="group_experiment", lazy=True)
|
||||||
experiment_marks = db.relationship("ExperimentMark", backref="group_experiment", lazy=True)
|
experiment_marks = db.relationship("ExperimentMark", backref="group_experiment", lazy=True)
|
||||||
|
@ -78,29 +78,29 @@ class Experiment(db.Model):
|
||||||
oral_weighting = db.Column(db.Float, nullable=False)
|
oral_weighting = db.Column(db.Float, nullable=False)
|
||||||
protocol_weighting = db.Column(db.Float, nullable=False)
|
protocol_weighting = db.Column(db.Float, nullable=False)
|
||||||
final_weighting = db.Column(db.Float, nullable=False)
|
final_weighting = db.Column(db.Float, nullable=False)
|
||||||
part_experiments = db.relationship("PartExperiment", backref="experiment", lazy=True)
|
semester_experiments = db.relationship("SemesterExperiment", backref="experiment", lazy=True)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return f"<Exp {self.number}>"
|
return f"<Exp {self.number}>"
|
||||||
|
|
||||||
|
|
||||||
# Helper table for the many to many relationship between Assistant and PartExperiment
|
# Helper table for the many to many relationship between Assistant and SemesterExperiment
|
||||||
experiment_assistant = db.Table(
|
experiment_assistant = db.Table(
|
||||||
"experiment_assistant",
|
"experiment_assistant",
|
||||||
db.Column("part_experiment_id", db.Integer, db.ForeignKey("part_experiment.id"), primary_key=True),
|
db.Column("semester_experiment_id", db.Integer, db.ForeignKey("semester_experiment.id"), primary_key=True),
|
||||||
db.Column("assistant_id", db.Integer, db.ForeignKey("assistant.id"), primary_key=True),
|
db.Column("assistant_id", db.Integer, db.ForeignKey("assistant.id"), primary_key=True),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class PartExperiment(db.Model):
|
class SemesterExperiment(db.Model):
|
||||||
# An experiment in a specific part
|
# An experiment in a specific part
|
||||||
id = db.Column(db.Integer, primary_key=True)
|
id = db.Column(db.Integer, primary_key=True)
|
||||||
experiment_id = db.Column(db.Integer, db.ForeignKey("experiment.id"), nullable=False)
|
experiment_id = db.Column(db.Integer, db.ForeignKey("experiment.id"), nullable=False)
|
||||||
part_id = db.Column(db.Integer, db.ForeignKey("part.id"), nullable=False)
|
semester_id = db.Column(db.Integer, db.ForeignKey("semester.id"), nullable=False)
|
||||||
assistants = db.relationship(
|
assistants = db.relationship(
|
||||||
"Assistant", secondary=experiment_assistant, lazy=True, backref=db.backref("part_experiments", lazy=True)
|
"Assistant", secondary=experiment_assistant, lazy=True, backref=db.backref("semester_experiments", lazy=True)
|
||||||
)
|
)
|
||||||
group_experiments = db.relationship("GroupExperiment", backref="part_experiment", lazy=True)
|
group_experiments = db.relationship("GroupExperiment", backref="semester_experiment", lazy=True)
|
||||||
|
|
||||||
|
|
||||||
class Assistant(db.Model):
|
class Assistant(db.Model):
|
||||||
|
@ -132,7 +132,6 @@ class Part(db.Model):
|
||||||
id = db.Column(db.Integer, primary_key=True)
|
id = db.Column(db.Integer, primary_key=True)
|
||||||
label = db.Column(db.String(100), nullable=False) # A/1, A/2, B/1, B/2
|
label = db.Column(db.String(100), nullable=False) # A/1, A/2, B/1, B/2
|
||||||
semester_id = db.Column(db.Integer, db.ForeignKey("semester.id"), nullable=False)
|
semester_id = db.Column(db.Integer, db.ForeignKey("semester.id"), nullable=False)
|
||||||
part_experiments = db.relationship("PartExperiment", backref="part", lazy=True)
|
|
||||||
part_students = db.relationship("PartStudent", backref="part", lazy=True)
|
part_students = db.relationship("PartStudent", backref="part", lazy=True)
|
||||||
groups = db.relationship("Group", backref="part", lazy=True)
|
groups = db.relationship("Group", backref="part", lazy=True)
|
||||||
|
|
||||||
|
@ -144,14 +143,21 @@ class Semester(db.Model):
|
||||||
id = db.Column(db.Integer, primary_key=True)
|
id = db.Column(db.Integer, primary_key=True)
|
||||||
label = db.Column(db.String(100), nullable=False, unique=True) # WS2122 for example
|
label = db.Column(db.String(100), nullable=False, unique=True) # WS2122 for example
|
||||||
parts = db.relationship("Part", backref="semester", lazy=True)
|
parts = db.relationship("Part", backref="semester", lazy=True)
|
||||||
|
semester_experiments = db.relationship("SemesterExperiment", backref="semester", lazy=True)
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return f"<{self.label}>"
|
return f"<{self.label}>"
|
||||||
|
|
||||||
def createParts(self):
|
def transferParts(self, oldSemester):
|
||||||
try:
|
try:
|
||||||
for partLabel in getConfig("partLabels"):
|
if oldSemester:
|
||||||
|
partLabels = [part.label for part in oldSemester.parts]
|
||||||
|
else:
|
||||||
|
partLabels = getConfig("defaultPartLabels")
|
||||||
|
|
||||||
|
for partLabel in partLabels:
|
||||||
db.session.add(Part(label=partLabel, semester=self))
|
db.session.add(Part(label=partLabel, semester=self))
|
||||||
|
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
except Exception as ex:
|
except Exception as ex:
|
||||||
flash(ex, "error")
|
flash(ex, "error")
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"partLabels": [
|
"defaultPartLabels": [
|
||||||
"A/1",
|
"A/1",
|
||||||
"A/2",
|
"A/2",
|
||||||
"A/m",
|
"A/m",
|
||||||
|
|
20
testDB.py
20
testDB.py
|
@ -15,8 +15,8 @@ with app.app_context():
|
||||||
db.session.add(sem1)
|
db.session.add(sem1)
|
||||||
db.session.add(sem2)
|
db.session.add(sem2)
|
||||||
|
|
||||||
sem1.createParts()
|
sem1.transferParts(None)
|
||||||
sem2.createParts()
|
sem2.transferParts(None)
|
||||||
|
|
||||||
parta1 = sem2.parts[0]
|
parta1 = sem2.parts[0]
|
||||||
partb2 = sem2.parts[1]
|
partb2 = sem2.parts[1]
|
||||||
|
@ -70,14 +70,14 @@ with app.app_context():
|
||||||
db.session.add(ex1)
|
db.session.add(ex1)
|
||||||
db.session.add(ex2)
|
db.session.add(ex2)
|
||||||
|
|
||||||
px1 = PartExperiment(experiment=ex1, part=parta1)
|
sx1 = SemesterExperiment(experiment=ex1, semester=sem2)
|
||||||
px2 = PartExperiment(experiment=ex2, part=partb2)
|
sx2 = SemesterExperiment(experiment=ex2, semester=sem2)
|
||||||
|
|
||||||
db.session.add(px1)
|
db.session.add(sx1)
|
||||||
db.session.add(px2)
|
db.session.add(sx2)
|
||||||
|
|
||||||
gx1 = GroupExperiment(part_experiment=px1, group=g1)
|
gx1 = GroupExperiment(semester_experiment=sx1, group=g1)
|
||||||
gx2 = GroupExperiment(part_experiment=px2, group=g2)
|
gx2 = GroupExperiment(semester_experiment=sx2, group=g2)
|
||||||
|
|
||||||
db.session.add(gx1)
|
db.session.add(gx1)
|
||||||
db.session.add(gx2)
|
db.session.add(gx2)
|
||||||
|
@ -100,8 +100,8 @@ with app.app_context():
|
||||||
)
|
)
|
||||||
as2 = Assistant(first_name="As2", last_name="l", email="test2@test.com", user=us2)
|
as2 = Assistant(first_name="As2", last_name="l", email="test2@test.com", user=us2)
|
||||||
|
|
||||||
as1.part_experiments.append(px1)
|
as1.semester_experiments.append(sx1)
|
||||||
as2.part_experiments.append(px2)
|
as2.semester_experiments.append(sx2)
|
||||||
|
|
||||||
db.session.add(as1)
|
db.session.add(as1)
|
||||||
db.session.add(as2)
|
db.session.add(as2)
|
||||||
|
|
Loading…
Reference in a new issue