mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-26 00:02:26 -04:00 
			
		
		
		
	Update:Chapter editor lookup modal add color legend and style improvements #657
This commit is contained in:
		
							parent
							
								
									63c55f08dc
								
							
						
					
					
						commit
						3a7639f690
					
				| @ -9,7 +9,7 @@ | |||||||
|       </button> |       </button> | ||||||
|       <div class="flex-grow" /> |       <div class="flex-grow" /> | ||||||
|       <p class="text-base">Duration:</p> |       <p class="text-base">Duration:</p> | ||||||
|       <p class="text-base font-mono ml-8">{{ mediaDuration }}</p> |       <p class="text-base font-mono ml-8">{{ $secondsToTimestamp(mediaDurationRounded) }}</p> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div class="flex flex-wrap-reverse justify-center py-4"> |     <div class="flex flex-wrap-reverse justify-center py-4"> | ||||||
| @ -81,7 +81,7 @@ | |||||||
|               <p class="text-xs truncate max-w-sm">{{ track.metadata.filename }}</p> |               <p class="text-xs truncate max-w-sm">{{ track.metadata.filename }}</p> | ||||||
|             </div> |             </div> | ||||||
|             <div class="w-20" style="min-width: 80px"> |             <div class="w-20" style="min-width: 80px"> | ||||||
|               <p class="text-xs font-mono text-gray-200">{{ track.duration }}</p> |               <p class="text-xs font-mono text-gray-200">{{ $secondsToTimestamp(Math.round(track.duration), false, true) }}</p> | ||||||
|             </div> |             </div> | ||||||
|             <div class="w-20 flex justify-center" style="min-width: 80px"> |             <div class="w-20 flex justify-center" style="min-width: 80px"> | ||||||
|               <span v-if="(track.chapters || []).length" class="material-icons text-success text-sm">check</span> |               <span v-if="(track.chapters || []).length" class="material-icons text-success text-sm">check</span> | ||||||
| @ -107,10 +107,16 @@ | |||||||
|           <ui-btn small color="primary" class="mt-5 ml-2" @click="findChapters">Find</ui-btn> |           <ui-btn small color="primary" class="mt-5 ml-2" @click="findChapters">Find</ui-btn> | ||||||
|         </div> |         </div> | ||||||
|         <div v-else class="w-full p-4"> |         <div v-else class="w-full p-4"> | ||||||
|           <p class="mb-4">Duration found: {{ chapterData.runtimeLengthSec }}</p> |           <div class="flex justify-between mb-4"> | ||||||
|           <div v-if="chapterData.runtimeLengthSec > mediaDuration" class="w-full bg-error bg-opacity-25 p-4 text-center mb-2 rounded border border-white border-opacity-10 text-gray-100 text-sm"> |             <p> | ||||||
|             <p>Chapter data invalid duration<br />Your media duration is shorter than duration found</p> |               Duration found: <span class="font-semibold">{{ $secondsToTimestamp(chapterData.runtimeLengthSec) }}</span> | ||||||
|  |             </p> | ||||||
|  |             <p> | ||||||
|  |               Your audiobook duration: <span class="font-semibold">{{ $secondsToTimestamp(mediaDurationRounded) }}</span> | ||||||
|  |             </p> | ||||||
|           </div> |           </div> | ||||||
|  |           <widgets-alert v-if="chapterData.runtimeLengthSec > mediaDurationRounded" type="warning" class="mb-2"> Your audiobook duration is shorter than duration found </widgets-alert> | ||||||
|  |           <widgets-alert v-else-if="chapterData.runtimeLengthSec < mediaDurationRounded" type="warning" class="mb-2"> Your audiobook duration is longer than the duration found </widgets-alert> | ||||||
| 
 | 
 | ||||||
