only make new save item if difference

This commit is contained in:
mrjvs 2023-11-24 20:05:22 +01:00
parent 0094261aec
commit b38e5768e3
1 changed files with 21 additions and 8 deletions

View File

@ -3,7 +3,7 @@ import { useInterval } from "react-use";
import { playerStatus } from "@/stores/player/slices/source";
import { usePlayerStore } from "@/stores/player/store";
import { useProgressStore } from "@/stores/progress";
import { ProgressItem, useProgressStore } from "@/stores/progress";
export function ProgressSaver() {
const meta = usePlayerStore((s) => s.meta);
@ -12,6 +12,8 @@ export function ProgressSaver() {
const status = usePlayerStore((s) => s.status);
const hasPlayedOnce = usePlayerStore((s) => s.mediaPlaying.hasPlayedOnce);
const lastSavedRef = useRef<ProgressItem | null>(null);
const dataRef = useRef({
updateItem,
meta,
@ -32,13 +34,24 @@ export function ProgressSaver() {
if (!d.progress || !d.meta || !d.updateItem) return;
if (d.status !== playerStatus.PLAYING) return;
if (!hasPlayedOnce) return;
d.updateItem({
meta: d.meta,
progress: {
duration: progress.duration,
watched: progress.time,
},
});
let isDifferent = false;
if (!lastSavedRef.current) isDifferent = true;
else if (
lastSavedRef.current?.duration !== progress.duration ||
lastSavedRef.current?.watched !== progress.time
)
isDifferent = true;
lastSavedRef.current = {
duration: progress.duration,
watched: progress.time,
};
if (isDifferent)
d.updateItem({
meta: d.meta,
progress: lastSavedRef.current,
});
}, 3000);
return null;