<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>