From ab5c528b21b7a9d6c7b7e34e95fa860ef8cc82d8 Mon Sep 17 00:00:00 2001 From: m4g4 Date: Wed, 4 Dec 2024 15:11:46 +0100 Subject: [PATCH 1/2] Fixed the scrolling of the selected menu option into view for menu portals. --- packages/react-select/src/Select.tsx | 33 +++++++--------------------- 1 file changed, 8 insertions(+), 25 deletions(-) diff --git a/packages/react-select/src/Select.tsx b/packages/react-select/src/Select.tsx index dadde14dd..e33419287 100644 --- a/packages/react-select/src/Select.tsx +++ b/packages/react-select/src/Select.tsx @@ -655,7 +655,6 @@ export default class Select< initialTouchX = 0; initialTouchY = 0; openAfterFocus = false; - scrollToFocusedOptionOnUpdate = false; userIsDragging?: boolean; isAppleDevice = isAppleDevice(); @@ -669,10 +668,12 @@ export default class Select< focusedOptionRef: HTMLDivElement | null = null; getFocusedOptionRef: RefCallback = (ref) => { this.focusedOptionRef = ref; + this.tryScrollIntoView(); }; menuListRef: HTMLDivElement | null = null; getMenuListRef: RefCallback = (ref) => { this.menuListRef = ref; + this.tryScrollIntoView(); }; inputRef: HTMLInputElement | null = null; getInputRef: RefCallback = (ref) => { @@ -805,16 +806,6 @@ export default class Select< if (this.props.autoFocus) { this.focusInput(); } - - // Scroll focusedOption into view if menuIsOpen is set on mount (e.g. defaultMenuIsOpen) - if ( - this.props.menuIsOpen && - this.state.focusedOption && - this.menuListRef && - this.focusedOptionRef - ) { - scrollIntoView(this.menuListRef, this.focusedOptionRef); - } } componentDidUpdate(prevProps: Props) { const { isDisabled, menuIsOpen } = this.props; @@ -843,16 +834,6 @@ export default class Select< // eslint-disable-next-line react/no-did-update-set-state this.setState({ isFocused: true }); } - - // scroll the focused option into view if necessary - if ( - this.menuListRef && - this.focusedOptionRef && - this.scrollToFocusedOptionOnUpdate - ) { - scrollIntoView(this.menuListRef, this.focusedOptionRef); - this.scrollToFocusedOptionOnUpdate = false; - } } componentWillUnmount() { this.stopListeningComposition(); @@ -864,6 +845,11 @@ export default class Select< // Consumer Handlers // ============================== + tryScrollIntoView() { + if (this.menuListRef && this.focusedOptionRef) { + scrollIntoView(this.menuListRef, this.focusedOptionRef); + } + } onMenuOpen() { this.props.onMenuOpen(); } @@ -908,9 +894,6 @@ export default class Select< } } - // only scroll if the menu isn't already open - this.scrollToFocusedOptionOnUpdate = !(isFocused && this.menuListRef); - this.setState( { inputIsHiddenAfterUpdate: false, @@ -990,7 +973,7 @@ export default class Select< } else if (direction === 'last') { nextFocus = options.length - 1; } - this.scrollToFocusedOptionOnUpdate = true; + this.setState({ focusedOption: options[nextFocus], focusedValue: null, From 337c2351bbda24ec244686f3c20ccf9530447365 Mon Sep 17 00:00:00 2001 From: m4g4 Date: Thu, 5 Dec 2024 09:49:02 +0100 Subject: [PATCH 2/2] Removed unused isFocused --- packages/react-select/src/Select.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/react-select/src/Select.tsx b/packages/react-select/src/Select.tsx index e33419287..9b05cc029 100644 --- a/packages/react-select/src/Select.tsx +++ b/packages/react-select/src/Select.tsx @@ -883,7 +883,7 @@ export default class Select< blur = this.blurInput; openMenu(focusOption: 'first' | 'last') { - const { selectValue, isFocused } = this.state; + const { selectValue } = this.state; const focusableOptions = this.buildFocusableOptions(); let openAtIndex = focusOption === 'first' ? 0 : focusableOptions.length - 1;