1
0
Fork 0
mirror of synced 2024-06-29 11:31:06 +12:00

update ActionButton interface

This commit is contained in:
Keviin Åberg Kultalahti 2021-04-23 15:45:10 +02:00
parent 422707c18a
commit 47f6509baf
6 changed files with 21 additions and 8 deletions

View file

@ -3,8 +3,6 @@
import { createEventDispatcher } from "svelte"
const dispatch = createEventDispatcher()
/** @type {('S', 'M', 'L', 'XL')} Size of button */
export let size = "M"
export let quiet = false
export let emphasized = false
export let selected = false
@ -12,6 +10,12 @@
export let disabled = false
export let icon = ""
export let xl = false
export let l = false
export let m = false
export let s = false
$: useDefault = ![xl, l, m, s].includes(true)
function longPress(element) {
if (!longPressable) return
let timer
@ -38,7 +42,11 @@
class:spectrum-ActionButton--quiet={quiet}
class:spectrum-ActionButton--emphasized={emphasized}
class:is-selected={selected}
class="spectrum-ActionButton spectrum-ActionButton--size{size.toUpperCase()}"
class:spectrum-ActionButton--sizeS={s}
class:spectrum-ActionButton--sizeM={m || useDefault}
class:spectrum-ActionButton--sizeL={l}
class:spectrum-ActionButton--sizeXL={xl}
class="spectrum-ActionButton"
{disabled}
on:longPress
on:click|preventDefault
@ -54,7 +62,11 @@
{/if}
{#if icon}
<svg
class="spectrum-Icon spectrum-Icon--size{size.toUpperCase()}"
class:spectrum-Icon--sizeS={s}
class:spectrum-Icon--sizeM={m || useDefault}
class:spectrum-Icon--sizeL={l}
class:spectrum-Icon--sizeXL={xl}
class="spectrum-Icon"
focusable="false"
aria-hidden="true"
aria-label={icon}

View file

@ -42,7 +42,7 @@
</div>
<div class="buttons">
<slot name="buttons" />
<ActionButton selected quiet icon="Close" on:click={hide} />
<ActionButton quiet icon="Close" on:click={hide} />
</div>
</header>
<slot name="body" />

View file

@ -13,5 +13,5 @@
<Checkbox value={selected} />
{/if}
{#if allowEditRows}
<ActionButton size="s" on:click={onEdit}>Edit</ActionButton>
<ActionButton s on:click={onEdit}>Edit</ActionButton>
{/if}

View file

@ -65,8 +65,8 @@
{#each tabs as tab, idx}
<div bind:this={anchors[idx]}>
<ActionButton
size="S"
quiet
s
icon={tab.icon}
disabled={tab.disabled}
on:click={tab.disabled ? null : () => onChangeTab(idx)}>

View file

@ -70,6 +70,7 @@
bindings={bindableProperties}
on:change={event => updateFieldValue(idx, event.detail)} />
<ActionButton
s
quiet
icon="Delete"
on:click={() => removeField(field[0])} />

View file

@ -29,7 +29,7 @@
<Heading s>{name}</Heading>
<Spacer medium />
<div class="card-footer" data-cy={`app-${name}`}>
<ActionButton text medium blue on:click={() => $goto(`/builder/${_id}`)}>
<ActionButton on:click={() => $goto(`/builder/${_id}`)}>
Open
{name}