add T param back

This commit is contained in:
mrjvs 2023-10-26 19:36:15 +02:00
parent 4f7728bb51
commit 92bca33b91
3 changed files with 31 additions and 4 deletions

View File

@ -47,8 +47,13 @@ export function usePlayer() {
setMeta(m: PlayerMeta, newStatus?: PlayerStatus) { setMeta(m: PlayerMeta, newStatus?: PlayerStatus) {
setMeta(m, newStatus); setMeta(m, newStatus);
}, },
playMedia(source: SourceSliceSource, sourceId: string | null) { playMedia(
setSource(source, getProgress(progressStore.items, meta)); source: SourceSliceSource,
sourceId: string | null,
startAtOverride?: number
) {
const start = startAtOverride ?? getProgress(progressStore.items, meta);
setSource(source, start);
setSourceId(sourceId); setSourceId(sourceId);
setStatus(playerStatus.PLAYING); setStatus(playerStatus.PLAYING);
init(); init();

View File

@ -6,12 +6,14 @@ import { usePlayer } from "@/components/player/hooks/usePlayer";
import { usePlayerMeta } from "@/components/player/hooks/usePlayerMeta"; import { usePlayerMeta } from "@/components/player/hooks/usePlayerMeta";
import { convertRunoutputToSource } from "@/components/player/utils/convertRunoutputToSource"; import { convertRunoutputToSource } from "@/components/player/utils/convertRunoutputToSource";
import { ScrapingItems, ScrapingSegment } from "@/hooks/useProviderScrape"; import { ScrapingItems, ScrapingSegment } from "@/hooks/useProviderScrape";
import { useQueryParam } from "@/hooks/useQueryParams";
import { MetaPart } from "@/pages/parts/player/MetaPart"; import { MetaPart } from "@/pages/parts/player/MetaPart";
import { PlayerPart } from "@/pages/parts/player/PlayerPart"; import { PlayerPart } from "@/pages/parts/player/PlayerPart";
import { ScrapeErrorPart } from "@/pages/parts/player/ScrapeErrorPart"; import { ScrapeErrorPart } from "@/pages/parts/player/ScrapeErrorPart";
import { ScrapingPart } from "@/pages/parts/player/ScrapingPart"; import { ScrapingPart } from "@/pages/parts/player/ScrapingPart";
import { useLastNonPlayerLink } from "@/stores/history"; import { useLastNonPlayerLink } from "@/stores/history";
import { PlayerMeta, playerStatus } from "@/stores/player/slices/source"; import { PlayerMeta, playerStatus } from "@/stores/player/slices/source";
import { parseTimestamp } from "@/utils/timestamp";
export function PlayerView() { export function PlayerView() {
const history = useHistory(); const history = useHistory();
@ -24,6 +26,7 @@ export function PlayerView() {
sources: Record<string, ScrapingSegment>; sources: Record<string, ScrapingSegment>;
sourceOrder: ScrapingItems[]; sourceOrder: ScrapingItems[];
} | null>(null); } | null>(null);
const [startAtParam, setStartAtParam] = useQueryParam("t");
const { status, playMedia, reset, setScrapeNotFound } = usePlayer(); const { status, playMedia, reset, setScrapeNotFound } = usePlayer();
const { setPlayerMeta, scrapeMedia } = usePlayerMeta(); const { setPlayerMeta, scrapeMedia } = usePlayerMeta();
const backUrl = useLastNonPlayerLink(); const backUrl = useLastNonPlayerLink();
@ -51,9 +54,14 @@ export function PlayerView() {
const playAfterScrape = useCallback( const playAfterScrape = useCallback(
(out: RunOutput | null) => { (out: RunOutput | null) => {
if (!out) return; if (!out) return;
playMedia(convertRunoutputToSource(out), out.sourceId); let startAt: number | undefined;
if (startAtParam) {
setStartAtParam(null);
startAt = parseTimestamp(startAtParam) ?? undefined;
}
playMedia(convertRunoutputToSource(out), out.sourceId, startAt);
}, },
[playMedia] [playMedia, setStartAtParam, startAtParam]
); );
return ( return (

14
src/utils/timestamp.ts Normal file
View File

@ -0,0 +1,14 @@
// Convert `t` param to time. Supports having only seconds (like `?t=192`), but also `3:30` or `1:30:02`
export function parseTimestamp(str: string | undefined | null): number | null {
const input = str ?? "";
const isValid = !!input.match(/^\d+(:\d+)*$/);
if (!isValid) return null;
const timeArr = input.split(":").map(Number).reverse();
const hours = timeArr[2] ?? 0;
const minutes = Math.min(timeArr[1] ?? 0, 59);
const seconds = Math.min(timeArr[0] ?? 0, minutes > 0 ? 59 : Infinity);
const timeInSeconds = hours * 60 * 60 + minutes * 60 + seconds;
return timeInSeconds;
}