1
0
Fork 0
mirror of https://codeberg.org/Mo8it/AdvLabDB.git synced 2024-11-08 21:21:06 +00:00
AdvLabDB/advlabdb/assistantModelViews.py

190 lines
5.9 KiB
Python
Raw Normal View History

from flask import flash
2022-02-23 18:37:09 +00:00
from flask_admin import expose
from flask_admin.contrib.sqla.fields import QuerySelectField, QuerySelectMultipleField
2022-02-23 19:36:29 +00:00
from flask_security import admin_change_password, current_user
from sqlalchemy import and_
2021-11-29 19:22:10 +00:00
from wtforms import BooleanField, Form, RadioField, SelectField, StringField
from wtforms.fields import DateField
from wtforms.validators import NumberRange
2021-07-30 00:50:49 +00:00
from advlabdb import assistantSpace, db
2022-02-23 18:37:09 +00:00
from advlabdb.customClasses import SecureAssistantBaseView, SecureAssistantModelView
2021-07-30 12:20:54 +00:00
from advlabdb.exceptions import DataBaseException, ModelViewException
2021-07-30 00:50:49 +00:00
from advlabdb.models import (
Appointment,
Assistant,
Experiment,
ExperimentMark,
Group,
GroupExperiment,
Part,
PartStudent,
2021-07-30 12:20:54 +00:00
Program,
2021-07-30 00:50:49 +00:00
Role,
Semester,
2021-07-30 12:20:54 +00:00
SemesterExperiment,
2021-07-30 00:50:49 +00:00
Student,
User,
)
2022-02-23 19:36:29 +00:00
from advlabdb.utils import (
flashRandomPassword,
initActiveSemesterMenuLinks,
randomPassword,
userActiveSemester,
)
2021-07-30 00:50:49 +00:00
class AssistantAppointmentView(SecureAssistantModelView):
2021-07-31 22:41:21 +00:00
column_list = [
"date",
"special",
"group_experiment.semester_experiment.experiment",
"group_experiment.group",
"group_experiment.group.part_students",
]
column_labels = {
"group_experiment.semester_experiment.experiment": "Experiment",
"group_experiment.group": "Group",
"group_experiment.group.part_students": "Students",
}
2021-11-30 00:47:37 +00:00
column_editable_list = [
"date",
]
def queryFilter(self):
return and_(
Appointment.group_experiment.has(
GroupExperiment.semester_experiment.has(SemesterExperiment.semester == userActiveSemester())
),
Appointment.assistant == current_user.assistant,
)
class AssistantExperimentMarkView(SecureAssistantModelView):
2021-07-31 22:41:21 +00:00
column_list = [
"oral_mark",
"protocol_mark",
2021-08-29 16:15:14 +00:00
"final_experiment_mark",
2021-07-31 22:41:21 +00:00
"group_experiment.semester_experiment.experiment",
"part_student.student.first_name",
"part_student.student.last_name",
"part_student.group",
"part_student.student.uni_email",
"part_student.student.contact_email",
"part_student.part",
"assistant",
"edited_by_admin",
]
column_labels = {
"group_experiment.semester_experiment.experiment": "Experiment",
"part_student.student.first_name": "First Name",
"part_student.student.last_name": "Last Name",
"part_student.group": "Group",
"part_student.student.uni_email": "Uni Email",
"part_student.student.contact_email": "Contact Email",
"part_student.part": "Part",
}
column_descriptions = {
"oral_mark": "Between 0 and 15",
"protocol_mark": "Between 0 and 15",
2021-08-29 16:15:14 +00:00
"final_experiment_mark": "Calculated automatically with oral and protocol marks and weightings",
2021-07-31 22:41:21 +00:00
"part_student.student.contact_email": "The preferred contact email address if entered by the student",
"assistant": "The assistant who assigned the mark",
"edited_by_admin": "If the mark was edited by an admin",
}
2021-11-30 00:47:37 +00:00
column_editable_list = [
"oral_mark",
"protocol_mark",
]
form_args = {
"oral_mark": {"validators": [NumberRange(0, 15)]},
"protocol_mark": {"validators": [NumberRange(0, 15)]},
}
2021-07-30 00:50:49 +00:00
column_default_sort = [("oral_mark", False), ("protocol_mark", False)]
2021-07-30 00:50:49 +00:00
def queryFilter(self):
return ExperimentMark.group_experiment.has(
GroupExperiment.semester_experiment.has(
and_(
SemesterExperiment.semester == userActiveSemester(),
SemesterExperiment.assistants.any(Assistant.user == current_user),
)
)
2021-07-30 00:50:49 +00:00
)
def update_model(self, form, model):
if (form.oral_mark and form.oral_mark.data != model.oral_mark) or (
form.protocol_mark and form.protocol_mark.data != model.protocol_mark
):
model.assistant = current_user.assistant
2021-07-30 00:50:49 +00:00
ret = super().update_model(form, model)
2021-07-30 00:50:49 +00:00
model.part_student.checkThenSetFinalPartMark()
return ret
else:
# Nothing changed
return True
2021-07-30 00:50:49 +00:00
2021-11-30 00:47:37 +00:00
class AssistantUserView(SecureAssistantModelView):
2022-02-23 19:36:29 +00:00
class EditForm(Form):
phone_number = StringField("Phone Number")
mobile_phone_number = StringField("Mobile Phone Number")
building = StringField("Building")
room = StringField("Room")
generate_new_password = BooleanField("Generate new random password", default=False)
form = EditForm
can_edit = True
column_display_actions = True
2021-11-30 00:47:37 +00:00
column_sortable_list = []
column_list = [
"email",
"phone_number",
"mobile_phone_number",
"building",
2022-02-23 19:36:29 +00:00
"room",
2021-11-30 00:47:37 +00:00
"assistant.semester_experiments",
]
column_labels = {
"assistant.semester_experiments": "Semester Experiments",
}
def queryFilter(self):
return User.id == current_user.id
2022-02-23 19:36:29 +00:00
def on_model_change(self, form, model, is_created):
if form.generate_new_password.data:
password = randomPassword()
flashRandomPassword(password)
admin_change_password(model, password, notify=False) # Password is automatically hashed with this function
2021-11-30 00:47:37 +00:00
2022-02-23 18:37:09 +00:00
class AssistantDocsView(SecureAssistantBaseView):
@expose("/", methods=["GET"])
def index(self):
return self.render("docs/assistant.html")
assistantSpace.add_view(
AssistantAppointmentView(Appointment, db.session, endpoint="assistant_appointment", url="appointment")
)
2021-07-30 00:50:49 +00:00
assistantSpace.add_view(
AssistantExperimentMarkView(ExperimentMark, db.session, endpoint="assistant_experimentmark", url="experimentmark")
2021-07-30 00:50:49 +00:00
)
2021-11-30 00:47:37 +00:00
assistantSpace.add_view(AssistantUserView(User, db.session, endpoint="assistant_user", url="user"))
2022-02-23 18:37:09 +00:00
assistantSpace.add_view(AssistantDocsView(name="Docs", endpoint="assistant_docs", url="docs"))
initActiveSemesterMenuLinks(assistantSpace)