mirror of
https://github.com/sussy-code/smov.git
synced 2025-01-04 16:47:40 +01:00
fix pause bugs and stuff
This commit is contained in:
parent
f3084d37a8
commit
d07a611c35
4 changed files with 38 additions and 35 deletions
|
@ -64,9 +64,7 @@ function BaseContainer(props: { children?: ReactNode }) {
|
||||||
return (
|
return (
|
||||||
<div ref={containerEl}>
|
<div ref={containerEl}>
|
||||||
<OverlayDisplay>
|
<OverlayDisplay>
|
||||||
<div className="relative overflow-hidden h-screen select-none">
|
<div className="h-screen select-none">{props.children}</div>
|
||||||
{props.children}
|
|
||||||
</div>
|
|
||||||
</OverlayDisplay>
|
</OverlayDisplay>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
@ -80,11 +78,13 @@ export function Container(props: PlayerProps) {
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="relative">
|
<div className="relative">
|
||||||
<VideoContainer />
|
|
||||||
<BaseContainer>
|
<BaseContainer>
|
||||||
<VideoClickTarget />
|
<VideoContainer />
|
||||||
<HeadUpdater />
|
<div className="relative h-screen overflow-hidden">
|
||||||
{props.children}
|
<VideoClickTarget />
|
||||||
|
<HeadUpdater />
|
||||||
|
{props.children}
|
||||||
|
</div>
|
||||||
</BaseContainer>
|
</BaseContainer>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import { PlayerHoverState } from "@/stores/player/slices/interface";
|
import { PlayerHoverState } from "@/stores/player/slices/interface";
|
||||||
import { usePlayerStore } from "@/stores/player/store";
|
import { usePlayerStore } from "@/stores/player/store";
|
||||||
|
|
||||||
export function useShouldShowControls(opts?: { touchOnly: boolean }) {
|
export function useShouldShowControls() {
|
||||||
const hovering = usePlayerStore((s) => s.interface.hovering);
|
const hovering = usePlayerStore((s) => s.interface.hovering);
|
||||||
const lastHoveringState = usePlayerStore(
|
const lastHoveringState = usePlayerStore(
|
||||||
(s) => s.interface.lastHoveringState
|
(s) => s.interface.lastHoveringState
|
||||||
|
@ -9,12 +9,18 @@ export function useShouldShowControls(opts?: { touchOnly: boolean }) {
|
||||||
const isPaused = usePlayerStore((s) => s.mediaPlaying.isPaused);
|
const isPaused = usePlayerStore((s) => s.mediaPlaying.isPaused);
|
||||||
const hasOpenOverlay = usePlayerStore((s) => s.interface.hasOpenOverlay);
|
const hasOpenOverlay = usePlayerStore((s) => s.interface.hasOpenOverlay);
|
||||||
|
|
||||||
const showTouchControls =
|
const isUsingTouch = lastHoveringState === PlayerHoverState.MOBILE_TAPPED;
|
||||||
lastHoveringState === PlayerHoverState.MOBILE_TAPPED;
|
const isHovering = hovering !== PlayerHoverState.NOT_HOVERING;
|
||||||
const notNotHovering = hovering !== PlayerHoverState.NOT_HOVERING;
|
|
||||||
|
|
||||||
if (opts?.touchOnly)
|
// when using touch, pause screens can be dismissed by tapping
|
||||||
return (showTouchControls && notNotHovering) || isPaused || hasOpenOverlay;
|
const showTargetsWithoutPause = isHovering || hasOpenOverlay;
|
||||||
|
const showTargetsIncludingPause = showTargetsWithoutPause || isPaused;
|
||||||
|
const showTargets = isUsingTouch
|
||||||
|
? showTargetsWithoutPause
|
||||||
|
: showTargetsIncludingPause;
|
||||||
|
|
||||||
return notNotHovering || isPaused || hasOpenOverlay;
|
return {
|
||||||
|
showTouchTargets: isUsingTouch && showTargets,
|
||||||
|
showTargets,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,18 +19,20 @@ export function VideoClickTarget() {
|
||||||
|
|
||||||
const togglePause = useCallback(
|
const togglePause = useCallback(
|
||||||
(e: PointerEvent<HTMLDivElement>) => {
|
(e: PointerEvent<HTMLDivElement>) => {
|
||||||
// pause on mouse click
|
setTimeout(() => {
|
||||||
if (e.pointerType === "mouse") {
|
// pause on mouse click
|
||||||
if (e.button !== 0) return;
|
if (e.pointerType === "mouse") {
|
||||||
if (isPaused) display?.play();
|
if (e.button !== 0) return;
|
||||||
else display?.pause();
|
if (isPaused) display?.play();
|
||||||
return;
|
else display?.pause();
|
||||||
}
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// toggle on other types of clicks
|
// toggle on other types of clicks
|
||||||
if (hovering !== PlayerHoverState.MOBILE_TAPPED)
|
if (hovering !== PlayerHoverState.MOBILE_TAPPED)
|
||||||
updateInterfaceHovering(PlayerHoverState.MOBILE_TAPPED);
|
updateInterfaceHovering(PlayerHoverState.MOBILE_TAPPED);
|
||||||
else updateInterfaceHovering(PlayerHoverState.NOT_HOVERING);
|
else updateInterfaceHovering(PlayerHoverState.NOT_HOVERING);
|
||||||
|
}, 10); // TODO this is dirty workaround, without this, tapping on something where a button will be will trigger it immediately
|
||||||
},
|
},
|
||||||
[display, isPaused, hovering, updateInterfaceHovering]
|
[display, isPaused, hovering, updateInterfaceHovering]
|
||||||
);
|
);
|
||||||
|
|
|
@ -7,20 +7,15 @@ import { AutoPlayStart } from "@/components/player/atoms";
|
||||||
import { usePlayer } from "@/components/player/hooks/usePlayer";
|
import { usePlayer } from "@/components/player/hooks/usePlayer";
|
||||||
import { useShouldShowControls } from "@/components/player/hooks/useShouldShowControls";
|
import { useShouldShowControls } from "@/components/player/hooks/useShouldShowControls";
|
||||||
import { ScrapingPart } from "@/pages/parts/player/ScrapingPart";
|
import { ScrapingPart } from "@/pages/parts/player/ScrapingPart";
|
||||||
import { PlayerHoverState } from "@/stores/player/slices/interface";
|
|
||||||
import {
|
import {
|
||||||
PlayerMeta,
|
PlayerMeta,
|
||||||
metaToScrapeMedia,
|
metaToScrapeMedia,
|
||||||
playerStatus,
|
playerStatus,
|
||||||
} from "@/stores/player/slices/source";
|
} from "@/stores/player/slices/source";
|
||||||
import { usePlayerStore } from "@/stores/player/store";
|
|
||||||
|
|
||||||
export function PlayerView() {
|
export function PlayerView() {
|
||||||
const { status, setScrapeStatus, playMedia, setMeta } = usePlayer();
|
const { status, setScrapeStatus, playMedia, setMeta } = usePlayer();
|
||||||
const { lastHoveringState } = usePlayerStore((s) => s.interface);
|
const { showTargets, showTouchTargets } = useShouldShowControls();
|
||||||
|
|
||||||
const desktopControlsVisible = useShouldShowControls();
|
|
||||||
const touchControlsVisible = useShouldShowControls({ touchOnly: true });
|
|
||||||
|
|
||||||
const meta = useMemo<PlayerMeta>(
|
const meta = useMemo<PlayerMeta>(
|
||||||
() => ({
|
() => ({
|
||||||
|
@ -70,7 +65,7 @@ export function PlayerView() {
|
||||||
/>
|
/>
|
||||||
) : null}
|
) : null}
|
||||||
|
|
||||||
<Player.BlackOverlay show={desktopControlsVisible} />
|
<Player.BlackOverlay show={showTargets} />
|
||||||
|
|
||||||
<Player.CenterControls>
|
<Player.CenterControls>
|
||||||
<Player.LoadingSpinner />
|
<Player.LoadingSpinner />
|
||||||
|
@ -79,14 +74,14 @@ export function PlayerView() {
|
||||||
|
|
||||||
<Player.CenterMobileControls
|
<Player.CenterMobileControls
|
||||||
className="text-white"
|
className="text-white"
|
||||||
show={touchControlsVisible}
|
show={showTouchTargets}
|
||||||
>
|
>
|
||||||
<Player.SkipBackward iconSizeClass="text-3xl" />
|
<Player.SkipBackward iconSizeClass="text-3xl" />
|
||||||
<Player.Pause iconSizeClass="text-5xl" />
|
<Player.Pause iconSizeClass="text-5xl" />
|
||||||
<Player.SkipForward iconSizeClass="text-3xl" />
|
<Player.SkipForward iconSizeClass="text-3xl" />
|
||||||
</Player.CenterMobileControls>
|
</Player.CenterMobileControls>
|
||||||
|
|
||||||
<Player.TopControls show={desktopControlsVisible}>
|
<Player.TopControls show={showTargets}>
|
||||||
<div className="grid grid-cols-[1fr,auto] xl:grid-cols-3 items-center">
|
<div className="grid grid-cols-[1fr,auto] xl:grid-cols-3 items-center">
|
||||||
<div className="flex space-x-3 items-center">
|
<div className="flex space-x-3 items-center">
|
||||||
<Player.BackLink />
|
<Player.BackLink />
|
||||||
|
@ -103,7 +98,7 @@ export function PlayerView() {
|
||||||
</div>
|
</div>
|
||||||
</Player.TopControls>
|
</Player.TopControls>
|
||||||
|
|
||||||
<Player.BottomControls show={desktopControlsVisible}>
|
<Player.BottomControls show={showTargets}>
|
||||||
<Player.ProgressBar />
|
<Player.ProgressBar />
|
||||||
<div className="flex justify-between">
|
<div className="flex justify-between">
|
||||||
<Player.LeftSideControls className="hidden lg:flex">
|
<Player.LeftSideControls className="hidden lg:flex">
|
||||||
|
|
Loading…
Reference in a new issue