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"
|
2023-07-07 13:09:23 +02:00
|
|
|
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
|
2021-04-15 12:50:56 +02:00
|
|
|
export let size = "M"
|
2021-04-23 09:41:49 +02:00
|
|
|
export let cta = false
|
|
|
|
export let primary = false
|
|
|
|
export let secondary = false
|
2021-04-21 15:59:08 +02:00
|
|
|
export let warning = false
|
2021-04-23 09:41:49 +02:00
|
|
|
export let overBackground = false
|
2021-04-08 18:04:03 +02:00
|
|
|
export let quiet = false
|
2021-04-15 12:50:56 +02:00
|
|
|
export let icon = undefined
|
2021-04-20 13:31:08 +02:00
|
|
|
export let active = false
|
2022-02-07 19:47:10 +01:00
|
|
|
export let tooltip = undefined
|
2022-12-14 16:51:56 +01:00
|
|
|
export let newStyles = true
|
2024-11-25 18:24:54 +01:00
|
|
|
export let id = undefined
|
|
|
|
export let ref = undefined
|
2024-09-06 10:20:00 +02:00
|
|
|
export let reverse = false
|
2023-07-07 13:09:23 +02:00
|
|
|
|
|
|
|
const dispatch = createEventDispatcher()
|
2021-04-15 12:50:56 +02:00
|
|
|
</script>
|
2021-04-08 17:04:27 +02:00
|
|
|
|
2023-07-07 13:09:23 +02:00
|
|
|
<AbsTooltip text={tooltip}>
|
|
|
|
<button
|
|
|
|
{id}
|
|
|
|
{type}
|
2024-09-02 10:31:19 +02:00
|
|
|
bind:this={ref}
|
2023-07-07 13:09:23 +02:00
|
|
|
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")
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
>
|
2024-09-06 10:20:00 +02:00
|
|
|
{#if $$slots && reverse}
|
|
|
|
<span class="spectrum-Button-label"><slot /></span>
|
|
|
|
{/if}
|
2023-07-07 13:09:23 +02:00
|
|
|
{#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}
|
2024-09-06 10:20:00 +02:00
|
|
|
{#if $$slots && !reverse}
|
2023-07-07 13:09:23 +02:00
|
|
|
<span class="spectrum-Button-label"><slot /></span>
|
|
|
|
{/if}
|
|
|
|
</button>
|
|
|
|
</AbsTooltip>
|
2021-03-31 11:59:07 +02:00
|
|
|
|
|
|
|
<style>
|
2022-02-14 17:49:56 +01:00
|
|
|
button {
|
2022-02-15 13:01:50 +01:00
|
|
|
position: relative;
|
2022-02-07 19:47:10 +01:00
|
|
|
}
|
2023-07-07 13:09:23 +02:00
|
|
|
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;
|
|
|
|
}
|
2022-06-10 13:15:58 +02:00
|
|
|
.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);
|
|
|
|
}
|
2023-07-07 13:09:23 +02:00
|
|
|
.spectrum-Button--secondary.new-styles:not(.is-disabled):hover {
|
2022-06-10 13:15:58 +02:00
|
|
|
background: var(--spectrum-global-color-gray-300);
|
|
|
|
}
|
2023-07-07 13:09:23 +02:00
|
|
|
.spectrum-Button--secondary.new-styles.is-disabled {
|
2022-12-16 16:54:34 +01:00
|
|
|
color: var(--spectrum-global-color-gray-500);
|
|
|
|
}
|
2024-09-06 10:20:00 +02:00
|
|
|
.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>
|