From a07741776192c7c5b6411996095a595dd43a5794 Mon Sep 17 00:00:00 2001 From: Jelle van Snik Date: Mon, 23 Jan 2023 23:01:08 +0100 Subject: [PATCH] mobile safe video sizes --- src/components/video/DecoratedVideoPlayer.tsx | 2 +- src/components/video/controls/TimeControl.tsx | 28 +------------------ src/hooks/useProgressBar.ts | 27 ++++++++++-------- src/setup/index.css | 5 +++- src/views/media/MediaView.tsx | 4 +-- 5 files changed, 22 insertions(+), 44 deletions(-) diff --git a/src/components/video/DecoratedVideoPlayer.tsx b/src/components/video/DecoratedVideoPlayer.tsx index b86ec2ff..6fd9e498 100644 --- a/src/components/video/DecoratedVideoPlayer.tsx +++ b/src/components/video/DecoratedVideoPlayer.tsx @@ -90,7 +90,7 @@ export function DecoratedVideoPlayer( >
diff --git a/src/components/video/controls/TimeControl.tsx b/src/components/video/controls/TimeControl.tsx index 1012b560..fdc67064 100644 --- a/src/components/video/controls/TimeControl.tsx +++ b/src/components/video/controls/TimeControl.tsx @@ -1,33 +1,7 @@ -import { Icon, Icons } from "@/components/Icon"; +import { Icons } from "@/components/Icon"; import { VideoPlayerIconButton } from "../parts/VideoPlayerIconButton"; import { useVideoPlayerState } from "../VideoContext"; -function durationExceedsHour(secs: number): boolean { - return secs > 60 * 60; -} - -function formatSeconds(secs: number, showHours = false): string { - if (Number.isNaN(secs)) { - if (showHours) return "0:00:00"; - return "0:00"; - } - - let time = secs; - const seconds = Math.floor(time % 60); - - time /= 60; - const minutes = Math.floor(time % 60); - - time /= 60; - const hours = Math.floor(time); - - const paddedSecs = seconds.toString().padStart(2, "0"); - const paddedMins = minutes.toString().padStart(2, "0"); - - if (!showHours) return [minutes, paddedSecs].join(":"); - return [hours, paddedMins, paddedSecs].join(":"); -} - interface Props { className?: string; } diff --git a/src/hooks/useProgressBar.ts b/src/hooks/useProgressBar.ts index ad069709..caaf2e89 100644 --- a/src/hooks/useProgressBar.ts +++ b/src/hooks/useProgressBar.ts @@ -2,7 +2,9 @@ import React, { RefObject, useCallback, useEffect, useState } from "react"; type ActivityEvent = | React.MouseEvent - | React.TouchEvent; + | React.TouchEvent + | MouseEvent + | TouchEvent; export function makePercentageString(num: number) { return `${num.toFixed(2)}%`; @@ -13,15 +15,13 @@ export function makePercentage(num: number) { } function isClickEvent( - evt: React.MouseEvent | React.TouchEvent -): evt is React.MouseEvent { - return evt.type === "mousedown"; + evt: ActivityEvent +): evt is React.MouseEvent | MouseEvent { + return evt.type === "mousedown" || evt.type === "mouseup"; } -const getEventX = ( - evt: React.MouseEvent | React.TouchEvent -) => { - return isClickEvent(evt) ? evt.pageX : evt.touches[0].pageX; +const getEventX = (evt: ActivityEvent) => { + return isClickEvent(evt) ? evt.pageX : evt.changedTouches[0].pageX; }; export function useProgressBar( @@ -33,15 +33,15 @@ export function useProgressBar( const [progress, setProgress] = useState(0); useEffect(() => { - function mouseMove(ev: MouseEvent) { + function mouseMove(ev: ActivityEvent) { if (!mouseDown || !barRef.current) return; const rect = barRef.current.getBoundingClientRect(); - const pos = (ev.pageX - rect.left) / barRef.current.offsetWidth; + const pos = (getEventX(ev) - rect.left) / barRef.current.offsetWidth; setProgress(pos * 100); if (commitImmediately) commit(pos); } - function mouseUp(ev: MouseEvent | TouchEvent) { + function mouseUp(ev: ActivityEvent) { if (!mouseDown) return; setMouseDown(false); document.body.removeAttribute("data-no-select"); @@ -53,17 +53,20 @@ export function useProgressBar( } document.addEventListener("mousemove", mouseMove); + document.addEventListener("touchmove", mouseMove); document.addEventListener("mouseup", mouseUp); document.addEventListener("touchend", mouseUp); return () => { document.removeEventListener("mousemove", mouseMove); + document.removeEventListener("touchmove", mouseMove); document.removeEventListener("mouseup", mouseUp); + document.removeEventListener("touchend", mouseUp); }; }, [mouseDown, barRef, commit, commitImmediately]); const dragMouseDown = useCallback( - (ev: React.MouseEvent | React.TouchEvent) => { + (ev: ActivityEvent) => { setMouseDown(true); document.body.setAttribute("data-no-select", "true"); diff --git a/src/setup/index.css b/src/setup/index.css index b8e12018..57c9a487 100644 --- a/src/setup/index.css +++ b/src/setup/index.css @@ -4,12 +4,15 @@ html, body { - @apply bg-denim-100 text-denim-700 font-open-sans min-h-screen overflow-x-hidden; + @apply bg-denim-100 text-denim-700 font-open-sans overflow-x-hidden; + min-height: 100vh; + min-height: 100dvh; } #root { padding: 0.05px; min-height: 100vh; + min-height: 100dvh; width: 100%; } diff --git a/src/views/media/MediaView.tsx b/src/views/media/MediaView.tsx index 2ff5305b..016c0521 100644 --- a/src/views/media/MediaView.tsx +++ b/src/views/media/MediaView.tsx @@ -105,10 +105,8 @@ export function MediaViewPlayer(props: MediaViewPlayerProps) { // eslint-disable-next-line react-hooks/exhaustive-deps }, [props.stream]); - // TODO show episode title - return ( -
+
{props.meta.meta.title}