mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	Add:Edit button and play button on audiobook landing page cover #360, Fix:Playback rate controller sending change events
This commit is contained in:
		
							parent
							
								
									db25affd43
								
							
						
					
					
						commit
						c046f9ee98
					
				@ -39,13 +39,13 @@
 | 
				
			|||||||
    <!-- Overlay is not shown if collapsing series in library -->
 | 
					    <!-- Overlay is not shown if collapsing series in library -->
 | 
				
			||||||
    <div v-show="!booksInSeries && audiobook && (isHovering || isSelectionMode || isMoreMenuOpen)" class="w-full h-full absolute top-0 left-0 z-10 bg-black rounded hidden md:block" :class="overlayWrapperClasslist">
 | 
					    <div v-show="!booksInSeries && audiobook && (isHovering || isSelectionMode || isMoreMenuOpen)" class="w-full h-full absolute top-0 left-0 z-10 bg-black rounded hidden md:block" :class="overlayWrapperClasslist">
 | 
				
			||||||
      <div v-show="showPlayButton" class="h-full flex items-center justify-center pointer-events-none">
 | 
					      <div v-show="showPlayButton" class="h-full flex items-center justify-center pointer-events-none">
 | 
				
			||||||
        <div class="hover:text-gray-200 hover:scale-110 transform duration-200 pointer-events-auto" @click.stop.prevent="play">
 | 
					        <div class="hover:text-white text-gray-200 hover:scale-110 transform duration-200 pointer-events-auto" @click.stop.prevent="play">
 | 
				
			||||||
          <span class="material-icons" :style="{ fontSize: playIconFontSize + 'rem' }">play_circle_filled</span>
 | 
					          <span class="material-icons" :style="{ fontSize: playIconFontSize + 'rem' }">play_circle_filled</span>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div v-show="showReadButton" class="h-full flex items-center justify-center pointer-events-none">
 | 
					      <div v-show="showReadButton" class="h-full flex items-center justify-center pointer-events-none">
 | 
				
			||||||
        <div class="hover:text-gray-200 hover:scale-110 transform duration-200 pointer-events-auto" @click.stop.prevent="clickReadEBook">
 | 
					        <div class="hover:text-white text-gray-200 hover:scale-110 transform duration-200 pointer-events-auto" @click.stop.prevent="clickReadEBook">
 | 
				
			||||||
          <span class="material-icons" :style="{ fontSize: playIconFontSize + 'rem' }">auto_stories</span>
 | 
					          <span class="material-icons" :style="{ fontSize: playIconFontSize + 'rem' }">auto_stories</span>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -89,6 +89,8 @@ export default {
 | 
				
			|||||||
      this.showMenu = val
 | 
					      this.showMenu = val
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  mounted() {}
 | 
					  mounted() {
 | 
				
			||||||
 | 
					    this.currentPlaybackRate = this.playbackRate
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
@ -5,7 +5,20 @@
 | 
				
			|||||||
        <div class="w-full flex justify-center md:block md:w-52" style="min-width: 208px">
 | 
					        <div class="w-full flex justify-center md:block md:w-52" style="min-width: 208px">
 | 
				
			||||||
          <div class="relative" style="height: fit-content">
 | 
					          <div class="relative" style="height: fit-content">
 | 
				
			||||||
            <covers-book-cover :audiobook="audiobook" :width="bookCoverWidth" :book-cover-aspect-ratio="bookCoverAspectRatio" />
 | 
					            <covers-book-cover :audiobook="audiobook" :width="bookCoverWidth" :book-cover-aspect-ratio="bookCoverAspectRatio" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            <!-- Book Progress Bar -->
 | 
				
			||||||
            <div class="absolute bottom-0 left-0 h-1.5 bg-yellow-400 shadow-sm z-10" :class="userIsRead ? 'bg-success' : 'bg-yellow-400'" :style="{ width: 208 * progressPercent + 'px' }"></div>
 | 
					            <div class="absolute bottom-0 left-0 h-1.5 bg-yellow-400 shadow-sm z-10" :class="userIsRead ? 'bg-success' : 'bg-yellow-400'" :style="{ width: 208 * progressPercent + 'px' }"></div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					            <!-- Book Cover Overlay -->
 | 
				
			||||||
 | 
					            <div class="absolute top-0 left-0 w-full h-full z-10 bg-black bg-opacity-30 opacity-0 hover:opacity-100 transition-opacity" @mousedown.prevent @mouseup.prevent>
 | 
				
			||||||
 | 
					              <div v-show="showPlayButton && !streaming" class="h-full flex items-center justify-center pointer-events-none">
 | 
				
			||||||
 | 
					                <div class="hover:text-white text-gray-200 hover:scale-110 transform duration-200 pointer-events-auto cursor-pointer" @click.stop.prevent="startStream">
 | 
				
			||||||
 | 
					                  <span class="material-icons text-4xl">play_circle_filled</span>
 | 
				
			||||||
 | 
					                </div>
 | 
				
			||||||
 | 
					              </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					              <span class="absolute bottom-2.5 right-2.5 z-10 material-icons text-lg cursor-pointer text-white text-opacity-75 hover:text-opacity-100 hover:scale-110 transform duration-200" @click="showEditCover">edit</span>
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="flex-grow px-2 py-6 md:py-0 md:px-10">
 | 
					        <div class="flex-grow px-2 py-6 md:py-0 md:px-10">
 | 
				
			||||||
@ -378,6 +391,10 @@ export default {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  methods: {
 | 
					  methods: {
 | 
				
			||||||
 | 
					    showEditCover() {
 | 
				
			||||||
 | 
					      this.$store.commit('setBookshelfBookIds', [])
 | 
				
			||||||
 | 
					      this.$store.commit('showEditModalOnTab', { audiobook: this.audiobook, tab: 'cover' })
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    openEbook() {
 | 
					    openEbook() {
 | 
				
			||||||
      this.$store.commit('showEReader', this.audiobook)
 | 
					      this.$store.commit('showEReader', this.audiobook)
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user