mirror of
https://github.com/gradio-app/gradio.git
synced 2024-12-15 02:11:15 +08:00
eda33b3763
* fetch * add changeset * add changeset * simplify * add changeset * changes * format * add changeset * changes * format * fixes * lint * fix components * fixes * typing * format frontend * path * fixes * fix stories * lint * lint --------- Co-authored-by: gradio-pr-bot <gradio-pr-bot@users.noreply.github.com>
50 lines
912 B
Svelte
50 lines
912 B
Svelte
<script lang="ts">
|
|
import Image from "./shared/Image.svelte";
|
|
import type { FileData } from "@gradio/client";
|
|
|
|
export let value: null | FileData;
|
|
export let type: "gallery" | "table";
|
|
export let selected = false;
|
|
</script>
|
|
|
|
<div
|
|
class="container"
|
|
class:table={type === "table"}
|
|
class:gallery={type === "gallery"}
|
|
class:selected
|
|
class:border={value}
|
|
>
|
|
{#if value}
|
|
<Image src={value.url} alt="" />
|
|
{/if}
|
|
</div>
|
|
|
|
<style>
|
|
.container :global(img) {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.container.selected {
|
|
border-color: var(--border-color-accent);
|
|
}
|
|
.border.table {
|
|
border: 2px solid var(--border-color-primary);
|
|
}
|
|
|
|
.container.table {
|
|
margin: 0 auto;
|
|
border-radius: var(--radius-lg);
|
|
overflow: hidden;
|
|
width: var(--size-20);
|
|
height: var(--size-20);
|
|
object-fit: cover;
|
|
}
|
|
|
|
.container.gallery {
|
|
width: var(--size-20);
|
|
max-width: var(--size-20);
|
|
object-fit: cover;
|
|
}
|
|
</style>
|