From f0365eaaa7ba7fdbb3d7ff014f76e2ae8b4d01b4 Mon Sep 17 00:00:00 2001 From: Qstick Date: Fri, 5 Apr 2019 23:08:07 -0400 Subject: [PATCH] Fixed: Error displayed occasionally after removing artist Co-Authored-By: Mark McDowall --- .../Artist/Index/ArtistIndexItemConnector.js | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/frontend/src/Artist/Index/ArtistIndexItemConnector.js b/frontend/src/Artist/Index/ArtistIndexItemConnector.js index 8b997b631..740298e29 100644 --- a/frontend/src/Artist/Index/ArtistIndexItemConnector.js +++ b/frontend/src/Artist/Index/ArtistIndexItemConnector.js @@ -48,6 +48,16 @@ function createMapStateToProps() { showSearchAction, executingCommands ) => { + + // If an artist is deleted this selector may fire before the parent + // selectors, which will result in an undefined artist, if that happens + // we want to return early here and again in the render function to avoid + // trying to show an artist that has no information available. + + if (!artist) { + return {}; + } + const isRefreshingArtist = executingCommands.some((command) => { return ( command.name === commandNames.REFRESH_ARTIST && @@ -106,13 +116,19 @@ class ArtistIndexItemConnector extends Component { render() { const { + id, component: ItemComponent, ...otherProps } = this.props; + if (!id) { + return null; + } + return ( @@ -121,7 +137,7 @@ class ArtistIndexItemConnector extends Component { } ArtistIndexItemConnector.propTypes = { - id: PropTypes.number.isRequired, + id: PropTypes.number, component: PropTypes.func.isRequired, executeCommand: PropTypes.func.isRequired };