From 06bfc120ab59c3ac3d40a18029bb952688cf2595 Mon Sep 17 00:00:00 2001 From: Richard Ebeling Date: Mon, 26 Feb 2024 17:48:09 +0100 Subject: [PATCH 1/3] Fix django-stubs-ext missing breaking a production setup (#2110) Make django-stubs a non-dev-requirement. Just make StrOrPromise = Any if we're not typechecking. Use strict StrOrPromise with typeguard --- evap/evaluation/models.py | 2 +- evap/evaluation/tools.py | 11 +++++++++-- evap/staff/views.py | 2 +- 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/evap/evaluation/models.py b/evap/evaluation/models.py index bc1d3cba17..a7601e4a64 100644 --- a/evap/evaluation/models.py +++ b/evap/evaluation/models.py @@ -30,10 +30,10 @@ from django.utils.translation import gettext_lazy as _ from django_fsm import FSMIntegerField, transition from django_fsm.signals import post_transition -from django_stubs_ext import StrOrPromise from evap.evaluation.models_logging import FieldAction, LoggedModel from evap.evaluation.tools import ( + StrOrPromise, clean_email, date_to_datetime, is_external_email, diff --git a/evap/evaluation/tools.py b/evap/evaluation/tools.py index ad9aa51a7f..9012ccedce 100644 --- a/evap/evaluation/tools.py +++ b/evap/evaluation/tools.py @@ -3,7 +3,7 @@ from abc import ABC, abstractmethod from collections import defaultdict from collections.abc import Iterable, Mapping -from typing import Any, Protocol, TypeVar +from typing import TYPE_CHECKING, Any, Protocol, TypeVar from urllib.parse import quote import xlwt @@ -16,7 +16,14 @@ from django.utils.datastructures import MultiValueDict from django.utils.translation import get_language from django.views.generic import FormView -from django_stubs_ext import StrOrPromise + +if TYPE_CHECKING: + from django_stubs_ext import StrOrPromise # use proper definition with mypy +else: + try: + from django_stubs_ext import StrOrPromise # if installed, use proper definition for typeguard + except ImportError: + StrOrPromise = Any # on production setups, type alias to Any M = TypeVar("M", bound=Model) T = TypeVar("T") diff --git a/evap/staff/views.py b/evap/staff/views.py index c9a8f7ddb1..df1b5e3be2 100644 --- a/evap/staff/views.py +++ b/evap/staff/views.py @@ -37,7 +37,6 @@ from django.utils.translation import gettext_lazy, ngettext from django.views.decorators.http import require_POST from django.views.generic import CreateView, FormView, UpdateView -from django_stubs_ext import StrOrPromise from evap.contributor.views import export_contributor_results from evap.evaluation.auth import manager_required, reviewer_required, staff_permission_required @@ -65,6 +64,7 @@ FormsetView, HttpResponseNoContent, SaveValidFormMixin, + StrOrPromise, get_object_from_dict_pk_entry_or_logged_40x, get_parameter_from_url_or_session, sort_formset, From c7c6ee6e3158b28f7aff0d59520182bcc47968a1 Mon Sep 17 00:00:00 2001 From: Christoph Thiede <38782922+LinqLover@users.noreply.github.com> Date: Mon, 26 Feb 2024 20:27:00 +0100 Subject: [PATCH 2/3] Mobile improvements (#2054) * avoid overflows in rewards overview on mobile * make navbar menu scrollable for small display heights * make footer horizontally scrollable on small screens The previous behavior was the footer became wider than the screen and the entire page width was increased. * contact form: enable line breaks in anonymous sender button * remove horizontal overflows in contributor index * avoid horizontal overflows of percentage value in distribution bars * avoid horizontal overflows in grade views * avoid horizontal overflows in contributor evaluation form * avoid horizontal overflows in some staff views * make staff overview mobile-friendly * avoid horizontal overflows of breadcrumb arrow * avoid horizontal overflows in staff faq views * fix navbar menus on desktop regression from regression from 75af5b2ec104a4cbd4b2831bf487cdd98c48ca78 --------- Co-authored-by: Richard Ebeling Co-authored-by: Johannes Wolf Co-authored-by: Niklas Mohrin --- .../contributor_evaluation_form.html | 14 +- .../templates/contributor_index.html | 4 +- .../templates/development_components.html | 12 +- evap/evaluation/templates/contact_modal.html | 2 +- evap/evaluation/templates/footer.html | 2 +- evap/grades/templates/grades_base.html | 20 ++- evap/grades/templates/grades_course_view.html | 2 +- .../templates/grades_semester_view.html | 2 +- .../templates/results_evaluation_detail.html | 10 +- evap/rewards/templates/rewards_index.html | 4 +- ...ds_reward_point_redemption_event_list.html | 2 +- evap/staff/templates/staff_base.html | 20 ++- .../templates/staff_course_type_index.html | 2 +- evap/staff/templates/staff_degree_index.html | 2 +- .../templates/staff_evaluation_form.html | 2 +- evap/staff/templates/staff_faq_index.html | 2 +- evap/staff/templates/staff_faq_section.html | 2 +- evap/staff/templates/staff_index.html | 168 ++++++++---------- .../templates/staff_questionnaire_form.html | 2 +- .../staff_questionnaire_index_list.html | 2 +- evap/staff/templates/staff_semester_view.html | 4 +- .../templates/staff_text_answer_warnings.html | 2 +- evap/staff/templates/staff_user_list.html | 2 +- evap/static/scss/_components.scss | 1 + evap/static/scss/_utilities.scss | 4 + evap/static/scss/_variables.scss | 2 + evap/static/scss/components/_breadcrumb.scss | 4 + .../scss/components/_distribution-bar.scss | 4 + evap/static/scss/components/_nav.scss | 8 + evap/static/scss/components/_staff-index.scss | 17 ++ evap/static/scss/evap.scss | 2 +- evap/student/templates/student_vote.html | 10 +- 32 files changed, 181 insertions(+), 155 deletions(-) create mode 100644 evap/static/scss/components/_staff-index.scss diff --git a/evap/contributor/templates/contributor_evaluation_form.html b/evap/contributor/templates/contributor_evaluation_form.html index ecd2e22c51..15273ba34d 100644 --- a/evap/contributor/templates/contributor_evaluation_form.html +++ b/evap/contributor/templates/contributor_evaluation_form.html @@ -5,10 +5,12 @@ {% block title %}{% trans 'Your EvaP' %} - {{ block.super }}{% endblock %} {% block breadcrumb_bar %} - + {% endblock %} {% block content %} @@ -59,7 +61,7 @@
{% trans 'Course data' %}
-
+
{% trans 'Evaluation data' %}
{% if evaluation.allow_editors_to_edit %} @@ -80,7 +82,7 @@
{% trans 'Evaluation data' %}
-
+
{% include 'contribution_formset.html' with formset=formset staff=False editable=editable %}
diff --git a/evap/contributor/templates/contributor_index.html b/evap/contributor/templates/contributor_index.html index e61132d2cc..6496bdac37 100644 --- a/evap/contributor/templates/contributor_index.html +++ b/evap/contributor/templates/contributor_index.html @@ -17,7 +17,7 @@
{% if user.is_delegate %}
-
{% trans 'Delegated evaluations' %}
+
{% trans 'Delegated evaluations' %}
{% trans 'Show' %} @@ -42,7 +42,7 @@
{{ semester.semester_name }}
-
+
diff --git a/evap/development/templates/development_components.html b/evap/development/templates/development_components.html index 303da8149f..901c4ebfb8 100644 --- a/evap/development/templates/development_components.html +++ b/evap/development/templates/development_components.html @@ -3,11 +3,13 @@ {% block title %}{% trans 'Development' %} - {{ block.super }}{% endblock %} {% block breadcrumb_bar %} - + {% endblock %} {% block content %} diff --git a/evap/evaluation/templates/contact_modal.html b/evap/evaluation/templates/contact_modal.html index 7566c4ed26..70ce142699 100644 --- a/evap/evaluation/templates/contact_modal.html +++ b/evap/evaluation/templates/contact_modal.html @@ -30,7 +30,7 @@ - + {% else %} diff --git a/evap/evaluation/templates/footer.html b/evap/evaluation/templates/footer.html index 2c747d68e6..4b8155ee60 100644 --- a/evap/evaluation/templates/footer.html +++ b/evap/evaluation/templates/footer.html @@ -6,7 +6,7 @@
- diff --git a/evap/grades/templates/grades_semester_view.html b/evap/grades/templates/grades_semester_view.html index 73ed72cd0c..e6b44b3e83 100644 --- a/evap/grades/templates/grades_semester_view.html +++ b/evap/grades/templates/grades_semester_view.html @@ -30,7 +30,7 @@

{% trans 'Courses' %}
-
+
{% if courses %}

diff --git a/evap/results/templates/results_evaluation_detail.html b/evap/results/templates/results_evaluation_detail.html index 6be6c29142..ef591e7ef8 100644 --- a/evap/results/templates/results_evaluation_detail.html +++ b/evap/results/templates/results_evaluation_detail.html @@ -7,10 +7,12 @@ {% block title %}{{ evaluation.full_name }} - {{ evaluation.course.semester.name }} - {% trans 'Results' %} - {{ block.super }}{% endblock %} {% block breadcrumb_bar %} - + {% endblock %} {% block content %} diff --git a/evap/rewards/templates/rewards_index.html b/evap/rewards/templates/rewards_index.html index 4ad138271b..96e11bdcd7 100644 --- a/evap/rewards/templates/rewards_index.html +++ b/evap/rewards/templates/rewards_index.html @@ -15,7 +15,7 @@
{% trans 'Redeem points' %}
-
+

{% trans 'Total points available' %}: {{ total_points_available }}

{% if total_points_available > 0 %} {% if events %} @@ -62,7 +62,7 @@
{% trans 'Reward points history' %}
-
+
{% if reward_point_actions %}
diff --git a/evap/rewards/templates/rewards_reward_point_redemption_event_list.html b/evap/rewards/templates/rewards_reward_point_redemption_event_list.html index 3648befacf..c3a4f28a32 100644 --- a/evap/rewards/templates/rewards_reward_point_redemption_event_list.html +++ b/evap/rewards/templates/rewards_reward_point_redemption_event_list.html @@ -1,7 +1,7 @@
{% trans title %}
-
+
{% if events %}
diff --git a/evap/staff/templates/staff_base.html b/evap/staff/templates/staff_base.html index 97de9c79bd..dbdff8038a 100644 --- a/evap/staff/templates/staff_base.html +++ b/evap/staff/templates/staff_base.html @@ -3,13 +3,15 @@ {% block title %}{% trans 'Manage' %} - {{ block.super }}{% endblock %} {% block breadcrumb_bar %} - + {% endblock %} diff --git a/evap/staff/templates/staff_course_type_index.html b/evap/staff/templates/staff_course_type_index.html index 95c7909c61..3ecd2aa511 100644 --- a/evap/staff/templates/staff_course_type_index.html +++ b/evap/staff/templates/staff_course_type_index.html @@ -19,7 +19,7 @@ {{ formset.management_form }}
-
+
diff --git a/evap/staff/templates/staff_degree_index.html b/evap/staff/templates/staff_degree_index.html index 2aa2782ea5..44ff2af056 100644 --- a/evap/staff/templates/staff_degree_index.html +++ b/evap/staff/templates/staff_degree_index.html @@ -15,7 +15,7 @@ {{ formset.management_form }}
-
+
diff --git a/evap/staff/templates/staff_evaluation_form.html b/evap/staff/templates/staff_evaluation_form.html index 79d88732ed..ef05c733a6 100644 --- a/evap/staff/templates/staff_evaluation_form.html +++ b/evap/staff/templates/staff_evaluation_form.html @@ -28,7 +28,7 @@

-
+
{% include 'contribution_formset.html' with formset=formset manager=True editable=editable %}
diff --git a/evap/staff/templates/staff_faq_index.html b/evap/staff/templates/staff_faq_index.html index 93b5032976..1f40eae3b7 100644 --- a/evap/staff/templates/staff_faq_index.html +++ b/evap/staff/templates/staff_faq_index.html @@ -15,7 +15,7 @@ {{ formset.management_form }}
-
+

diff --git a/evap/staff/templates/staff_faq_section.html b/evap/staff/templates/staff_faq_section.html index e687ce8e42..1f99205a39 100644 --- a/evap/staff/templates/staff_faq_section.html +++ b/evap/staff/templates/staff_faq_section.html @@ -16,7 +16,7 @@ {{ formset.management_form }}
-
+
diff --git a/evap/staff/templates/staff_index.html b/evap/staff/templates/staff_index.html index 03fec7bd6b..e83a85e5cd 100644 --- a/evap/staff/templates/staff_index.html +++ b/evap/staff/templates/staff_index.html @@ -1,106 +1,80 @@ {% extends 'staff_base.html' %} {% block content %} -
-
-
-
-

{% trans 'Semesters' %}

- {% if semesters %} - - {% else %} - {% trans 'There are no semesters yet.' %} - {% endif %} - {% trans 'Create new semester' %} -
-
+
+
+

{% trans 'Semesters' %}

+ {% if semesters %} + + {% else %} + {% trans 'There are no semesters yet.' %} + {% endif %} + {% trans 'Create new semester' %}
-
-
- -
- + -
-
-
-

{% trans 'Degrees' %}

- -
-
-
-
-

{% trans 'Course types' %}

- -
-
-
-
-

{% trans 'Text answer warnings' %}

- -
-
-
-
-

{% trans 'Reward Points' %}

- -
-
+ -
-
-
-

{% trans 'Templates' %}

- -
-
-
-
-

{% trans 'FAQ and Infotexts' %}

- -
-
+
+

{% trans 'Degrees' %}

+ +
+
+

{% trans 'Course types' %}

+ +
+
+

{% trans 'Text answer warnings' %}

+ +
+
+

{% trans 'Reward Points' %}

+ +
+
+

{% trans 'Templates' %}

+ +
+
+

{% trans 'FAQ and Infotexts' %}

+
{% endblock %} diff --git a/evap/staff/templates/staff_questionnaire_form.html b/evap/staff/templates/staff_questionnaire_form.html index 0f968f76c9..64c6bc7835 100644 --- a/evap/staff/templates/staff_questionnaire_form.html +++ b/evap/staff/templates/staff_questionnaire_form.html @@ -22,7 +22,7 @@
{% trans 'General Options' %}
-
+
{% trans 'Questions' %}
{{ formset.management_form }} {% include 'bootstrap_form_errors.html' with errors=formset.non_form_errors %} diff --git a/evap/staff/templates/staff_questionnaire_index_list.html b/evap/staff/templates/staff_questionnaire_index_list.html index c4f0331e3b..8465d395b3 100644 --- a/evap/staff/templates/staff_questionnaire_index_list.html +++ b/evap/staff/templates/staff_questionnaire_index_list.html @@ -6,7 +6,7 @@
-
+
diff --git a/evap/staff/templates/staff_semester_view.html b/evap/staff/templates/staff_semester_view.html index f586e5f83f..6b34d43a1b 100644 --- a/evap/staff/templates/staff_semester_view.html +++ b/evap/staff/templates/staff_semester_view.html @@ -80,7 +80,7 @@

{% endif %}
-
+

@@ -259,7 +259,7 @@

-
+ {% if num_evaluations > 0 %}

diff --git a/evap/staff/templates/staff_text_answer_warnings.html b/evap/staff/templates/staff_text_answer_warnings.html index 380101e58c..16b52d4456 100644 --- a/evap/staff/templates/staff_text_answer_warnings.html +++ b/evap/staff/templates/staff_text_answer_warnings.html @@ -16,7 +16,7 @@ {{ formset.management_form }}
-
+
diff --git a/evap/staff/templates/staff_user_list.html b/evap/staff/templates/staff_user_list.html index 174cca33ac..a472b830a4 100644 --- a/evap/staff/templates/staff_user_list.html +++ b/evap/staff/templates/staff_user_list.html @@ -37,7 +37,7 @@
-
+
diff --git a/evap/static/scss/_components.scss b/evap/static/scss/_components.scss index 9fc73c5d1a..ccbee1df31 100644 --- a/evap/static/scss/_components.scss +++ b/evap/static/scss/_components.scss @@ -19,4 +19,5 @@ @import "components/distribution-bar"; @import "components/quick-review"; +@import "components/staff-index"; @import "components/notebook"; diff --git a/evap/static/scss/_utilities.scss b/evap/static/scss/_utilities.scss index dd91f2ce3e..d56f26cd28 100644 --- a/evap/static/scss/_utilities.scss +++ b/evap/static/scss/_utilities.scss @@ -71,3 +71,7 @@ a.no-underline:hover { .z-over-fixed { z-index: $zindex-fixed + 1; } + +.break-spaces { + white-space: break-spaces; +} diff --git a/evap/static/scss/_variables.scss b/evap/static/scss/_variables.scss index b069329a73..899b004e0f 100644 --- a/evap/static/scss/_variables.scss +++ b/evap/static/scss/_variables.scss @@ -2,6 +2,8 @@ $fa-font-path: "../font-awesome/webfonts"; +$brand-height: 42px; + $enable-smooth-scroll: false; $grid-breakpoints: ( diff --git a/evap/static/scss/components/_breadcrumb.scss b/evap/static/scss/components/_breadcrumb.scss index 150df8394f..f33e3262b5 100644 --- a/evap/static/scss/components/_breadcrumb.scss +++ b/evap/static/scss/components/_breadcrumb.scss @@ -25,3 +25,7 @@ border-right: 13px solid transparent; } } + +.breadcrumb-bar { + overflow-x: hidden; /* breadcrumb::after must not overflow screen */ +} diff --git a/evap/static/scss/components/_distribution-bar.scss b/evap/static/scss/components/_distribution-bar.scss index f3f6311e05..b6c8aadc25 100644 --- a/evap/static/scss/components/_distribution-bar.scss +++ b/evap/static/scss/components/_distribution-bar.scss @@ -62,6 +62,10 @@ margin: 0 0.5rem; } + &:not(:empty) { + min-width: calc(3ch + 2*3px); // 3 characters + left and right border + } + } .result-widget:hover { diff --git a/evap/static/scss/components/_nav.scss b/evap/static/scss/components/_nav.scss index 7596088606..7ebb2ea4cf 100644 --- a/evap/static/scss/components/_nav.scss +++ b/evap/static/scss/components/_nav.scss @@ -4,6 +4,10 @@ background-color: $darker-gray; } +.navbar-collapse.show { + overflow-y: scroll; /* scrollable menus on mobile */ +} + .navbar-nav .nav-link, .navbar-nav .navbar-text { padding: .0 .5rem; @@ -29,3 +33,7 @@ .nav-item { padding: 0 0.25rem; } + +#navbarNavDropdown { + max-height: calc(100vh - $brand-height); +} diff --git a/evap/static/scss/components/_staff-index.scss b/evap/static/scss/components/_staff-index.scss new file mode 100644 index 0000000000..45a3336d9b --- /dev/null +++ b/evap/static/scss/components/_staff-index.scss @@ -0,0 +1,17 @@ +.staff-index-card-columns { + @include media-breakpoint-up(sm) { + column-count: 2; + } + @include media-breakpoint-up(lg) { + column-count: 3; + } + + .card { + margin-bottom: 1rem; + + @include media-breakpoint-up(sm) { + display: inline-block; + width: 100%; + } + } +} diff --git a/evap/static/scss/evap.scss b/evap/static/scss/evap.scss index 0afa6168ae..fb2a687f72 100644 --- a/evap/static/scss/evap.scss +++ b/evap/static/scss/evap.scss @@ -40,7 +40,7 @@ body { } .brand-image { - height: 42px; + height: $brand-height; } .color-bar { diff --git a/evap/student/templates/student_vote.html b/evap/student/templates/student_vote.html index 30411076cf..61ebc9ebe7 100644 --- a/evap/student/templates/student_vote.html +++ b/evap/student/templates/student_vote.html @@ -7,10 +7,12 @@ {% block title %}{{ evaluation.full_name }} - {% trans 'Evaluation' %} - {{ block.super }}{% endblock %} {% block breadcrumb_bar %} - + {% endblock %} {% block content %} From 8145c0959996a280f0779d8f51e35d9ddb45d5e6 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 26 Feb 2024 19:43:27 +0000 Subject: [PATCH 3/3] Update pylint requirement from ~=3.0.1 to ~=3.1.0 (#2127) --- requirements-dev.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements-dev.txt b/requirements-dev.txt index e260c921ec..dc7b3fe099 100644 --- a/requirements-dev.txt +++ b/requirements-dev.txt @@ -9,7 +9,7 @@ model-bakery~=1.17.0 mypy~=1.8.0 openpyxl-stubs~=0.1.25 pylint-django~=2.5.4 -pylint~=3.0.1 +pylint~=3.1.0 tblib~=3.0.0 xlrd~=2.0.1 typeguard~=4.1.5