1
0
Fork 0
mirror of synced 2024-09-10 22:46:09 +12:00
budibase/packages/bbui/src/Button/Button.svelte

48 lines
1.2 KiB
Svelte
Raw Normal View History

2021-03-31 22:59:07 +13:00
<script>
2021-04-09 03:04:27 +12:00
import "@spectrum-css/button/dist/index-vars.css"
export let disabled = false
export let size = "M"
export let cta, primary, secondary, warning, overBackground
export let quiet = false
export let icon = undefined
2021-04-20 23:31:08 +12:00
export let active = false
</script>
2021-04-09 03:04:27 +12:00
<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}
2021-04-20 23:31:08 +12:00
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}
2021-04-09 03:04:27 +12:00
<span class="spectrum-Button-label"><slot /></span>
{/if}
</button>
2021-03-31 22:59:07 +13:00
<style>
2021-04-17 04:12:22 +12:00
.spectrum-Button-label {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
2021-04-20 23:31:08 +12:00
button.active {
color: var(--spectrum-semantic-cta-color-background-default);
}
2021-03-31 22:59:07 +13:00
</style>