Skip to content

Commit

Permalink
🚸 [#437] Implement cursor start/end on Home/End keypress
Browse files Browse the repository at this point in the history
Solution taken from react-select issue/discussion.

There is some ambiguity on what the behaviour should be on MacOS, but
due to lack of appropriate device we're leaving that as it is, for
now.
  • Loading branch information
sergei-maertens committed Oct 16, 2023
1 parent 2787793 commit 44e502f
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions src/components/forms/SelectField/SelectField.js
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,24 @@ const SelectField = ({
[autoSelectOnlyOption, isSingle, value, JSON.stringify(options), setValue, valueProperty]
);

// Taken from snippet posted in react-select issue:
// https://github.com/JedWatson/react-select/issues/3562#issuecomment-518841754
const handleKeyDown = evt => {
switch (evt.key) {
case 'Home':
evt.preventDefault();
if (evt.shiftKey) evt.target.selectionStart = 0;
else evt.target.setSelectionRange(0, 0);
break;
case 'End':
evt.preventDefault();
const len = evt.target.value.length;
if (evt.shiftKey) evt.target.selectionEnd = len;
else evt.target.setSelectionRange(len, len);
break;
}
};

return (
<Wrapper>
<FormField invalid={invalid} className="utrecht-form-field--openforms">
Expand Down Expand Up @@ -105,6 +123,7 @@ const SelectField = ({
defaultMessage="No results found"
/>
)}
onKeyDown={handleKeyDown}
{...props}
onChange={newValue => {
const isSingle = !Array.isArray(newValue);
Expand Down

0 comments on commit 44e502f

Please sign in to comment.