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

Add GroupExperiment.note to adminSpace

This commit is contained in:
Mo 2022-06-17 19:15:38 +02:00
parent 41a329512a
commit 8c34cb71f7
2 changed files with 21 additions and 8 deletions

View file

@ -25,6 +25,7 @@ from wtforms.fields import (
RadioField, RadioField,
StringField, StringField,
SubmitField, SubmitField,
TextAreaField,
) )
from wtforms.validators import URL, DataRequired, Email, NumberRange, Optional from wtforms.validators import URL, DataRequired, Email, NumberRange, Optional
from wtforms.widgets import NumberInput from wtforms.widgets import NumberInput
@ -132,7 +133,7 @@ class UserView(SecureAdminModelView):
query_factory=semesterExperimentQueryFactory, query_factory=semesterExperimentQueryFactory,
allow_blank=True, allow_blank=True,
blank_text="-", blank_text="-",
description="Only needed if the user has the assistant role", description="Only needed if the user has the assistant role.",
) )
active = BooleanField( active = BooleanField(
@ -283,7 +284,7 @@ class SemesterView(SecureAdminModelView):
"Year", "Year",
validators=[DataRequired(), NumberRange(MIN_YEAR, MAX_YEAR)], validators=[DataRequired(), NumberRange(MIN_YEAR, MAX_YEAR)],
default=defaultFormYear, default=defaultFormYear,
description=f"Between {MIN_YEAR} and {MAX_YEAR}", description=f"Between {MIN_YEAR} and {MAX_YEAR}.",
) )
transfer_parts = BooleanField( transfer_parts = BooleanField(
"Transfer parts", "Transfer parts",
@ -690,7 +691,7 @@ class SemesterExperimentView(SecureAdminModelView):
"Oral weighting", "Oral weighting",
validators=[DataRequired(), NumberRange(0, 1)], validators=[DataRequired(), NumberRange(0, 1)],
default=0.5, default=0.5,
description="Between 0 and 1", description="Between 0 and 1.",
places=2, places=2,
widget=NumberInput(step=0.01), widget=NumberInput(step=0.01),
) )
@ -706,7 +707,7 @@ class SemesterExperimentView(SecureAdminModelView):
"Final weighting", "Final weighting",
validators=[DataRequired(), NumberRange(0, 1)], validators=[DataRequired(), NumberRange(0, 1)],
default=1.0, default=1.0,
description="Between 0 and 1", description="Between 0 and 1.",
places=2, places=2,
widget=NumberInput(step=0.01), widget=NumberInput(step=0.01),
) )
@ -904,6 +905,14 @@ class ExperimentRowFilter(FilterEqual):
return (experimentNumber, programId) return (experimentNumber, programId)
def group_experiment_note_field():
return TextAreaField(
"Note",
validators=[Optional()],
description="This note can be seen and edited by assistants that are responsible for this semester experiment.",
)
class GroupExperimentView(SecureAdminModelView): class GroupExperimentView(SecureAdminModelView):
class ExperimentFilter(ExperimentRowFilter): class ExperimentFilter(ExperimentRowFilter):
def apply(self, query, value, alias=None): def apply(self, query, value, alias=None):
@ -923,6 +932,9 @@ class GroupExperimentView(SecureAdminModelView):
def customId(self, row): def customId(self, row):
return row.semester_experiment_id return row.semester_experiment_id
class EditForm(Form):
note = group_experiment_note_field()
class CreateForm(Form): class CreateForm(Form):
group = QuerySelectField( group = QuerySelectField(
"Group", "Group",
@ -970,8 +982,8 @@ class GroupExperimentView(SecureAdminModelView):
allow_blank=True, allow_blank=True,
blank_text=assistantBlankText, blank_text=assistantBlankText,
) )
note = group_experiment_note_field()
can_edit = False
column_display_all_relations = True column_display_all_relations = True
column_filters = ( column_filters = (
@ -1072,7 +1084,7 @@ class AppointmentView(SecureAdminModelView):
special = BooleanField( special = BooleanField(
"Special", "Special",
default=False, default=False,
description="A special appointment should take place in the semester break", description="A special appointment should take place in the semester break.",
) )
assistant = QuerySelectField( assistant = QuerySelectField(
"Assistant", "Assistant",
@ -1226,12 +1238,12 @@ class ExperimentMarkView(SecureAdminModelView):
oral_mark = IntegerField( oral_mark = IntegerField(
"Oral Mark", "Oral Mark",
validators=[Optional(), NumberRange(MIN_MARK, MAX_MARK)], validators=[Optional(), NumberRange(MIN_MARK, MAX_MARK)],
description=f"Between {MIN_MARK} and {MAX_MARK}", description=f"Between {MIN_MARK} and {MAX_MARK}.",
) )
protocol_mark = IntegerField( protocol_mark = IntegerField(
"Protocol Mark", "Protocol Mark",
validators=[Optional(), NumberRange(MIN_MARK, MAX_MARK)], validators=[Optional(), NumberRange(MIN_MARK, MAX_MARK)],
description=f"Between {MIN_MARK} and {MAX_MARK}", description=f"Between {MIN_MARK} and {MAX_MARK}.",
) )
column_descriptions = { column_descriptions = {

View file

@ -202,6 +202,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)
note = db.Column(db.Text, nullable=True)
semester_experiment_id = db.Column(db.Integer, db.ForeignKey("semester_experiment.id"), nullable=False) semester_experiment_id = db.Column(db.Integer, db.ForeignKey("semester_experiment.id"), nullable=False)
semester_experiment = db.relationship("SemesterExperiment", back_populates="group_experiments") semester_experiment = db.relationship("SemesterExperiment", back_populates="group_experiments")