budibase/packages/standard-components/src/Text.svelte

43 lines
1.3 KiB
Svelte

<script>
import { getContext } from "svelte"
const { styleable } = getContext("sdk")
const styles = getContext("style")
export let text = ""
export let className = ""
export let type = ""
const isTag = tag => type === tag
</script>
{#if isTag('none')}
<span use:styleable={$styles}>{text}</span>
{:else if isTag('bold')}
<b class={className} use:styleable={$styles}>{text}</b>
{:else if isTag('strong')}
<strong class={className} use:styleable={$styles}>{text}</strong>
{:else if isTag('italic')}
<i class={className} use:styleable={$styles}>{text}</i>
{:else if isTag('emphasis')}
<em class={className} use:styleable={$styles}>{text}</em>
{:else if isTag('mark')}
<mark class={className} use:styleable={$styles}>{text}</mark>
{:else if isTag('small')}
<small class={className} use:styleable={$styles}>{text}</small>
{:else if isTag('del')}
<del class={className} use:styleable={$styles}>{text}</del>
{:else if isTag('ins')}
<ins class={className} use:styleable={$styles}>{text}</ins>
{:else if isTag('sub')}
<sub class={className} use:styleable={$styles}>{text}</sub>
{:else if isTag('sup')}
<sup class={className} use:styleable={$styles}>{text}</sup>
{:else}<span use:styleable={$styles}>{text}</span>{/if}
<style>
span {
display: inline-block;
}
</style>