From 829eed0b9f8c42096eb47a5f0656eef60e28a8ca Mon Sep 17 00:00:00 2001 From: Dominik Pschenitschni Date: Sun, 22 May 2022 15:13:12 +0000 Subject: [PATCH] fix: problem with newTaskInput ref (#1986) Co-authored-by: Dominik Pschenitschni Reviewed-on: https://kolaente.dev/vikunja/frontend/pulls/1986 Co-authored-by: Dominik Pschenitschni Co-committed-by: Dominik Pschenitschni --- src/views/tasks/TaskDetailView.vue | 40 +++++++++++++++++++++--------- 1 file changed, 28 insertions(+), 12 deletions(-) diff --git a/src/views/tasks/TaskDetailView.vue b/src/views/tasks/TaskDetailView.vue index 01087ec6..dba01611 100644 --- a/src/views/tasks/TaskDetailView.vue +++ b/src/views/tasks/TaskDetailView.vue @@ -445,6 +445,26 @@ import ChecklistSummary from '../../components/tasks/partials/checklist-summary' import CreatedUpdated from '@/components/tasks/partials/createdUpdated' import { setTitle } from '@/helpers/setTitle' +function scrollIntoView(el) { + if (!el) { + return + } + + const boundingRect = el.getBoundingClientRect() + const scrollY = window.scrollY + + if ( + boundingRect.top > (scrollY + window.innerHeight) || + boundingRect.top < scrollY + ) { + el.scrollIntoView({ + behavior: 'smooth', + block: 'center', + inline: 'nearest', + }) + } +} + export default defineComponent({ name: 'TaskDetailView', compatConfig: { ATTR_FALSE_VALUE: false }, @@ -643,19 +663,15 @@ export default defineComponent({ setFieldActive(fieldName) { this.activeFields[fieldName] = true this.$nextTick(() => { - if (this.$refs[fieldName]) { - this.$refs[fieldName].$el.focus() - - // scroll the field to the center of the screen if not in viewport already - const boundingRect = this.$refs[fieldName].$el.getBoundingClientRect() - - if (boundingRect.top > (window.scrollY + window.innerHeight) || boundingRect.top < window.scrollY) - this.$refs[fieldName].$el.scrollIntoView({ - behavior: 'smooth', - block: 'center', - inline: 'nearest', - }) + const el = this.$refs[fieldName]?.$el + if (!el) { + return } + + el.focus() + + // scroll the field to the center of the screen if not in viewport already + scrollIntoView(el) }) },