53 lines
1.3 KiB
Svelte
53 lines
1.3 KiB
Svelte
<script>
|
|
import "@spectrum-css/button/dist/index-vars.css"
|
|
|
|
export let disabled = false
|
|
export let size = "M"
|
|
export let cta = false
|
|
export let primary = false
|
|
export let secondary = false
|
|
export let warning = false
|
|
export let overBackground = false
|
|
export let quiet = false
|
|
export let icon = undefined
|
|
export let active = false
|
|
</script>
|
|
|
|
<button
|
|
class:spectrum-Button--cta={cta}
|
|
class:spectrum-Button--primary={primary}
|
|
class:spectrum-Button--secondary={secondary}
|
|
class:spectrum-Button--warning={warning}
|
|
class:spectrum-Button--overBackground={overBackground}
|
|
class:spectrum-Button--quiet={quiet}
|
|
class:active
|
|
class="spectrum-Button spectrum-Button--size{size.toUpperCase()}"
|
|
{disabled}
|
|
on:click|preventDefault
|
|
>
|
|
{#if icon}
|
|
<svg
|
|
class="spectrum-Icon spectrum-Icon--size{size.toUpperCase()}"
|
|
focusable="false"
|
|
aria-hidden="true"
|
|
aria-label={icon}
|
|
>
|
|
<use xlink:href="#spectrum-icon-18-{icon}" />
|
|
</svg>
|
|
{/if}
|
|
{#if $$slots}
|
|
<span class="spectrum-Button-label"><slot /></span>
|
|
{/if}
|
|
</button>
|
|
|
|
<style>
|
|
.spectrum-Button-label {
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
.active {
|
|
color: var(--spectrum-global-color-blue-600) !important;
|
|
}
|
|
</style>
|