budibase/packages/materialdesign-components/src/IconButton/IconButton.svelte

76 lines
1.9 KiB
Svelte
Raw Normal View History

2020-03-11 15:04:47 +01:00
<script>
2020-03-20 10:57:49 +01:00
import { onMount } from "svelte"
2020-03-11 17:28:09 +01:00
import ripple from "../Common/Ripple.js"
import ClassBuilder from "../ClassBuilder.js"
2020-03-11 15:04:47 +01:00
2020-03-11 17:28:09 +01:00
const cb = new ClassBuilder("icon-button")
2020-03-11 15:04:47 +01:00
let on = false
2020-03-11 17:28:09 +01:00
export let _bb
export let context = ""
export let onClick = () => {}
export let disabled = false
export let href = ""
export let icon = ""
export let onIcon = "" //on state icon for toggle button
export let size = "medium"
2020-03-11 15:04:47 +01:00
2020-03-20 10:57:49 +01:00
onMount(() => {
let ctx = !!_bb ? _bb.getContext("BBMD:icon-button:context") : ""
//It isn't possible to use context within nested components as they do not have their own _bb instance (has to be passed down from parent component). This allows context to be passed as props
if (!context && !!ctx) {
context = ctx
}
})
function onButtonClick() {
open = !open
_bb.call(onClick)
}
2020-03-11 17:28:09 +01:00
$: isToggleButton = !!icon && !!onIcon
$: useLinkButton = !!href
2020-03-11 15:04:47 +01:00
2020-03-11 17:28:09 +01:00
$: customs = { size }
$: props = { customs, extras: ["material-icons", context] }
$: iconBtnClass = cb.build({ props })
2020-03-11 15:04:47 +01:00
</script>
{#if useLinkButton}
<a
on:click={onButtonClick}
class={iconBtnClass}
{href}
{disabled}
role="button"
tabindex="0">
2020-03-11 15:04:47 +01:00
{#if isToggleButton}
2020-03-11 17:28:09 +01:00
<i
use:ripple
class="material-icons mdc-icon-button__icon mdc-icon-button__icon--on">
2020-03-11 15:04:47 +01:00
{onIcon}
</i>
2020-03-11 17:28:09 +01:00
<i use:ripple class="material-icons mdc-icon-button__icon">{icon}</i>
2020-03-11 15:04:47 +01:00
{:else}{icon}{/if}
</a>
{:else}
2020-03-11 17:28:09 +01:00
<button
on:click={onButtonClick}
2020-03-11 17:28:09 +01:00
class={iconBtnClass}
{disabled}
role="button"
aria-label="Add to favorites"
aria-pressed="false"
2020-03-11 17:28:09 +01:00
tabindex="0">
2020-03-11 15:04:47 +01:00
{#if isToggleButton}
<i use:ripple class="material-icons mdc-icon-button__icon">{icon}</i>
2020-03-11 17:28:09 +01:00
<i
use:ripple
class="material-icons mdc-icon-button__icon mdc-icon-button__icon--on">
2020-03-11 15:04:47 +01:00
{onIcon}
</i>
{:else}{icon}{/if}
</button>
{/if}