Spaces:
Build error
Build error
File size: 1,887 Bytes
ebcc4b8 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
<script lang="ts">
import { ICON } from "$lib/utils/icon";
import type { VideoInstance } from "$lib/elements/video//VideoManager.svelte";
import { BaseStatusBox, StatusHeader, StatusContent, StatusIndicator, StatusButton } from "$lib/components/3d/ui";
interface Props {
video: VideoInstance;
handleClick?: () => void;
}
let { video, handleClick }: Props = $props();
// Input theme color (green)
const inputColor = "rgb(34, 197, 94)";
</script>
<!--
@component
Input connection box showing the status of the input connection.
Displays input information when connected or connection prompt when disconnected.
-->
<BaseStatusBox
color={inputColor}
borderOpacity={0.6}
backgroundOpacity={0.2}
opacity={video.hasInput ? 1 : 0.6}
onclick={handleClick}
>
{#if video.hasInput}
<!-- Active Input State -->
{#if video.input.type === 'local-camera'}
<StatusHeader
icon={ICON["icon-[material-symbols--download]"].svg}
text="CAMERA"
color={inputColor}
opacity={0.9}
/>
{:else}
<StatusHeader
icon={ICON["icon-[material-symbols--download]"].svg}
text="REMOTE"
color="rgb(96, 165, 250)"
opacity={0.9}
/>
{/if}
<StatusContent
title={video.input.type === 'local-camera' ? 'Local Camera' : `Room: ${video.input.roomId}`}
subtitle="Connected"
color={inputColor}
variant="primary"
/>
<!-- Active pulse indicator -->
<StatusIndicator color={inputColor} />
{:else}
<!-- No Input State -->
<StatusHeader
icon={ICON["icon-[material-symbols--download]"].svg}
text="NO INPUT"
color={inputColor}
opacity={0.7}
/>
<StatusContent
title="Click to Start"
color={inputColor}
variant="secondary"
/>
<StatusButton
icon={ICON["icon-[mdi--plus]"].svg}
text="Add Input"
color={inputColor}
backgroundOpacity={0.1}
textOpacity={0.7}
/>
{/if}
</BaseStatusBox> |