Skip to content

Commit

Permalink
Merge pull request #29203 from tienifr/fix/22850-task-title-is-not-fo…
Browse files Browse the repository at this point in the history
…cused

fix: 22850 task title is not focused after refresh
  • Loading branch information
stitesExpensify authored Oct 12, 2023
2 parents d30a850 + c3a6b42 commit 3b98327
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 4 deletions.
40 changes: 40 additions & 0 deletions src/hooks/useAutoFocusInput.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
import {useFocusEffect} from '@react-navigation/native';
import {useState, useEffect, useRef, useCallback} from 'react';
import CONST from '../CONST';

export default function useAutoFocusInput() {
const [isInputInitialized, setIsInputInitialized] = useState(false);
const [isScreenTransitionEnded, setIsScreenTransitionEnded] = useState(false);

const inputRef = useRef(null);
const focusTimeoutRef = useRef(null);

useEffect(() => {
if (!isScreenTransitionEnded || !isInputInitialized || !inputRef.current) {
return;
}
inputRef.current.focus();
}, [isScreenTransitionEnded, isInputInitialized]);

useFocusEffect(
useCallback(() => {
focusTimeoutRef.current = setTimeout(() => {
setIsScreenTransitionEnded(true);
}, CONST.ANIMATED_TRANSITION);
return () => {
if (!focusTimeoutRef.current) {
return;
}
clearTimeout(focusTimeoutRef.current);
};
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []),
);

const inputCallbackRef = (ref) => {
inputRef.current = ref;
setIsInputInitialized(true);
};

return {inputCallbackRef};
}
9 changes: 5 additions & 4 deletions src/pages/tasks/NewTaskDetailsPage.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import React, {useEffect, useRef, useState} from 'react';
import React, {useEffect, useState} from 'react';
import {View} from 'react-native';
import {withOnyx} from 'react-native-onyx';
import PropTypes from 'prop-types';
Expand All @@ -17,6 +17,7 @@ import ROUTES from '../../ROUTES';
import * as Task from '../../libs/actions/Task';
import CONST from '../../CONST';
import * as Browser from '../../libs/Browser';
import useAutoFocusInput from '../../hooks/useAutoFocusInput';

const propTypes = {
/** Beta features list */
Expand All @@ -37,10 +38,11 @@ const defaultProps = {
};

function NewTaskDetailsPage(props) {
const inputRef = useRef();
const [taskTitle, setTaskTitle] = useState(props.task.title);
const [taskDescription, setTaskDescription] = useState(props.task.description || '');

const {inputCallbackRef} = useAutoFocusInput();

useEffect(() => {
setTaskTitle(props.task.title);
setTaskDescription(props.task.description || '');
Expand Down Expand Up @@ -74,7 +76,6 @@ function NewTaskDetailsPage(props) {
}
return (
<ScreenWrapper
onEntryTransitionEnd={() => inputRef.current && inputRef.current.focus()}
includeSafeAreaPaddingBottom={false}
shouldEnableMaxHeight
testID={NewTaskDetailsPage.displayName}
Expand All @@ -95,7 +96,7 @@ function NewTaskDetailsPage(props) {
>
<View style={styles.mb5}>
<TextInput
ref={(el) => (inputRef.current = el)}
ref={inputCallbackRef}
accessibilityRole={CONST.ACCESSIBILITY_ROLE.TEXT}
inputID="taskTitle"
label={props.translate('task.title')}
Expand Down

0 comments on commit 3b98327

Please sign in to comment.