workadventure/front/src/Components/Video/ScreenSharingMediaBox.svelte

34 lines
1,005 B
Svelte
Raw Normal View History

<script lang="ts">
2021-12-06 16:12:37 +01:00
import type { ScreenSharingPeer } from "../../WebRtc/ScreenSharingPeer";
import { videoFocusStore } from "../../Stores/VideoFocusStore";
import { getColorByString, srcObject } from "./utils";
export let peer: ScreenSharingPeer;
let streamStore = peer.streamStore;
let name = peer.userName;
let statusStore = peer.statusStore;
</script>
<div class="video-container">
2021-12-06 16:12:37 +01:00
{#if $statusStore === "connecting"}
<div class="connecting-spinner" />
{/if}
2021-12-06 16:12:37 +01:00
{#if $statusStore === "error"}
<div class="rtc-error" />
{/if}
{#if $streamStore === null}
<i style="background-color: {getColorByString(name)};">{name}</i>
{:else}
2021-12-06 16:12:37 +01:00
<!-- svelte-ignore a11y-media-has-caption -->
<video use:srcObject={$streamStore} autoplay playsinline on:click={() => videoFocusStore.toggleFocus(peer)} />
{/if}
</div>
<style lang="scss">
2021-12-06 16:12:37 +01:00
.video-container {
video {
width: 100%;
}
}
</style>