open-webui/src/lib/components/common/Sidebar.svelte

31 lines
825 B
Svelte
Raw Normal View History

2024-10-21 22:24:59 +00:00
<script lang="ts">
import { quadInOut, quintIn } from 'svelte/easing';
import { fade, slide } from 'svelte/transition';
export let show = false;
export let side = 'right';
export let width = '200px';
export let className = '';
</script>
{#if show}
<!-- svelte-ignore a11y-no-static-element-interactions -->
<div
class="absolute z-20 top-0 right-0 left-0 bottom-0 bg-black/10 w-full min-h-full h-full flex justify-center overflow-hidden overscroll-contain"
on:mousedown={() => {
show = false;
}}
transition:fade
/>
<div
class="absolute z-30 shadow-xl {side === 'right' ? 'right-0' : 'left-0'} top-0 bottom-0"
transition:slide={{ easing: quadInOut, axis: side === 'right' ? 'x' : 'y' }}
>
<div class="{className} h-full" style="width: {show ? width : '0px'}">
<slot />
</div>
</div>
{/if}