🦜 Adds new topbar inspired by real spot controller

This commit is contained in:
Rune Harlyk
2024-02-03 18:00:00 +01:00
parent 6d35e27991
commit 5bb1a0a675
+44 -106
View File
@@ -1,117 +1,55 @@
<script lang="ts"> <script lang="ts">
import { isConnected, dataBuffer } from '../lib/socket'; import { isConnected, dataBuffer, status } from '../lib/socket';
import { Icon, ArrowsPointingIn, ArrowsPointingOut, Bars3, Power, Cube } from 'svelte-hero-icons'; import { Icon, Bars3, Power, Battery100, Signal, SignalSlash } from 'svelte-hero-icons';
import { tweened } from 'svelte/motion';
import { quadInOut } from 'svelte/easing';
import { emulateModel, sidebarOpen } from '../lib/store'; import { emulateModel, sidebarOpen } from '../lib/store';
let isFullscreen = false; const views = ["Robot camera", "Virtual environment"]
const modes = ["Drive", "Choreography"]
const width = tweened(0, {
duration: 250,
easing: quadInOut
});
function handleClick() {
if ($width === 0) width.set(75);
else width.set(0);
}
const toggleFullScreen = () => {
if (!document.fullscreenElement) document.documentElement.requestFullscreen();
else if (document.exitFullscreen) document.exitFullscreen();
isFullscreen = !document.fullscreenElement;
};
</script> </script>
<div class="absolute flex justify-between w-full z-10 h-10" on:dblclick={handleClick}>
<div class="absolute flex justify-between w-full"> <div class="topbar absolute left-0 top-0 w-full z-10 flex justify-between bg-zinc-800">
<div class="w-20 p-4 z-20"> <div class="flex gap-2 py-2">
<button on:click={() => sidebarOpen.set(true)}> <button class="ml-2" on:click={() => sidebarOpen.set(true)}>
<Icon src={Bars3} size="32" /> <Icon src={Bars3} size="32" />
</button> </button>
</div> <select>
<div class="w-20 p-4 text-right">{Math.floor($dataBuffer[0])}°🌡️<br> {#each modes as mode}
{Math.floor($dataBuffer[9]*10)/10}V<br> <option>{mode}</option>
{Math.floor($dataBuffer[8]*1000)/1000}A {/each}
</div> </select>
<select>
{#each views as view}
<option>{view}</option>
{/each}
</select>
</div> </div>
<div class="absolute flex justify-center w-full">
<div> <div class="flex gap-2 p-2">
<div <button class="action_button bg-zinc-600">
style="height:{$width}px; width:300px; background-color:#36393f" <Icon src={Power} size="24" />
class="rounded-b-xl overflow-hidden flex justify-end flex-col" </button>
> <button class="action_button"><Icon src={Battery100} size="24" /></button>
{#if $width !== 0} <button class="action_button"><Icon src={$isConnected ? Signal : SignalSlash} size="24" /></button>
<div class="flex justify-evenly p-4 w-full"> </div>
<button on:click={toggleFullScreen}> <div>
<Icon src={isFullscreen ? ArrowsPointingIn : ArrowsPointingOut} size="32" /> <button class="h-full w-20 bg-red-600 text-white">STOP</button>
</button>
<button>
<Icon src={Power} size="32" />
</button>
<button class:text-blue-600={$emulateModel} on:click={() => emulateModel.update(v => !v)}>
<Icon src={Cube} size="32"/>
</button>
</div>
{/if}
</div>
<div class="flex justify-center" on:mouseup={handleClick}>
<svg height="40" width="300" class="Settings_topSVG__2VXbU">
<path
stroke="none"
fill="#36393f"
d="M 0 0 C 40 0 40 40 80 40 H 220 C 260 40 260 0 300 0 Z"
/>
</svg>
<div
class="absolute flex gap-1 h-10 w-36 justify-center items-center dots
{$isConnected ? 'connected' : 'disconnected'}"
>
<span class="dot h-4 w-4" />
<span class="dot h-4 w-4" />
<span class="dot h-4 w-4" />
<span class="dot h-4 w-4" />
</div>
</div>
</div>
</div> </div>
</div> </div>
<style scoped> <style>
.dot { .topbar {
background-color: grey; height: 50px;
} }
.disconnected .dot { .action_button {
animation: _fade 0.5s 3s infinite alternate forwards; border-radius: 4px;
} width: 34px;
.connected .dot:first-child { height: 34px;
background-color: #00bbe3; display: flex;
transform: scale(1.1); justify-content: center;
} align-items: center;
.dots .dot:first-child { outline: 1px solid #52525b;
animation-delay: 0.25s; }
}
.dots .dot:nth-child(2) {
animation-delay: 0.5s;
}
.dots .dot:nth-child(3) {
animation-delay: 0.75s;
}
.dots .dot:last-child {
animation-delay: 1s;
}
.dots .dot:last-child {
animation-delay: 1s;
}
@keyframes _fade {
from {
background-color: #00bbe3;
transform: scale(1.1);
}
to {
background-color: grey;
transform: scale(1.1);
}
}
</style> </style>