Don't regenerate groups if not needed

This commit is contained in:
Ajay
2022-12-11 15:20:05 -05:00
parent a5d91c9b57
commit 7eb6b3a79d

View File

@@ -62,6 +62,7 @@ class PreviewBar {
originalChapterBar: HTMLElement;
originalChapterBarBlocks: NodeListOf<HTMLElement>;
chapterMargin: number;
lastRenderedSegments: PreviewBarSegment[];
unfilteredChapterGroups: ChapterGroup[];
chapterGroups: ChapterGroup[];
@@ -308,6 +309,8 @@ class PreviewBar {
this.container.appendChild(bar);
}
console.log(this.segments)
console.trace()
this.createChaptersBar(this.segments.sort((a, b) => a.segment[0] - b.segment[0]));
if (chapterChevron) {
@@ -356,8 +359,10 @@ class PreviewBar {
return;
}
if (segments !== this.lastRenderedSegments) {
// Merge overlapping chapters
this.unfilteredChapterGroups = this.createChapterRenderGroups(segments);
}
if (segments.every((segments) => segments.source === SponsorSourceType.YouTube)
|| (!Config.config.renderSegmentsAsChapters
@@ -368,6 +373,9 @@ class PreviewBar {
return;
}
if (segments !== this.lastRenderedSegments) {
this.lastRenderedSegments = segments;
const filteredSegments = segments?.filter((segment) => this.chapterFilter(segment));
if (filteredSegments) {
let groups = this.unfilteredChapterGroups;
@@ -387,6 +395,7 @@ class PreviewBar {
} else {
this.chapterGroups = this.unfilteredChapterGroups;
}
}
if (!this.chapterGroups || this.chapterGroups.length <= 0) {
if (this.customChaptersBar) this.customChaptersBar.style.display = "none";