mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-25 15:52:26 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			145 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <div class="w-full h-full px-1 md:px-4 py-1 mb-4">
 | |
|     <div class="flex items-center py-3">
 | |
|       <ui-toggle-switch v-model="useSquareBookCovers" @input="formUpdated" />
 | |
|       <ui-tooltip :text="$strings.LabelSettingsSquareBookCoversHelp">
 | |
|         <p class="pl-4 text-base">
 | |
|           {{ $strings.LabelSettingsSquareBookCovers }}
 | |
|           <span class="material-icons icon-text text-sm">info_outlined</span>
 | |
|         </p>
 | |
|       </ui-tooltip>
 | |
|     </div>
 | |
|     <div class="py-3">
 | |
|       <div class="flex items-center">
 | |
|         <ui-toggle-switch v-if="!globalWatcherDisabled" v-model="enableWatcher" @input="formUpdated" />
 | |
|         <ui-toggle-switch v-else disabled :value="false" />
 | |
|         <p class="pl-4 text-base">{{ $strings.LabelSettingsEnableWatcherForLibrary }}</p>
 | |
|       </div>
 | |
|       <p v-if="globalWatcherDisabled" class="text-xs text-warning">*{{ $strings.MessageWatcherIsDisabledGlobally }}</p>
 | |
|     </div>
 | |
|     <div v-if="isBookLibrary" class="flex items-center py-3">
 | |
|       <ui-toggle-switch v-model="audiobooksOnly" @input="formUpdated" />
 | |
|       <ui-tooltip :text="$strings.LabelSettingsAudiobooksOnlyHelp">
 | |
|         <p class="pl-4 text-base">
 | |
|           {{ $strings.LabelSettingsAudiobooksOnly }}
 | |
|           <span class="material-icons icon-text text-sm">info_outlined</span>
 | |
|         </p>
 | |
|       </ui-tooltip>
 | |
|     </div>
 | |
|     <div v-if="isBookLibrary" class="py-3">
 | |
|       <div class="flex items-center">
 | |
|         <ui-toggle-switch v-model="skipMatchingMediaWithAsin" @input="formUpdated" />
 | |
|         <p class="pl-4 text-base">{{ $strings.LabelSettingsSkipMatchingBooksWithASIN }}</p>
 | |
|       </div>
 | |
|     </div>
 | |
|     <div v-if="isBookLibrary" class="py-3">
 | |
|       <div class="flex items-center">
 | |
|         <ui-toggle-switch v-model="skipMatchingMediaWithIsbn" @input="formUpdated" />
 | |
|         <p class="pl-4 text-base">{{ $strings.LabelSettingsSkipMatchingBooksWithISBN }}</p>
 | |
|       </div>
 | |
|     </div>
 | |
|     <div v-if="isBookLibrary" class="py-3">
 | |
|       <div class="flex items-center">
 | |
|         <ui-toggle-switch v-model="hideSingleBookSeries" @input="formUpdated" />
 | |
|         <ui-tooltip :text="$strings.LabelSettingsHideSingleBookSeriesHelp">
 | |
|           <p class="pl-4 text-base">
 | |
|             {{ $strings.LabelSettingsHideSingleBookSeries }}
 | |
|             <span class="material-icons icon-text text-sm">info_outlined</span>
 | |
|           </p>
 | |
|         </ui-tooltip>
 | |
|       </div>
 | |
|     </div>
 | |
|     <div v-if="isBookLibrary" class="py-3">
 | |
|       <div class="flex items-center">
 | |
|         <ui-toggle-switch v-model="onlyShowLaterBooksInContinueSeries" @input="formUpdated" />
 | |
|         <ui-tooltip :text="$strings.LabelSettingsOnlyShowLaterBooksInContinueSeriesHelp">
 | |
|           <p class="pl-4 text-base">
 | |
|             {{ $strings.LabelSettingsOnlyShowLaterBooksInContinueSeries }}
 | |
|             <span class="material-icons icon-text text-sm">info_outlined</span>
 | |
|           </p>
 | |
|         </ui-tooltip>
 | |
|       </div>
 | |
|     </div>
 | |
