Implement DeArrow support everywhere.

Closes #2575
This commit is contained in:
Kavin 2023-07-21 21:07:53 +01:00
parent f8e4c70ea0
commit 9539d51126
No known key found for this signature in database
GPG Key ID: 6E4598CA5C92C41F
6 changed files with 27 additions and 41 deletions

View File

@ -148,6 +148,7 @@ export default {
this.contentItems = this.channel.relatedStreams; this.contentItems = this.channel.relatedStreams;
this.fetchSubscribedStatus(); this.fetchSubscribedStatus();
this.updateWatched(this.channel.relatedStreams); this.updateWatched(this.channel.relatedStreams);
this.fetchDeArrowContent(this.channel.relatedStreams);
this.tabs.push({ this.tabs.push({
translatedName: this.$t("video.videos"), translatedName: this.$t("video.videos"),
}); });
@ -186,6 +187,7 @@ export default {
this.loading = false; this.loading = false;
this.updateWatched(json.relatedStreams); this.updateWatched(json.relatedStreams);
json.relatedStreams.map(stream => this.contentItems.push(stream)); json.relatedStreams.map(stream => this.contentItems.push(stream));
this.fetchDeArrowContent(this.contentItems);
}); });
}, },
fetchChannelTabNextPage() { fetchChannelTabNextPage() {
@ -196,6 +198,7 @@ export default {
this.tabs[this.selectedTab].tabNextPage = json.nextpage; this.tabs[this.selectedTab].tabNextPage = json.nextpage;
this.loading = false; this.loading = false;
json.content.map(item => this.contentItems.push(item)); json.content.map(item => this.contentItems.push(item));
this.fetchDeArrowContent(this.contentItems);
this.tabs[this.selectedTab].content = this.contentItems; this.tabs[this.selectedTab].content = this.contentItems;
}); });
}, },
@ -258,6 +261,7 @@ export default {
data: this.tabs[index].data, data: this.tabs[index].data,
}).then(tab => { }).then(tab => {
this.contentItems = this.tabs[index].content = tab.content; this.contentItems = this.tabs[index].content = tab.content;
this.fetchDeArrowContent(this.contentItems);
this.tabs[this.selectedTab].tabNextPage = tab.nextpage; this.tabs[this.selectedTab].tabNextPage = tab.nextpage;
}); });
}, },

View File

@ -138,18 +138,8 @@ export default {
loadMoreVideos() { loadMoreVideos() {
this.currentVideoCount = Math.min(this.currentVideoCount + this.videoStep, this.videosStore.length); this.currentVideoCount = Math.min(this.currentVideoCount + this.videoStep, this.videosStore.length);
if (this.videos.length != this.videosStore.length) { if (this.videos.length != this.videosStore.length) {
const videoIds = this.videosStore
.slice(this.videos.length, this.currentVideoCount)
.map(video => video.url.substr(-11))
.sort();
if (this.getPreferenceBoolean("dearrow", false))
this.fetchDeArrowContent(videoIds).then(json => {
Object.keys(json).forEach(key => {
const video = this.videosStore.find(video => video.url.substr(-11) == key);
video.dearrow = json[key];
});
});
this.videos = this.videosStore.slice(0, this.currentVideoCount); this.videos = this.videosStore.slice(0, this.currentVideoCount);
this.fetchDeArrowContent(this.videos);
} }
}, },
handleScroll() { handleScroll() {

View File

@ -116,6 +116,7 @@ export default {
.then(() => { .then(() => {
this.updateTitle(); this.updateTitle();
this.updateWatched(this.playlist.relatedStreams); this.updateWatched(this.playlist.relatedStreams);
this.fetchDeArrowContent(this.playlist.relatedStreams);
}); });
}, },
async updateTitle() { async updateTitle() {
@ -132,6 +133,7 @@ export default {
this.playlist.nextpage = json.nextpage; this.playlist.nextpage = json.nextpage;
this.loading = false; this.loading = false;
json.relatedStreams.map(stream => this.playlist.relatedStreams.push(stream)); json.relatedStreams.map(stream => this.playlist.relatedStreams.push(stream));
this.fetchDeArrowContent(this.playlist.relatedStreams);
}); });
} }
}, },

View File

@ -29,13 +29,7 @@ export default {
this.fetchTrending(region).then(videos => { this.fetchTrending(region).then(videos => {
this.videos = videos; this.videos = videos;
this.updateWatched(this.videos); this.updateWatched(this.videos);
const videoIds = this.videos.map(video => video.url.substr(-11)).sort(); this.fetchDeArrowContent(this.videos);
this.fetchDeArrowContent(videoIds).then(json => {
Object.keys(json).forEach(key => {
const video = this.videos.find(video => video.url.substr(-11) == key);
video.dearrow = json[key];
});
});
}); });
}, },
activated() { activated() {

View File

@ -454,16 +454,7 @@ export default {
this.video.description = this.rewriteDescription(xmlDoc.querySelector("body").innerHTML); this.video.description = this.rewriteDescription(xmlDoc.querySelector("body").innerHTML);
this.updateWatched(this.video.relatedStreams); this.updateWatched(this.video.relatedStreams);
const videoIds = this.video.relatedStreams this.fetchDeArrowContent(this.video.relatedStreams);
.filter(obj => obj.type === "stream")
.map(video => video.url.substr(-11))
.sort();
this.fetchDeArrowContent(videoIds).then(json => {
Object.keys(json).forEach(key => {
const video = this.video.relatedStreams.find(video => video.url.substr(-11) == key);
video.dearrow = json[key];
});
});
} }
}); });
}, },
@ -485,16 +476,7 @@ export default {
} }
}); });
await this.fetchPlaylistPages().then(() => { await this.fetchPlaylistPages().then(() => {
const videoIds = this.playlist.relatedStreams this.fetchDeArrowContent(this.playlist.relatedStreams);
.filter(obj => obj.type === "stream")
.map(video => video.url.substr(-11))
.sort();
this.fetchDeArrowContent(videoIds).then(json => {
Object.keys(json).forEach(key => {
const video = this.playlist.relatedStreams.find(video => video.url.substr(-11) == key);
video.dearrow = json[key];
});
});
}); });
} }
}, },

View File

@ -542,10 +542,24 @@ const mixin = {
return undefined; return undefined;
} }
}, },
fetchDeArrowContent(videoIds) { fetchDeArrowContent(content) {
if (!this.getPreferenceBoolean("dearrow", false)) return new Promise(resolve => resolve({})); if (!this.getPreferenceBoolean("dearrow", false)) return;
return this.fetchJson(this.apiUrl() + "/dearrow", {
const videoIds = content
.filter(item => item.type === "stream")
.filter(item => item.dearrow === undefined)
.map(item => item.url.substr(-11))
.sort();
if (videoIds.length === 0) return;
this.fetchJson(this.apiUrl() + "/dearrow", {
videoIds: videoIds.join(","), videoIds: videoIds.join(","),
}).then(json => {
Object.keys(json).forEach(videoId => {
const item = content.find(item => item.url.endsWith(videoId));
if (item) item.dearrow = json[videoId];
});
}); });
}, },
}, },