mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-25 07:48:56 -04:00 
			
		
		
		
	Show next book only if previous book is finished
This patch changes the books displayed in “Continue Series”, avoiding books if another book from the series is played back right now. This prevents Audiobookshelf suggesting books to which users will not listen to because they are still listening to the last one. Once a book is finished, the next book in the series will pop still be suggested to the user. This fixes #1382
This commit is contained in:
		
							parent
							
								
									5ed06871b6
								
							
						
					
					
						commit
						02c4b21d3f
					
				| @ -499,6 +499,7 @@ module.exports = { | |||||||
|           for (const librarySeries of libraryItem.media.metadata.series) { |           for (const librarySeries of libraryItem.media.metadata.series) { | ||||||
|             const mediaProgress = allItemProgress.length ? allItemProgress[0] : null |             const mediaProgress = allItemProgress.length ? allItemProgress[0] : null | ||||||
|             const bookInProgress = mediaProgress && (mediaProgress.inProgress || mediaProgress.isFinished) |             const bookInProgress = mediaProgress && (mediaProgress.inProgress || mediaProgress.isFinished) | ||||||
|  |             const bookActive = mediaProgress && mediaProgress.inProgress && !mediaProgress.isFinished | ||||||
|             const libraryItemJson = libraryItem.toJSONMinified() |             const libraryItemJson = libraryItem.toJSONMinified() | ||||||
|             libraryItemJson.seriesSequence = librarySeries.sequence |             libraryItemJson.seriesSequence = librarySeries.sequence | ||||||
| 
 | 
 | ||||||
| @ -511,6 +512,7 @@ module.exports = { | |||||||
|                   ...seriesObj.toJSON(), |                   ...seriesObj.toJSON(), | ||||||
|                   books: [libraryItemJson], |                   books: [libraryItemJson], | ||||||
|                   inProgress: bookInProgress, |                   inProgress: bookInProgress, | ||||||
|  |                   hasActiveBook: bookActive, | ||||||
|                   hideFromContinueListening, |                   hideFromContinueListening, | ||||||
|                   bookInProgressLastUpdate: bookInProgress ? mediaProgress.lastUpdate : null, |                   bookInProgressLastUpdate: bookInProgress ? mediaProgress.lastUpdate : null, | ||||||
|                   firstBookUnread: bookInProgress ? null : libraryItemJson |                   firstBookUnread: bookInProgress ? null : libraryItemJson | ||||||
| @ -553,6 +555,11 @@ module.exports = { | |||||||
|                   seriesMap[librarySeries.id].firstBookUnread = libraryItemJson |                   seriesMap[librarySeries.id].firstBookUnread = libraryItemJson | ||||||
|                 } |                 } | ||||||
|               } |               } | ||||||
|  | 
 | ||||||
|  |               // Update if series has an active (progress < 100%) book
 | ||||||
|  |               if (bookActive) { | ||||||
|  |                 seriesMap[librarySeries.id].hasActiveBook = true | ||||||
|  |               } | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
| @ -648,10 +655,12 @@ module.exports = { | |||||||
|       if (seriesMap[seriesId].inProgress && !seriesMap[seriesId].hideFromContinueListening) { |       if (seriesMap[seriesId].inProgress && !seriesMap[seriesId].hideFromContinueListening) { | ||||||
|         seriesMap[seriesId].books = naturalSort(seriesMap[seriesId].books).asc(li => li.seriesSequence) |         seriesMap[seriesId].books = naturalSort(seriesMap[seriesId].books).asc(li => li.seriesSequence) | ||||||
| 
 | 
 | ||||||
|         // NEW implementation takes the first book unread with the smallest series sequence
 |         // take the first book unread with the smallest series sequence
 | ||||||
|  |         // unless the user is already listening to a book from this series
 | ||||||
|  |         const hasActiveBook = seriesMap[seriesId].hasActiveBook | ||||||
|         const nextBookInSeries = seriesMap[seriesId].firstBookUnread |         const nextBookInSeries = seriesMap[seriesId].firstBookUnread | ||||||
| 
 | 
 | ||||||
|         if (nextBookInSeries) { |         if (!hasActiveBook && nextBookInSeries) { | ||||||
|           const bookForContinueSeries = { |           const bookForContinueSeries = { | ||||||
|             ...nextBookInSeries, |             ...nextBookInSeries, | ||||||
|             prevBookInProgressLastUpdate: seriesMap[seriesId].bookInProgressLastUpdate |             prevBookInProgressLastUpdate: seriesMap[seriesId].bookInProgressLastUpdate | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user