budibase/packages/bbui/src/Button/Button.svelte

108 lines
3.0 KiB
Svelte
Raw Normal View History

2021-03-31 11:59:07 +02:00
<script>
2021-04-08 17:04:27 +02:00
import "@spectrum-css/button/dist/index-vars.css"
import AbsTooltip from "../Tooltip/AbsTooltip.svelte"
import { createEventDispatcher } from "svelte"
2021-04-08 17:04:27 +02:00
2024-11-25 18:24:54 +01:00
export let type = undefined
2021-04-08 17:04:27 +02:00
export let disabled = false
export let size = "M"
2021-04-23 09:41:49 +02:00
export let cta = false
export let primary = false
export let secondary = false
export let warning = false
2021-04-23 09:41:49 +02:00
export let overBackground = false
export let quiet = false
export let icon = undefined
2021-04-20 13:31:08 +02:00
export let active = false
export let tooltip = undefined
export let newStyles = true
2024-11-25 18:24:54 +01:00
export let id = undefined
export let ref = undefined
export let reverse = false
const dispatch = createEventDispatcher()
</script>
2021-04-08 17:04:27 +02:00
<AbsTooltip text={tooltip}>
<button
{id}
{type}
2024-09-02 10:31:19 +02:00
bind:this={ref}
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:new-styles={newStyles}
class:active
class:is-disabled={disabled}
class="spectrum-Button spectrum-Button--size{size.toUpperCase()}"
on:click|preventDefault={() => {
if (!disabled) {
dispatch("click")
}
}}
>
{#if $$slots && reverse}
<span class="spectrum-Button-label"><slot /></span>
{/if}
{#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 && !reverse}
<span class="spectrum-Button-label"><slot /></span>
{/if}
</button>
</AbsTooltip>
2021-03-31 11:59:07 +02:00
<style>
button {
position: relative;
}
button.is-disabled {
cursor: default;
}
2021-04-16 18:12:22 +02:00
.spectrum-Button-label {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
2021-04-26 17:02:03 +02:00
.active {
color: var(--spectrum-global-color-blue-600) !important;
}
.spectrum-Button--primary.new-styles {
background: var(--spectrum-global-color-gray-800);
border-color: transparent;
color: var(--spectrum-global-color-gray-50);
}
.spectrum-Button--primary.new-styles:hover {
background: var(--spectrum-global-color-gray-900);
}
.spectrum-Button--secondary.new-styles {
background: var(--spectrum-global-color-gray-200);
border-color: transparent;
color: var(--spectrum-global-color-gray-900);
}
.spectrum-Button--secondary.new-styles:not(.is-disabled):hover {
background: var(--spectrum-global-color-gray-300);
}
.spectrum-Button--secondary.new-styles.is-disabled {
color: var(--spectrum-global-color-gray-500);
}
.spectrum-Button .spectrum-Button-label + .spectrum-Icon {
margin-left: var(--spectrum-button-primary-icon-gap);
margin-right: calc(
-1 * (var(--spectrum-button-primary-textonly-padding-left-adjusted) -
var(--spectrum-button-primary-padding-left-adjusted))
);
}
2021-03-31 11:59:07 +02:00
</style>