2021-12-30 19:28:43 +01:00
|
|
|
<script lang="ts">
|
|
|
|
import Icon from "./Icon.svelte";
|
|
|
|
|
|
|
|
export let name: string;
|
|
|
|
export let active = false;
|
|
|
|
export let disabled = false;
|
|
|
|
export let title: string | undefined = undefined;
|
2023-09-01 19:52:49 +02:00
|
|
|
export let outline = false;
|
2023-08-28 18:14:06 +02:00
|
|
|
export let subdued = false;
|
2023-09-01 19:52:49 +02:00
|
|
|
export let color: string | undefined = "var(--active-color, var(--primary))";
|
2021-12-30 19:28:43 +01:00
|
|
|
</script>
|
|
|
|
|
2023-09-01 19:52:49 +02:00
|
|
|
<button
|
|
|
|
on:click
|
|
|
|
class:active
|
|
|
|
class:outline
|
2023-08-28 18:14:06 +02:00
|
|
|
class:subdued
|
2023-09-01 19:52:49 +02:00
|
|
|
{disabled}
|
|
|
|
{title}
|
|
|
|
style="--color: {color}"
|
|
|
|
>
|
2021-12-30 19:28:43 +01:00
|
|
|
<Icon {name} />
|
2023-04-23 13:14:36 +02:00
|
|
|
<div class="text">
|
|
|
|
<slot />
|
|
|
|
</div>
|
2021-12-30 19:28:43 +01:00
|
|
|
</button>
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
button {
|
2023-04-23 13:14:36 +02:00
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
align-items: center;
|
|
|
|
|
2021-12-30 19:28:43 +01:00
|
|
|
border: 0;
|
|
|
|
background: transparent;
|
|
|
|
cursor: pointer;
|
|
|
|
color: inherit;
|
|
|
|
opacity: 0.66;
|
|
|
|
|
2022-01-03 22:31:51 +01:00
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
|
2023-09-01 19:52:49 +02:00
|
|
|
transition:
|
|
|
|
opacity 0.2s,
|
|
|
|
color 0.2s,
|
|
|
|
border-color 0.2s;
|
|
|
|
}
|
|
|
|
|
2023-08-28 18:14:06 +02:00
|
|
|
button.subdued {
|
|
|
|
opacity: 0.4;
|
|
|
|
}
|
|
|
|
|
2023-09-01 19:52:49 +02:00
|
|
|
.outline {
|
|
|
|
border: 1px solid var(--foreground);
|
|
|
|
border-radius: 4px;
|
|
|
|
|
|
|
|
padding: 0.25em 1em;
|
2021-12-30 19:28:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
.active,
|
|
|
|
button:hover {
|
|
|
|
opacity: 1;
|
2023-09-01 19:52:49 +02:00
|
|
|
color: var(--color);
|
|
|
|
border-color: var(--color);
|
2021-12-30 19:28:43 +01:00
|
|
|
}
|
2022-01-27 17:35:58 +01:00
|
|
|
|
|
|
|
button:disabled {
|
|
|
|
color: gray;
|
|
|
|
pointer-events: none;
|
|
|
|
}
|
2023-04-23 13:14:36 +02:00
|
|
|
|
|
|
|
.text {
|
2023-06-19 11:48:58 +02:00
|
|
|
font-size: 0.5em;
|
2023-04-23 13:14:36 +02:00
|
|
|
text-align: center;
|
|
|
|
margin-top: 0.2em;
|
|
|
|
}
|
2021-12-30 19:28:43 +01:00
|
|
|
</style>
|