partey_workadventure/front/src/Components/Video/VideoMediaBox.svelte

104 lines
3.6 KiB
Svelte
Raw Normal View History

<script lang="ts">
import type { VideoPeer } from "../../WebRtc/VideoPeer";
import SoundMeterWidget from "../SoundMeterWidget.svelte";
import microphoneCloseImg from "../images/microphone-close.svg";
import reportImg from "./images/report.svg";
import blockSignImg from "./images/blockSign.svg";
import { showReportScreenStore } from "../../Stores/ShowReportScreenStore";
import { getColorByString, srcObject } from "./utils";
2022-01-05 10:27:40 +01:00
import { highlightedEmbedScreen } from "../../Stores/EmbedScreensStore";
import type { EmbedScreen } from "../../Stores/EmbedScreensStore";
import type { Streamable } from "../../Stores/StreamableCollectionStore";
2021-11-30 19:10:35 +01:00
2021-12-07 13:56:28 +01:00
import Woka from "../Woka/Woka.svelte";
2022-01-05 10:27:40 +01:00
import { onMount } from "svelte";
import { isMediaBreakpointOnly } from "../../Utils/BreakpointsUtils";
export let clickable = false;
export let peer: VideoPeer;
let streamStore = peer.streamStore;
let name = peer.userName;
let statusStore = peer.statusStore;
let constraintStore = peer.constraintsStore;
2021-06-15 15:16:01 +02:00
function openReport(peer: VideoPeer): void {
showReportScreenStore.set({ userId: peer.userId, userName: peer.userName });
2021-06-15 15:16:01 +02:00
}
2022-01-05 10:27:40 +01:00
let embedScreen: EmbedScreen;
let videoContainer: HTMLDivElement;
let minimized = isMediaBreakpointOnly("md");
if (peer) {
embedScreen = {
type: "streamable",
embed: peer as unknown as Streamable,
};
}
function noDrag() {
return false;
}
const resizeObserver = new ResizeObserver(() => {
minimized = isMediaBreakpointOnly("md");
});
onMount(() => {
resizeObserver.observe(videoContainer);
});
</script>
<div class="video-container" class:no-clikable={!clickable} bind:this={videoContainer} on:click={() => (clickable ? highlightedEmbedScreen.toggleHighlight(embedScreen) : null)}>
{#if $statusStore === "connecting"}
<div class="connecting-spinner" />
{/if}
{#if $statusStore === "error"}
<div class="rtc-error" />
{/if}
2021-12-07 16:07:58 +01:00
<!-- {#if !$constraintStore || $constraintStore.video === false} -->
<i class="container">
<span style="background-color: {getColorByString(name)};">{name}</span>
2021-12-07 16:07:58 +01:00
</i>
<div class="woka-icon {($constraintStore && $constraintStore.video !== false) || minimized ? '' : 'no-video'}">
<Woka userId={peer.userId} placeholderSrc={""} />
</div>
2021-12-07 16:07:58 +01:00
<!-- {/if} -->
{#if $constraintStore && $constraintStore.audio === false}
2022-01-05 10:27:40 +01:00
<img
src={microphoneCloseImg}
class="active noselect"
draggable="false"
on:dragstart|preventDefault={noDrag}
alt="Muted"
/>
{/if}
2021-06-15 15:16:01 +02:00
<button class="report" on:click={() => openReport(peer)}>
2022-01-05 10:27:40 +01:00
<img alt="Report this user" draggable="false" on:dragstart|preventDefault={noDrag} src={reportImg} />
<span class="noselect">Report/Block</span>
</button>
2021-12-06 16:12:37 +01:00
<!-- svelte-ignore a11y-media-has-caption -->
2022-01-05 10:27:40 +01:00
<video
2022-01-11 13:52:38 +01:00
class:no-video={!$constraintStore || $constraintStore.video === false}
2022-01-05 10:27:40 +01:00
use:srcObject={$streamStore}
autoplay
playsinline
on:click={() => (clickable ? highlightedEmbedScreen.toggleHighlight(embedScreen) : null)}
/>
<img src={blockSignImg} draggable="false" on:dragstart|preventDefault={noDrag} class="block-logo" alt="Block" />
{#if $constraintStore && $constraintStore.audio !== false}
<SoundMeterWidget stream={$streamStore} />
{/if}
</div>
2021-12-07 15:21:54 +01:00
2022-01-05 10:27:40 +01:00
<style lang="scss">
2021-12-07 15:21:54 +01:00
.container {
display: flex;
2021-12-07 16:07:58 +01:00
flex-direction: column;
2021-12-07 15:21:54 +01:00
}
2022-01-11 13:52:38 +01:00
video.no-video {
visibility: collapse;
}
2021-12-07 15:21:54 +01:00
</style>