From 2b254dfff6a3a68f1c7ac9f1dbb88d6d4d696099 Mon Sep 17 00:00:00 2001 From: Peter Kulko Date: Mon, 13 Jan 2025 18:53:21 +0200 Subject: [PATCH] refactor: fixed scroll behavior to xblock element --- .../add-component/AddComponent.jsx | 1 + .../hooks/useMessageHandlers.tsx | 39 +++++++++++++------ .../configure-modal/ConfigureModal.jsx | 2 +- src/generic/configure-modal/UnitTab.jsx | 5 ++- 4 files changed, 33 insertions(+), 14 deletions(-) diff --git a/src/course-unit/add-component/AddComponent.jsx b/src/course-unit/add-component/AddComponent.jsx index 70962a7ac6..ac1a815dd4 100644 --- a/src/course-unit/add-component/AddComponent.jsx +++ b/src/course-unit/add-component/AddComponent.jsx @@ -61,6 +61,7 @@ const AddComponent = ({ blockId, handleCreateNewCourseXBlock }) => { case COMPONENT_TYPES.problem: case COMPONENT_TYPES.video: handleCreateNewCourseXBlock({ type, parentLocator: blockId }, ({ courseKey, locator }) => { + localStorage.setItem('modalEditLastYPosition', window.scrollY); navigate(`/course/${courseKey}/editor/${type}/${locator}`); }); break; diff --git a/src/course-unit/xblock-container-iframe/hooks/useMessageHandlers.tsx b/src/course-unit/xblock-container-iframe/hooks/useMessageHandlers.tsx index 8d40999304..81562074b1 100644 --- a/src/course-unit/xblock-container-iframe/hooks/useMessageHandlers.tsx +++ b/src/course-unit/xblock-container-iframe/hooks/useMessageHandlers.tsx @@ -1,4 +1,5 @@ import { useMemo } from 'react'; +import { debounce } from 'lodash'; import { copyToClipboard } from '../../../generic/data/thunks'; import { messageTypes } from '../../constants'; @@ -19,17 +20,33 @@ export const useMessageHandlers = ({ handleDuplicateXBlock, handleScrollToXBlock, handleManageXBlockAccess, -}: UseMessageHandlersTypes): MessageHandlersTypes => useMemo(() => ({ - [messageTypes.copyXBlock]: ({ usageId }) => dispatch(copyToClipboard(usageId)), - [messageTypes.deleteXBlock]: ({ usageId }) => handleDeleteXBlock(usageId), - [messageTypes.newXBlockEditor]: ({ blockType, usageId }) => navigate(`/course/${courseId}/editor/${blockType}/${usageId}`), - [messageTypes.duplicateXBlock]: ({ blockType, usageId }) => handleDuplicateXBlock(blockType, usageId), - [messageTypes.manageXBlockAccess]: ({ usageId }) => handleManageXBlockAccess(usageId), - [messageTypes.scrollToXBlock]: ({ scrollOffset }) => handleScrollToXBlock(scrollOffset), - [messageTypes.toggleCourseXBlockDropdown]: ({ - courseXBlockDropdownHeight, - }: { courseXBlockDropdownHeight: number }) => setIframeOffset(courseXBlockDropdownHeight), -}), [ +}: UseMessageHandlersTypes): MessageHandlersTypes => useMemo(() => { + const handleResizeDebounced = debounce(() => { + const scrollOffsetString = localStorage.getItem('modalEditLastYPosition'); + const scrollOffset = scrollOffsetString ? parseInt(scrollOffsetString, 10) : 0; + + if (scrollOffset) { + window.scrollBy({ + top: scrollOffset, + behavior: 'smooth', + }); + localStorage.removeItem('modalEditLastYPosition'); + } + }, 2000); + + return { + [messageTypes.copyXBlock]: ({ usageId }) => dispatch(copyToClipboard(usageId)), + [messageTypes.deleteXBlock]: ({ usageId }) => handleDeleteXBlock(usageId), + [messageTypes.newXBlockEditor]: ({ blockType, usageId }) => navigate(`/course/${courseId}/editor/${blockType}/${usageId}`), + [messageTypes.duplicateXBlock]: ({ blockType, usageId }) => handleDuplicateXBlock(blockType, usageId), + [messageTypes.manageXBlockAccess]: ({ usageId }) => handleManageXBlockAccess(usageId), + [messageTypes.scrollToXBlock]: debounce(({ scrollOffset }) => handleScrollToXBlock(scrollOffset), 3000), + [messageTypes.resize]: handleResizeDebounced, + [messageTypes.toggleCourseXBlockDropdown]: ({ + courseXBlockDropdownHeight, + }: { courseXBlockDropdownHeight: number }) => setIframeOffset(courseXBlockDropdownHeight), + }; +}, [ courseId, handleDeleteXBlock, handleDuplicateXBlock, diff --git a/src/generic/configure-modal/ConfigureModal.jsx b/src/generic/configure-modal/ConfigureModal.jsx index 04c82200df..4aa03435f1 100644 --- a/src/generic/configure-modal/ConfigureModal.jsx +++ b/src/generic/configure-modal/ConfigureModal.jsx @@ -365,7 +365,7 @@ ConfigureModal.propTypes = { supportsOnboarding: PropTypes.bool, showReviewRules: PropTypes.bool, onlineProctoringRules: PropTypes.string, - discussionEnabled: PropTypes.bool.isRequired, + discussionEnabled: PropTypes.bool, }).isRequired, isXBlockComponent: PropTypes.bool, isSelfPaced: PropTypes.bool.isRequired, diff --git a/src/generic/configure-modal/UnitTab.jsx b/src/generic/configure-modal/UnitTab.jsx index 01e18be075..28d7ab45ac 100644 --- a/src/generic/configure-modal/UnitTab.jsx +++ b/src/generic/configure-modal/UnitTab.jsx @@ -152,13 +152,14 @@ UnitTab.propTypes = { isXBlockComponent: PropTypes.bool, values: PropTypes.shape({ isVisibleToStaffOnly: PropTypes.bool.isRequired, - discussionEnabled: PropTypes.bool.isRequired, + discussionEnabled: PropTypes.bool, selectedPartitionIndex: PropTypes.oneOfType([ PropTypes.string, PropTypes.number, ]).isRequired, selectedGroups: PropTypes.oneOfType([ - PropTypes.string, + PropTypes.arrayOf(PropTypes.string), + PropTypes.array, ]), }).isRequired, setFieldValue: PropTypes.func.isRequired,