1
0
Fork 0
mirror of synced 2024-09-12 15:37:31 +12:00
budibase/packages/bbui/src/Icon/Icon.svelte

52 lines
1.2 KiB
Svelte
Raw Normal View History

2021-04-16 22:24:06 +12:00
<script context="module">
export const directions = ["n", "ne", "e", "se", "s", "sw", "w", "nw"]
2021-04-16 22:24:06 +12:00
</script>
<script>
export let direction = "n"
export let name = "Add"
export let hidden = false
export let s = false
export let m = false
export let l = false
export let xl = false
export let hoverable = false
export let disabled = false
2021-04-16 22:24:06 +12:00
$: rotation = directions.indexOf(direction) * 45
$: useDefault = ![s, m, l, xl].includes(true)
2021-04-16 22:24:06 +12:00
</script>
<svg
on:click
class:hoverable
class:disabled
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={hidden}
aria-label={name}
2021-04-23 20:33:41 +12:00
style={`transform: rotate(${rotation}deg)`}
>
<use xlink:href="#spectrum-icon-18-{name}" />
</svg>
<style>
svg.hoverable {
pointer-events: all;
transition: color var(--spectrum-global-animation-duration-100, 130ms);
}
svg.hoverable:hover {
color: var(--spectrum-alias-icon-color-selected);
cursor: pointer;
}
svg.disabled {
color: var(--spectrum-global-color-gray-500) !important;
pointer-events: none !important;
}
</style>