From 078b634ba073625053fd14005f1a09554525bef1 Mon Sep 17 00:00:00 2001 From: nearbeach Date: Fri, 15 Sep 2023 21:47:34 +1000 Subject: [PATCH] Bugfix - nearbeach-1085 Wide screen kanban - UI/UX - switch to enable/disable dragging seems out of place | nearbeach-1086 Kanban Board - UI/UX - Level headers do not line up exactly with heading --- NearBeach/views/customer_views.py | 4 ++++ NearBeach/views/organisation_views.py | 4 ++++ NearBeach/views/profile_views.py | 4 ++++ src/js/components/customers/CustomerInformation.vue | 1 + src/js/components/kanban/KanbanBoard.vue | 11 ++++++++++- src/js/components/profile/UpdateProfilePicture.vue | 6 ++++-- 6 files changed, 27 insertions(+), 3 deletions(-) diff --git a/NearBeach/views/customer_views.py b/NearBeach/views/customer_views.py index ec7cb5ff2..26d885b32 100644 --- a/NearBeach/views/customer_views.py +++ b/NearBeach/views/customer_views.py @@ -98,6 +98,10 @@ def customer_update_profile(request, customer_id, *args, **kwargs): file = form.cleaned_data["file"] document_description = str(file) + # Check file size + if file.size > 250 * 1024: + return HttpResponseBadRequest("File size too large") + # Upload the document document_submit, _ = handle_document_permissions( request, diff --git a/NearBeach/views/organisation_views.py b/NearBeach/views/organisation_views.py index c4019dcde..adbc2ff57 100644 --- a/NearBeach/views/organisation_views.py +++ b/NearBeach/views/organisation_views.py @@ -197,6 +197,10 @@ def organisation_update_profile(request, organisation_id, *args, **kwargs): file = form.cleaned_data["file"] document_description = str(file) + # Check the file size + if file.size > 250 * 1024: + return HttpResponseBadRequest("File size too large") + # Upload the document document_submit, _ = handle_document_permissions( request, diff --git a/NearBeach/views/profile_views.py b/NearBeach/views/profile_views.py index b3f7232fe..799ab810b 100644 --- a/NearBeach/views/profile_views.py +++ b/NearBeach/views/profile_views.py @@ -90,6 +90,10 @@ def update_profile(request): file = form.cleaned_data["file"] document_description = str(file) + # Check file size + if file.size > 250 * 1024: + return HttpResponseBadRequest("Profile Picture too large. Please use 250Kb") + # Upload the document document_submit, _ = handle_document_permissions( request, diff --git a/src/js/components/customers/CustomerInformation.vue b/src/js/components/customers/CustomerInformation.vue index 2319889d2..b0450e6df 100644 --- a/src/js/components/customers/CustomerInformation.vue +++ b/src/js/components/customers/CustomerInformation.vue @@ -35,6 +35,7 @@ 'X-CSRFTOKEN': getToken('csrftoken'), }" :data="{}" + @error="showErrorModal('Profile Picture was not updated','Profile Picture','')" @finish="updateProfilePicture" > Update Profile Picture diff --git a/src/js/components/kanban/KanbanBoard.vue b/src/js/components/kanban/KanbanBoard.vue index a4bda7aba..70657fb56 100644 --- a/src/js/components/kanban/KanbanBoard.vue +++ b/src/js/components/kanban/KanbanBoard.vue @@ -106,7 +106,8 @@ import { nextTick } from 'vue'; }, resizeProcedure() { // Get the screen size and the columns width - const columns_width = this.columnResults.length * 400; + const little_adjustment = 2 * (this.columnResults.length - 1) + const columns_width = this.columnResults.length * 400 + little_adjustment; const container_element = document.getElementsByClassName("kanban-container")[0]; const kanban_container_width = container_element.clientWidth; @@ -115,22 +116,30 @@ import { nextTick } from 'vue'; // that smaller size if (columns_width < kanban_container_width) { //Add in the width restrictions + var header_element = document.getElementsByClassName("kanban-edit-text")[0]; var elements = document.getElementsByClassName("kanban-level-div"); //Loop through each element Array.from(elements).forEach((element) => { element.style = `max-width: ${columns_width}px;`; }); + + //Adjust the size of the header element + header_element.style = `max-width: ${columns_width}px`; } else { //The columns width is greater than the container width. //So we need to use the scroll width of the container const scroll_width = container_element.scrollWidth; + var header_element = document.getElementsByClassName("kanban-edit-text")[0]; let elements = document.getElementsByClassName("kanban-level-div"); //Loop through each element Array.from(elements).forEach((element) => { element.style = `width: ${scroll_width}px;`; }); + + //Adjust the size of the header element + header_element.style = `max-width: ${scroll_width}px`; } }, scrollProcedure() { diff --git a/src/js/components/profile/UpdateProfilePicture.vue b/src/js/components/profile/UpdateProfilePicture.vue index ee7293ceb..0cc84e4c6 100644 --- a/src/js/components/profile/UpdateProfilePicture.vue +++ b/src/js/components/profile/UpdateProfilePicture.vue @@ -16,13 +16,14 @@ class="organisation-profile-image" />
- Update Profile Picture @@ -39,6 +40,7 @@ import { mapGetters } from "vuex"; //Mixins + import errorModalMixin from "../../mixins/errorModalMixin"; import getToken from "../../mixins/getTokenMixin"; import getThemeMixin from "../../mixins/getThemeMixin"; @@ -71,7 +73,7 @@ rootUrl: "getRootUrl", }), }, - mixins: [getToken, getThemeMixin], + mixins: [errorModalMixin, getToken, getThemeMixin], methods: { setProfilePicture() { //Set the default