|           <div class="flex py-0.5 text-xs font-semibold uppercase text-gray-300 mb-1"> |           <div class="flex py-0.5 text-xs font-semibold uppercase text-gray-300 mb-1"> | ||||||
|             <div class="w-24 px-2">Start</div> |             <div class="w-24 px-2">Start</div> | ||||||
| @ -126,7 +132,18 @@ | |||||||
|               </div> |               </div> | ||||||
|             </div> |             </div> | ||||||
|           </div> |           </div> | ||||||
|  |           <div v-if="chapterData.runtimeLengthSec > mediaDurationRounded" class="w-full pt-2"> | ||||||
|  |             <div class="flex items-center"> | ||||||
|  |               <div class="w-2 h-2 bg-warning bg-opacity-50" /> | ||||||
|  |               <p class="pl-2">Chapter end is after the end of your audiobook</p> | ||||||
|  |             </div> | ||||||
|  |             <div class="flex items-center"> | ||||||
|  |               <div class="w-2 h-2 bg-error bg-opacity-50" /> | ||||||
|  |               <p class="pl-2">Chapter start is after the end of your audiobook</p> | ||||||
|  |             </div> | ||||||
|  |           </div> | ||||||
|           <div class="flex pt-2"> |           <div class="flex pt-2"> | ||||||
|  |             <ui-btn small color="primary" @click="applyChapterNamesOnly">Apply Names Only</ui-btn> | ||||||
|             <div class="flex-grow" /> |             <div class="flex-grow" /> | ||||||
|             <ui-btn small color="success" @click="applyChapterData">Apply Chapters</ui-btn> |             <ui-btn small color="success" @click="applyChapterData">Apply Chapters</ui-btn> | ||||||
|           </div> |           </div> | ||||||
| @ -197,6 +214,9 @@ export default { | |||||||
|     mediaDuration() { |     mediaDuration() { | ||||||
|       return this.media.duration |       return this.media.duration | ||||||
|     }, |     }, | ||||||
|  |     mediaDurationRounded() { | ||||||
|  |       return Math.round(this.mediaDuration) | ||||||
|  |     }, | ||||||
|     chapters() { |     chapters() { | ||||||
|       return this.media.chapters || [] |       return this.media.chapters || [] | ||||||
|     }, |     }, | ||||||
| @ -369,6 +389,7 @@ export default { | |||||||
|           this.$toast.error('Failed to update chapters') |           this.$toast.error('Failed to update chapters') | ||||||
|         }) |         }) | ||||||
|     }, |     }, | ||||||
|  |     applyChapterNamesOnly() {}, | ||||||
|     applyChapterData() { |     applyChapterData() { | ||||||
|       var index = 0 |       var index = 0 | ||||||
|       this.newChapters = this.chapterData.chapters |       this.newChapters = this.chapterData.chapters | ||||||
|  | |||||||
| @ -27,18 +27,27 @@ Vue.prototype.$elapsedPretty = (seconds, useFullNames = false) => { | |||||||
|   return `${hours} ${useFullNames ? `hour${hours === 1 ? '' : 's'}` : 'hr'} ${minutes} ${useFullNames ? `minute${minutes === 1 ? '' : 's'}` : 'min'}` |   return `${hours} ${useFullNames ? `hour${hours === 1 ? '' : 's'}` : 'hr'} ${minutes} ${useFullNames ? `minute${minutes === 1 ? '' : 's'}` : 'min'}` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Vue.prototype.$secondsToTimestamp = (seconds) => { | Vue.prototype.$secondsToTimestamp = (seconds, includeMs = false, alwaysIncludeHours = false) => { | ||||||
|   if (!seconds) return '0:00' |   if (!seconds) { | ||||||
|  |     return alwaysIncludeHours ? '00:00:00' : '0:00' | ||||||
|  |   } | ||||||
|   var _seconds = seconds |   var _seconds = seconds | ||||||
|   var _minutes = Math.floor(seconds / 60) |   var _minutes = Math.floor(seconds / 60) | ||||||
|   _seconds -= _minutes * 60 |   _seconds -= _minutes * 60 | ||||||
|   var _hours = Math.floor(_minutes / 60) |   var _hours = Math.floor(_minutes / 60) | ||||||
|   _minutes -= _hours * 60 |   _minutes -= _hours * 60 | ||||||
|  | 
 | ||||||
|  |   var ms = _seconds - Math.floor(seconds) | ||||||
|   _seconds = Math.floor(_seconds) |   _seconds = Math.floor(_seconds) | ||||||
|   if (!_hours) { | 
 | ||||||
|     return `${_minutes}:${_seconds.toString().padStart(2, '0')}` |   var msString = includeMs ? '.' + ms.toFixed(3).split('.')[1] : '' | ||||||
|  |   if (alwaysIncludeHours) { | ||||||
|  |     return `${_hours.toString().padStart(2, '0')}:${_minutes.toString().padStart(2, '0')}:${_seconds.toString().padStart(2, '0')}${msString}` | ||||||
|   } |   } | ||||||
|   return `${_hours}:${_minutes.toString().padStart(2, '0')}:${_seconds.toString().padStart(2, '0')}` |   if (!_hours) { | ||||||
|  |     return `${_minutes}:${_seconds.toString().padStart(2, '0')}${msString}` | ||||||
|  |   } | ||||||
|  |   return `${_hours}:${_minutes.toString().padStart(2, '0')}:${_seconds.toString().padStart(2, '0')}${msString}` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Vue.prototype.$elapsedPrettyExtended = (seconds, useDays = true) => { | Vue.prototype.$elapsedPrettyExtended = (seconds, useDays = true) => { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user