|
|
@ -16,11 +16,32 @@ import AlbumDetails from './AlbumDetails';
|
|
|
|
import createAllArtistSelector from 'Store/Selectors/createAllArtistSelector';
|
|
|
|
import createAllArtistSelector from 'Store/Selectors/createAllArtistSelector';
|
|
|
|
import createUISettingsSelector from 'Store/Selectors/createUISettingsSelector';
|
|
|
|
import createUISettingsSelector from 'Store/Selectors/createUISettingsSelector';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const selectTrackFiles = createSelector(
|
|
|
|
|
|
|
|
(state) => state.trackFiles,
|
|
|
|
|
|
|
|
(trackFiles) => {
|
|
|
|
|
|
|
|
const {
|
|
|
|
|
|
|
|
items,
|
|
|
|
|
|
|
|
isFetching,
|
|
|
|
|
|
|
|
isPopulated,
|
|
|
|
|
|
|
|
error
|
|
|
|
|
|
|
|
} = trackFiles;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const hasTrackFiles = !!items.length;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
|
|
isTrackFilesFetching: isFetching,
|
|
|
|
|
|
|
|
isTrackFilesPopulated: isPopulated,
|
|
|
|
|
|
|
|
trackFilesError: error,
|
|
|
|
|
|
|
|
hasTrackFiles
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
function createMapStateToProps() {
|
|
|
|
function createMapStateToProps() {
|
|
|
|
return createSelector(
|
|
|
|
return createSelector(
|
|
|
|
(state, { foreignAlbumId }) => foreignAlbumId,
|
|
|
|
(state, { foreignAlbumId }) => foreignAlbumId,
|
|
|
|
(state) => state.tracks,
|
|
|
|
(state) => state.tracks,
|
|
|
|
(state) => state.trackFiles,
|
|
|
|
selectTrackFiles,
|
|
|
|
(state) => state.albums,
|
|
|
|
(state) => state.albums,
|
|
|
|
createAllArtistSelector(),
|
|
|
|
createAllArtistSelector(),
|
|
|
|
createCommandsSelector(),
|
|
|
|
createCommandsSelector(),
|
|
|
@ -35,14 +56,20 @@ function createMapStateToProps() {
|
|
|
|
return {};
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const {
|
|
|
|
|
|
|
|
isTrackFilesFetching,
|
|
|
|
|
|
|
|
isTrackFilesPopulated,
|
|
|
|
|
|
|
|
trackFilesError,
|
|
|
|
|
|
|
|
hasTrackFiles
|
|
|
|
|
|
|
|
} = trackFiles;
|
|
|
|
|
|
|
|
|
|
|
|
const previousAlbum = sortedAlbums[albumIndex - 1] || _.last(sortedAlbums);
|
|
|
|
const previousAlbum = sortedAlbums[albumIndex - 1] || _.last(sortedAlbums);
|
|
|
|
const nextAlbum = sortedAlbums[albumIndex + 1] || _.first(sortedAlbums);
|
|
|
|
const nextAlbum = sortedAlbums[albumIndex + 1] || _.first(sortedAlbums);
|
|
|
|
const isSearching = !!findCommand(commands, { name: commandNames.ALBUM_SEARCH });
|
|
|
|
const isSearching = !!findCommand(commands, { name: commandNames.ALBUM_SEARCH });
|
|
|
|
|
|
|
|
|
|
|
|
const isFetching = tracks.isFetching || trackFiles.isFetching;
|
|
|
|
const isFetching = tracks.isFetching || isTrackFilesFetching;
|
|
|
|
const isPopulated = tracks.isPopulated && trackFiles.isPopulated;
|
|
|
|
const isPopulated = tracks.isPopulated && isTrackFilesPopulated;
|
|
|
|
const tracksError = tracks.error;
|
|
|
|
const tracksError = tracks.error;
|
|
|
|
const trackFilesError = trackFiles.error;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
return {
|
|
|
|
...album,
|
|
|
|
...album,
|
|
|
@ -53,6 +80,7 @@ function createMapStateToProps() {
|
|
|
|
isPopulated,
|
|
|
|
isPopulated,
|
|
|
|
tracksError,
|
|
|
|
tracksError,
|
|
|
|
trackFilesError,
|
|
|
|
trackFilesError,
|
|
|
|
|
|
|
|
hasTrackFiles,
|
|
|
|
previousAlbum,
|
|
|
|
previousAlbum,
|
|
|
|
nextAlbum
|
|
|
|
nextAlbum
|
|
|
|
};
|
|
|
|
};
|
|
|
|