diff --git a/client/pages/audiobook/_id/chapters.vue b/client/pages/audiobook/_id/chapters.vue
index 55f74b5c..659e4e58 100644
--- a/client/pages/audiobook/_id/chapters.vue
+++ b/client/pages/audiobook/_id/chapters.vue
@@ -144,18 +144,20 @@
@@ -261,6 +263,7 @@ export default {
showFindChaptersModal: false,
chapterData: null,
asinError: null,
+ removeBranding: false,
showSecondInputs: false,
audibleRegions: ['US', 'CA', 'UK', 'AU', 'FR', 'DE', 'JP', 'IT', 'IN', 'ES'],
hasChanges: false
@@ -322,6 +325,9 @@ export default {
this.checkChapters()
},
+ toggleRemoveBranding() {
+ this.removeBranding = !this.removeBranding;
+ },
shiftChapterTimes() {
if (!this.shiftAmount || isNaN(this.shiftAmount) || this.newChapters.length <= 1) {
return
@@ -568,7 +574,7 @@ export default {
this.asinError = this.$getString(data.stringKey)
} else {
console.log('Chapter data', data)
- this.chapterData = data
+ this.chapterData = this.removeBranding ? this.removeBrandingFromData(data) : data
}
})
.catch((error) => {
@@ -578,6 +584,37 @@ export default {
this.showFindChaptersModal = false
})
},
+ removeBrandingFromData(data) {
+ if (!data) return data
+ try {
+ const introDuration = data.brandIntroDurationMs
+ const outroDuration = data.brandOutroDurationMs
+
+ for (let i = 0; i < data.chapters.length; i++) {
+ const chapter = data.chapters[i]
+ if (chapter.startOffsetMs < introDuration) {
+ // This should never happen, as the intro is not longer than the first chapter
+ // If this happens set to the next second
+ // Will be 0 for the first chapter anayways
+ chapter.startOffsetMs = i * 1000
+ chapter.startOffsetSec = i
+ } else {
+ chapter.startOffsetMs -= introDuration
+ chapter.startOffsetSec = Math.floor(chapter.startOffsetMs / 1000)
+ }
+ }
+
+ const lastChapter = data.chapters[data.chapters.length - 1]
+ // If there is an outro that's in the outro duration, remove it
+ if (lastChapter && lastChapter.lengthMs <= outroDuration) {
+ data.chapters.pop()
+ }
+
+ } catch {
+ return data
+ }
+ return data
+ },
resetChapters() {
const payload = {
message: this.$strings.MessageResetChaptersConfirm,