diff --git a/src/view/com/util/post-embeds/VideoEmbed.tsx b/src/view/com/util/post-embeds/VideoEmbed.tsx index 55ac188248..03838b6620 100644 --- a/src/view/com/util/post-embeds/VideoEmbed.tsx +++ b/src/view/com/util/post-embeds/VideoEmbed.tsx @@ -18,7 +18,8 @@ import * as VideoFallback from './VideoEmbedInner/VideoFallback' export function VideoEmbed({embed}: {embed: AppBskyEmbedVideo.View}) { const t = useTheme() - const {activeSource, setActiveSource} = useActiveVideoNative() + const {activeSource, setActiveSource, player} = useActiveVideoNative() + const [isFullscreen, setIsFullscreen] = React.useState(false) const isActive = embed.playlist === activeSource const {_} = useLingui() @@ -31,6 +32,20 @@ export function VideoEmbed({embed}: {embed: AppBskyEmbedVideo.View}) { ) const gate = useGate() + const onChangeStatus = (isVisible: boolean) => { + if (isVisible) { + setActiveSource(embed.playlist) + if (!player.playing) { + player.play() + } + } else if (!isFullscreen) { + player.muted = true + if (player.playing) { + player.pause() + } + } + } + if (!gate('video_view_on_posts')) { return null } @@ -54,15 +69,13 @@ export function VideoEmbed({embed}: {embed: AppBskyEmbedVideo.View}) { a.my_xs, ]}> - { - if (isVisible) { - setActiveSource(embed.playlist) - } - }}> + {isActive ? ( - + ) : ( <> void }) { const {_} = useLingui() const {player} = useActiveVideoNative() const ref = useRef(null) - const [isFullscreen, setIsFullscreen] = useState(false) const enterFullscreen = useCallback(() => { ref.current?.enterFullscreen()