mirror of
https://github.com/hyprwm/hyprland-website.git
synced 2025-01-10 18:29:48 +01:00
fix play button for autoplay blocked users
This commit is contained in:
parent
bddb1f1887
commit
7f98db23d5
2 changed files with 22 additions and 21 deletions
|
@ -2,6 +2,7 @@
|
||||||
import clsx from 'clsx'
|
import clsx from 'clsx'
|
||||||
import PlayIcon from '~icons/mingcute/play-circle-line'
|
import PlayIcon from '~icons/mingcute/play-circle-line'
|
||||||
import { inview } from 'svelte-inview'
|
import { inview } from 'svelte-inview'
|
||||||
|
import { onMount } from 'svelte'
|
||||||
|
|
||||||
/** @type {string} */
|
/** @type {string} */
|
||||||
export let src
|
export let src
|
||||||
|
@ -14,7 +15,7 @@
|
||||||
/** @type {string}*/
|
/** @type {string}*/
|
||||||
export let videoClass = ''
|
export let videoClass = ''
|
||||||
let videoElement
|
let videoElement
|
||||||
let isPaused = !autoplay
|
let isPaused = true
|
||||||
|
|
||||||
function togglePlay() {
|
function togglePlay() {
|
||||||
videoElement.paused ? videoElement.play() : videoElement.pause()
|
videoElement.paused ? videoElement.play() : videoElement.pause()
|
||||||
|
@ -47,6 +48,7 @@
|
||||||
on:click={togglePlay}
|
on:click={togglePlay}
|
||||||
on:dblclick={makeFullscreen}
|
on:dblclick={makeFullscreen}
|
||||||
{autoplay}
|
{autoplay}
|
||||||
|
on:play={() => (isPaused = false)}
|
||||||
/>
|
/>
|
||||||
<div
|
<div
|
||||||
class={clsx(
|
class={clsx(
|
||||||
|
|
|
@ -4,18 +4,14 @@
|
||||||
import previewRiceThumbnail from '$lib/videos/end_4_thumbnail.webp'
|
import previewRiceThumbnail from '$lib/videos/end_4_thumbnail.webp'
|
||||||
import PlayIcon from '~icons/mingcute/play-circle-line'
|
import PlayIcon from '~icons/mingcute/play-circle-line'
|
||||||
import clsx from 'clsx'
|
import clsx from 'clsx'
|
||||||
|
import { onMount } from 'svelte'
|
||||||
|
|
||||||
/** @type HTMLVideoElement */
|
/** @type HTMLVideoElement */
|
||||||
let videoElement
|
let videoElement
|
||||||
|
|
||||||
let isVisible = false
|
let isVisible = false
|
||||||
let isMuted = true
|
let isPaused = true
|
||||||
let isPaused = false
|
|
||||||
|
|
||||||
// Video has no sound anymore
|
|
||||||
// function toggleMute() {
|
|
||||||
// isMuted = !isMuted
|
|
||||||
// }
|
|
||||||
function togglePlay() {
|
function togglePlay() {
|
||||||
videoElement.paused ? videoElement.play() : videoElement.pause()
|
videoElement.paused ? videoElement.play() : videoElement.pause()
|
||||||
isPaused = videoElement.paused
|
isPaused = videoElement.paused
|
||||||
|
@ -24,6 +20,15 @@
|
||||||
function makeFullscreen() {
|
function makeFullscreen() {
|
||||||
videoElement.requestFullscreen()
|
videoElement.requestFullscreen()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onMount(() => {
|
||||||
|
// Nessecary as browsers might block autoplay. The timeout is nessecary as the video is always paused at the very start, even with autoplay on
|
||||||
|
const timeout = setTimeout(() => {
|
||||||
|
isPaused = videoElement.paused
|
||||||
|
}, 10)
|
||||||
|
|
||||||
|
return () => clearTimeout(timeout)
|
||||||
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<section class={$$restProps.class} class:isVisible>
|
<section class={$$restProps.class} class:isVisible>
|
||||||
|
@ -33,7 +38,7 @@
|
||||||
use:inview={{ threshold: 0.5 }}
|
use:inview={{ threshold: 0.5 }}
|
||||||
on:inview_enter={() => {
|
on:inview_enter={() => {
|
||||||
isVisible = true
|
isVisible = true
|
||||||
!isPaused && videoElement.play()
|
!isPaused && videoElement.play().catch(() => {})
|
||||||
}}
|
}}
|
||||||
on:inview_leave={() => {
|
on:inview_leave={() => {
|
||||||
isVisible = false
|
isVisible = false
|
||||||
|
@ -48,8 +53,10 @@
|
||||||
disableremoteplayback="true"
|
disableremoteplayback="true"
|
||||||
class="rounded-xl"
|
class="rounded-xl"
|
||||||
loop
|
loop
|
||||||
muted={isMuted}
|
muted
|
||||||
preload="auto"
|
preload="auto"
|
||||||
|
autoplay
|
||||||
|
on:play={() => {}}
|
||||||
poster={previewRiceThumbnail}
|
poster={previewRiceThumbnail}
|
||||||
on:click={togglePlay}
|
on:click={togglePlay}
|
||||||
on:dblclick={makeFullscreen}
|
on:dblclick={makeFullscreen}
|
||||||
|
@ -60,20 +67,9 @@
|
||||||
isPaused ? 'opacity-100' : 'pointer-events-none'
|
isPaused ? 'opacity-100' : 'pointer-events-none'
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<!-- Currently there is no audio. Component might get refractored into a stand-alone player, so lets leave that here -->
|
|
||||||
<!-- <button
|
|
||||||
class="absolute bottom-4 right-4 h-10 w-10 rounded-full bg-black/5 p-2 opacity-70 hover:opacity-100"
|
|
||||||
on:click|stopPropagation={toggleMute}
|
|
||||||
>
|
|
||||||
{#if isMuted}
|
|
||||||
<MuteIcon class="h-full w-full" />
|
|
||||||
{:else}
|
|
||||||
<AudioIcon class="h-full w-full" />
|
|
||||||
{/if}
|
|
||||||
</button> -->
|
|
||||||
{#if isPaused}
|
{#if isPaused}
|
||||||
<div
|
<div
|
||||||
class="pointer-events-none absolute left-1/2 top-1/2 h-14 w-14 -translate-x-1/2 -translate-y-1/2 rounded-full opacity-80 hover:opacity-100"
|
class="pointer-events-none absolute left-1/2 top-1/2 h-14 w-14 -translate-x-1/2 -translate-y-1/2 rounded-full opacity-80 shadow-sm hover:opacity-100"
|
||||||
>
|
>
|
||||||
<PlayIcon class="h-full w-full" />
|
<PlayIcon class="h-full w-full" />
|
||||||
</div>
|
</div>
|
||||||
|
@ -103,12 +99,15 @@
|
||||||
border: solid 2px theme(colors.sky.400);
|
border: solid 2px theme(colors.sky.400);
|
||||||
scale: 0.9;
|
scale: 0.9;
|
||||||
background: theme(colors.cyan.300 / 70%);
|
background: theme(colors.cyan.300 / 70%);
|
||||||
|
aspect-ratio: 16/9;
|
||||||
|
|
||||||
& video {
|
& video {
|
||||||
transition-property: opacity;
|
transition-property: opacity;
|
||||||
transition-duration: inherit;
|
transition-duration: inherit;
|
||||||
transition-timing-function: inherit;
|
transition-timing-function: inherit;
|
||||||
opacity: 0.3;
|
opacity: 0.3;
|
||||||
|
height: 100%;
|
||||||
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.isVisible & {
|
.isVisible & {
|
||||||
|
|
Loading…
Reference in a new issue