|     <div v-if="isPodcastLibrary" class="py-3">
 | |
|       <ui-dropdown :label="$strings.LabelPodcastSearchRegion" v-model="podcastSearchRegion" :items="$podcastSearchRegionOptions" small class="max-w-52" @input="formUpdated" />
 | |
|     </div>
 | |
|   </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| export default {
 | |
|   props: {
 | |
|     library: {
 | |
|       type: Object,
 | |
|       default: () => null
 | |
|     },
 | |
|     processing: Boolean
 | |
|   },
 | |
|   data() {
 | |
|     return {
 | |
|       provider: null,
 | |
|       useSquareBookCovers: false,
 | |
|       enableWatcher: false,
 | |
|       skipMatchingMediaWithAsin: false,
 | |
|       skipMatchingMediaWithIsbn: false,
 | |
|       audiobooksOnly: false,
 | |
|       hideSingleBookSeries: false,
 | |
|       onlyShowLaterBooksInContinueSeries: false,
 | |
|       podcastSearchRegion: 'us'
 | |
|     }
 | |
|   },
 | |
|   computed: {
 | |
|     librarySettings() {
 | |
|       return this.library.settings || {}
 | |
|     },
 | |
|     globalWatcherDisabled() {
 | |
|       return this.$store.getters['getServerSetting']('scannerDisableWatcher')
 | |
|     },
 | |
|     mediaType() {
 | |
|       return this.library.mediaType
 | |
|     },
 | |
|     isBookLibrary() {
 | |
|       return this.mediaType === 'book'
 | |
|     },
 | |
|     isPodcastLibrary() {
 | |
|       return this.mediaType === 'podcast'
 | |
|     },
 | |
|     providers() {
 | |
|       if (this.mediaType === 'podcast') return this.$store.state.scanners.podcastProviders
 | |
|       return this.$store.state.scanners.providers
 | |
|     }
 | |
|   },
 | |
|   methods: {
 | |
|     getLibraryData() {
 | |
|       return {
 | |
|         settings: {
 | |
|           coverAspectRatio: this.useSquareBookCovers ? this.$constants.BookCoverAspectRatio.SQUARE : this.$constants.BookCoverAspectRatio.STANDARD,
 | |
|           disableWatcher: !this.enableWatcher,
 | |
|           skipMatchingMediaWithAsin: !!this.skipMatchingMediaWithAsin,
 | |
|           skipMatchingMediaWithIsbn: !!this.skipMatchingMediaWithIsbn,
 | |
|           audiobooksOnly: !!this.audiobooksOnly,
 | |
|           hideSingleBookSeries: !!this.hideSingleBookSeries,
 | |
|           onlyShowLaterBooksInContinueSeries: !!this.onlyShowLaterBooksInContinueSeries,
 | |
|           podcastSearchRegion: this.podcastSearchRegion
 | |
|         }
 | |
|       }
 | |
|     },
 | |
|     formUpdated() {
 | |
|       this.$emit('update', this.getLibraryData())
 | |
|     },
 | |
|     init() {
 | |
|       this.useSquareBookCovers = this.librarySettings.coverAspectRatio === this.$constants.BookCoverAspectRatio.SQUARE
 | |
|       this.enableWatcher = !this.librarySettings.disableWatcher
 | |
|       this.skipMatchingMediaWithAsin = !!this.librarySettings.skipMatchingMediaWithAsin
 | |
|       this.skipMatchingMediaWithIsbn = !!this.librarySettings.skipMatchingMediaWithIsbn
 | |
|       this.audiobooksOnly = !!this.librarySettings.audiobooksOnly
 | |
|       this.hideSingleBookSeries = !!this.librarySettings.hideSingleBookSeries
 | |
|       this.onlyShowLaterBooksInContinueSeries = !!this.librarySettings.onlyShowLaterBooksInContinueSeries
 | |
|       this.podcastSearchRegion = this.librarySettings.podcastSearchRegion || 'us'
 | |
|     }
 | |
|   },
 | |
|   mounted() {
 | |
|     this.init()
 | |
|   }
 | |
| }
 | |
| </script> |