Fixed: Edit path on artist index resetting cursor to end on change

Co-Authored-By: Mark McDowall <markus101@users.noreply.github.com>
pull/6/head
Qstick 6 years ago
parent d6b210a4c9
commit 2273be5afd

@ -18,10 +18,19 @@ class PathInput extends Component {
this._node = document.getElementById('portal-root'); this._node = document.getElementById('portal-root');
this.state = { this.state = {
value: props.value,
isFileBrowserModalOpen: false isFileBrowserModalOpen: false
}; };
} }
componentDidUpdate(prevProps) {
const { value } = this.props;
if (prevProps.value !== value) {
this.setState({ value });
}
}
// //
// Control // Control
@ -51,11 +60,8 @@ class PathInput extends Component {
// //
// Listeners // Listeners
onInputChange = (event, { newValue }) => { onInputChange = ({ value }) => {
this.props.onChange({ this.setState({ value });
name: this.props.name,
value: newValue
});
} }
onInputKeyDown = (event) => { onInputKeyDown = (event) => {
@ -77,6 +83,11 @@ class PathInput extends Component {
} }
onInputBlur = () => { onInputBlur = () => {
this.props.onChange({
name: this.props.name,
value: this.state.value
});
this.props.onClearPaths(); this.props.onClearPaths();
} }
@ -108,13 +119,18 @@ class PathInput extends Component {
const { const {
className, className,
name, name,
value,
paths, paths,
includeFiles, includeFiles,
hasFileBrowser, hasFileBrowser,
onChange, onChange,
...otherProps ...otherProps
} = this.props; } = this.props;
const {
value,
isFileBrowserModalOpen
} = this.state;
return ( return (
<div className={className}> <div className={className}>
<AutoSuggestInput <AutoSuggestInput
@ -130,7 +146,7 @@ class PathInput extends Component {
onSuggestionSelected={this.onSuggestionSelected} onSuggestionSelected={this.onSuggestionSelected}
onSuggestionsFetchRequested={this.onSuggestionsFetchRequested} onSuggestionsFetchRequested={this.onSuggestionsFetchRequested}
onSuggestionsClearRequested={this.onSuggestionsClearRequested} onSuggestionsClearRequested={this.onSuggestionsClearRequested}
onChange={onChange} onChange={this.onInputChange}
/> />
{ {
@ -144,7 +160,7 @@ class PathInput extends Component {
</FormInputButton> </FormInputButton>
<FileBrowserModal <FileBrowserModal
isOpen={this.state.isFileBrowserModalOpen} isOpen={isFileBrowserModalOpen}
name={name} name={name}
value={value} value={value}
includeFiles={includeFiles} includeFiles={includeFiles}

@ -197,7 +197,7 @@ export const toggleAlbumMonitored = createThunk(TOGGLE_ALBUM_MONITORED);
export const setArtistValue = createAction(SET_ARTIST_VALUE, (payload) => { export const setArtistValue = createAction(SET_ARTIST_VALUE, (payload) => {
return { return {
section: 'artist', section,
...payload ...payload
}; };
}); });

Loading…
Cancel
Save