mirror of
https://github.com/TeamPiped/Piped.git
synced 2025-01-10 11:30:28 +05:30
feat: mark as watched button in feed (#3746)
* feat: add mark as watched/unwatched button * fix: remove from trending page and hide if watch history is diabled remove the button from trending page because it only works in feed page. * fix: missing thumbnail url in watch_history when using mark as watched * fix: missing uploadername in watch_history when using mark as watched * refactor: make mark as watched consistent with other app elements * refactor: simplify setting "watched" property for videos --------- Co-authored-by: Bnyro <bnyro@tutanota.com>
This commit is contained in:
parent
56bcc1b90f
commit
676dbef9b8
@ -48,7 +48,7 @@
|
|||||||
|
|
||||||
<LoadingIndicatorPage :show-content="videosStore != null" class="video-grid">
|
<LoadingIndicatorPage :show-content="videosStore != null" class="video-grid">
|
||||||
<template v-for="video in filteredVideos" :key="video.url">
|
<template v-for="video in filteredVideos" :key="video.url">
|
||||||
<VideoItem v-if="shouldShowVideo(video)" :is-feed="true" :item="video" />
|
<VideoItem v-if="shouldShowVideo(video)" :is-feed="true" :item="video" @update:watched="onUpdateWatched" />
|
||||||
</template>
|
</template>
|
||||||
</LoadingIndicatorPage>
|
</LoadingIndicatorPage>
|
||||||
</template>
|
</template>
|
||||||
@ -140,6 +140,15 @@ export default {
|
|||||||
this.loadMoreVideos();
|
this.loadMoreVideos();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
onUpdateWatched(urls = null) {
|
||||||
|
if (urls === null) {
|
||||||
|
if (this.videos.length > 0) this.updateWatched(this.videos);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const subset = this.videos.filter(({ url }) => urls.includes(url));
|
||||||
|
if (subset.length > 0) this.updateWatched(subset);
|
||||||
|
},
|
||||||
shouldShowVideo(video) {
|
shouldShowVideo(video) {
|
||||||
switch (this.selectedFilter.toLowerCase()) {
|
switch (this.selectedFilter.toLowerCase()) {
|
||||||
case "shorts":
|
case "shorts":
|
||||||
|
@ -127,6 +127,18 @@
|
|||||||
>
|
>
|
||||||
<i class="i-fa6-solid:circle-minus" />
|
<i class="i-fa6-solid:circle-minus" />
|
||||||
</button>
|
</button>
|
||||||
|
<button
|
||||||
|
v-if="showMarkOnWatched && isFeed"
|
||||||
|
ref="watchButton"
|
||||||
|
@click="toggleWatched(item.url.substr(-11))"
|
||||||
|
>
|
||||||
|
<i
|
||||||
|
v-if="item.watched && item.currentTime > item.duration * 0.9"
|
||||||
|
:title="$t('actions.mark_as_unwatched')"
|
||||||
|
class="i-fa6-solid:eye-slash"
|
||||||
|
/>
|
||||||
|
<i v-else :title="$t('actions.mark_as_watched')" class="i-fa6-solid:eye" />
|
||||||
|
</button>
|
||||||
<ConfirmModal
|
<ConfirmModal
|
||||||
v-if="showConfirmRemove"
|
v-if="showConfirmRemove"
|
||||||
:message="$t('actions.delete_playlist_video_confirm')"
|
:message="$t('actions.delete_playlist_video_confirm')"
|
||||||
@ -176,13 +188,14 @@ export default {
|
|||||||
preferListen: { type: Boolean, default: false },
|
preferListen: { type: Boolean, default: false },
|
||||||
admin: { type: Boolean, default: false },
|
admin: { type: Boolean, default: false },
|
||||||
},
|
},
|
||||||
emits: ["remove"],
|
emits: ["update:watched", "remove"],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
showPlaylistModal: false,
|
showPlaylistModal: false,
|
||||||
showShareModal: false,
|
showShareModal: false,
|
||||||
showVideo: true,
|
showVideo: true,
|
||||||
showConfirmRemove: false,
|
showConfirmRemove: false,
|
||||||
|
showMarkOnWatched: false,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -195,6 +208,7 @@ export default {
|
|||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
this.shouldShowVideo();
|
this.shouldShowVideo();
|
||||||
|
this.shouldShowMarkOnWatched();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
removeVideo() {
|
removeVideo() {
|
||||||
@ -217,6 +231,38 @@ export default {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
shouldShowMarkOnWatched() {
|
||||||
|
this.showMarkOnWatched = this.getPreferenceBoolean("watchHistory", false);
|
||||||
|
},
|
||||||
|
toggleWatched(videoId) {
|
||||||
|
if (window.db) {
|
||||||
|
var tx = window.db.transaction("watch_history", "readwrite");
|
||||||
|
var store = tx.objectStore("watch_history");
|
||||||
|
var instance = this;
|
||||||
|
var request = store.get(videoId);
|
||||||
|
request.onsuccess = function (event) {
|
||||||
|
var video = event.target.result;
|
||||||
|
if (video) {
|
||||||
|
video.watchedAt = Date.now();
|
||||||
|
} else {
|
||||||
|
video = {
|
||||||
|
videoId: videoId,
|
||||||
|
title: instance.item.title,
|
||||||
|
duration: instance.item.duration,
|
||||||
|
thumbnail: instance.item.thumbnail,
|
||||||
|
uploaderUrl: instance.item.uploaderUrl,
|
||||||
|
uploaderName: instance.item.uploaderName,
|
||||||
|
watchedAt: Date.now(),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
video.currentTime =
|
||||||
|
instance.item.currentTime < instance.item.duration * 0.9 ? instance.item.duration : 0;
|
||||||
|
store.put(video);
|
||||||
|
instance.$emit("update:watched", [instance.item.url]);
|
||||||
|
instance.shouldShowVideo();
|
||||||
|
};
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
@ -132,6 +132,8 @@
|
|||||||
"show_chapters": "Chapters",
|
"show_chapters": "Chapters",
|
||||||
"store_search_history": "Store Search History",
|
"store_search_history": "Store Search History",
|
||||||
"hide_watched": "Hide watched videos in the feed",
|
"hide_watched": "Hide watched videos in the feed",
|
||||||
|
"mark_as_watched": "Mark as Watched",
|
||||||
|
"mark_as_unwatched": "Mark as Unwatched",
|
||||||
"documentation": "Documentation",
|
"documentation": "Documentation",
|
||||||
"status_page": "Status",
|
"status_page": "Status",
|
||||||
"source_code": "Source code",
|
"source_code": "Source code",
|
||||||
|
@ -144,7 +144,7 @@ const mixin = {
|
|||||||
var request = store.get(video.url.substr(-11));
|
var request = store.get(video.url.substr(-11));
|
||||||
request.onsuccess = function (event) {
|
request.onsuccess = function (event) {
|
||||||
if (event.target.result) {
|
if (event.target.result) {
|
||||||
video.watched = true;
|
video.watched = event.target.result.currentTime != 0;
|
||||||
video.currentTime = event.target.result.currentTime;
|
video.currentTime = event.target.result.currentTime;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user