1
0
Fork 0
mirror of https://codeberg.org/Mo8it/AdvLabDB.git synced 2025-01-03 15:49:19 +00:00

Remove old views

This commit is contained in:
Mo 2022-06-27 23:27:09 +02:00
parent 82e2e9977f
commit 22ee6f7c54

View file

@ -1,5 +1,6 @@
from flask import flash, redirect, request, url_for from flask import flash, redirect, request, url_for
from flask_admin import expose from flask_admin import expose
from flask_admin.model.template import EndpointLinkRowAction
from flask_security import admin_change_password, current_user from flask_security import admin_change_password, current_user
from flask_wtf import FlaskForm from flask_wtf import FlaskForm
from wtforms.fields import TextAreaField from wtforms.fields import TextAreaField
@ -37,14 +38,6 @@ from .models import (
class AssistantGroupExperimentView(SecureAssistantModelView): class AssistantGroupExperimentView(SecureAssistantModelView):
class EditForm(FlaskForm):
note = TextAreaField(
"Note",
validators=[Optional()],
description="This note is optional and can be seen and edited by admins and assistants that are responsible for this semester experiment. This note is for information related to the experiment and group. Examples: Protocol received, submission until ..., etc.",
)
can_edit = True
column_display_actions = True column_display_actions = True
column_list = [ column_list = [
@ -81,6 +74,14 @@ class AssistantGroupExperimentView(SecureAssistantModelView):
"appointments": appointments_formatter, "appointments": appointments_formatter,
} }
column_extra_row_actions = [
EndpointLinkRowAction(
icon_class="fa fa-pencil",
endpoint="assistant_groupexperiment.form_view",
title="Edit",
)
]
def query_modifier(self, query): def query_modifier(self, query):
return ( return (
query.join(SemesterExperiment) query.join(SemesterExperiment)
@ -128,8 +129,19 @@ class AssistantGroupExperimentView(SecureAssistantModelView):
appointment.date = appointment_fields[ind].data appointment.date = appointment_fields[ind].data
for ind, experiment_mark in enumerate(experiment_marks): for ind, experiment_mark in enumerate(experiment_marks):
experiment_mark.oral_mark = parse_selection_mark_field(oral_experiment_mark_fields[ind]) form_oral_mark = parse_selection_mark_field(oral_experiment_mark_fields[ind])
experiment_mark.protocol_mark = parse_selection_mark_field(protocol_experiment_mark_fields[ind]) form_protocol_mark = parse_selection_mark_field(protocol_experiment_mark_fields[ind])
if (
form_oral_mark != experiment_mark.oral_mark
or form_protocol_mark != experiment_mark.protocol_mark
):
experiment_mark.oral_mark = form_oral_mark
experiment_mark.protocol_mark = form_protocol_mark
experiment_mark.assistant = current_user.assistant
experiment_mark.part_student.checkThenSetFinalPartMark()
group_experiment.note = form.note.data group_experiment.note = form.note.data
@ -159,131 +171,6 @@ class AssistantGroupExperimentView(SecureAssistantModelView):
) )
class AssistantAppointmentView(SecureAssistantModelView):
can_edit = True
column_list = [
"date",
"special",
"group_experiment.semester_experiment.experiment",
"group_experiment.group.number",
"group_experiment.group.part_students",
]
column_labels = {
"group_experiment.semester_experiment.experiment": "Experiment",
"group_experiment.group.number": "Group number",
"group_experiment.group.part_students": "Students",
}
column_editable_list = [
"date",
]
form_columns = column_editable_list
column_descriptions = {
"special": "A special appointment should take place in the semester break",
}
def part_students_formatter(view, context, model, name):
part_students = deep_getattr(model, name)
if part_students is not None:
return ", ".join([str(part_student.student) for part_student in part_students])
return attr
column_formatters = {
"group_experiment.semester_experiment.experiment": str_formatter,
"group_experiment.group.part_students": part_students_formatter,
}
def query_modifier(self, query):
return (
query.join(GroupExperiment)
.join(SemesterExperiment)
.where(
SemesterExperiment.semester == current_user.active_semester,
Appointment.assistant == current_user.assistant,
)
)
class AssistantExperimentMarkView(SecureAssistantModelView):
class EditForm(FlaskForm):
oral_mark = mark_field("Oral")
protocol_mark = mark_field("Protocol")
can_edit = True
column_display_actions = True
column_list = [
"oral_mark",
"protocol_mark",
"final_experiment_mark",
"group_experiment.semester_experiment.experiment.number",
"part_student.student",
"part_student.group.number",
"part_student.student.uni_email",
"part_student.student.contact_email",
"part_student.part",
"assistant",
"admin",
]
column_labels = {
"group_experiment.semester_experiment.experiment.number": "Experiment number",
"part_student.student": "Student",
"part_student.group.number": "Group number",
"part_student.student.uni_email": "Uni Email",
"part_student.student.contact_email": "Contact Email",
"part_student.part": "Part",
}
column_descriptions = {
"oral_mark": f"Between {MIN_MARK} and {MAX_MARK}",
"protocol_mark": f"Between {MIN_MARK} and {MAX_MARK}",
"final_experiment_mark": "Calculated automatically with oral and protocol marks and weightings",
"part_student.student.contact_email": "The preferred contact email address if entered by the student",
"assistant": "The last assistant who edited the mark",
"admin": "The last admin who edited the mark",
}
column_searchable_list = [
"part_student.student.first_name",
"part_student.student.last_name",
"part_student.student.uni_email",
"part_student.student.contact_email",
]
column_formatters = {
"oral_mark": missing_formatter,
"protocol_mark": missing_formatter,
"part_student.part": str_without_semester_formatter,
}
column_default_sort = [("oral_mark", False), ("protocol_mark", False)]
def query_modifier(self, query):
return (
query.join(GroupExperiment)
.join(SemesterExperiment)
.where(SemesterExperiment.semester == current_user.active_semester)
.join(SemesterExperiment.assistants)
.where(Assistant.user == current_user)
)
def update_model(self, form, model):
if (form.oral_mark is not None and form.oral_mark.data != model.oral_mark) or (
form.protocol_mark is not None and form.protocol_mark.data != model.protocol_mark
):
model.assistant = current_user.assistant
updateSuccessful = super().update_model(form, model)
model.part_student.checkThenSetFinalPartMark()
return updateSuccessful
else:
# Nothing changed
return True
class AssistantUserView(SecureAssistantModelView): class AssistantUserView(SecureAssistantModelView):
class EditForm(FlaskForm): class EditForm(FlaskForm):
phone_number, mobile_phone_number, building, room = user_info_fields() phone_number, mobile_phone_number, building, room = user_info_fields()
@ -330,12 +217,6 @@ assistantSpace.add_view(
GroupExperiment, db.session, endpoint="assistant_groupexperiment", url="group_experiment" GroupExperiment, db.session, endpoint="assistant_groupexperiment", url="group_experiment"
) )
) )
assistantSpace.add_view(
AssistantAppointmentView(Appointment, db.session, endpoint="assistant_appointment", url="appointment")
)
assistantSpace.add_view(
AssistantExperimentMarkView(ExperimentMark, db.session, endpoint="assistant_experimentmark", url="experiment_mark")
)
assistantSpace.add_view(AssistantUserView(User, db.session, endpoint="assistant_user", url="user")) assistantSpace.add_view(AssistantUserView(User, db.session, endpoint="assistant_user", url="user"))
assistantSpace.add_view(AssistantDocsView(name="Docs", endpoint="assistant_docs", url="docs")) assistantSpace.add_view(AssistantDocsView(name="Docs", endpoint="assistant_docs", url="docs"))