/
Menu.svelte
38 lines (35 loc) · 1.32 KB
/
Menu.svelte
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
<script lang="ts">
export let size = '24';
export let color = 'currentColor';
export let variation: 'solid' | 'outline' = 'outline';
export let ariaLabel = 'bars 3';
let viewBox: string;
let svgpath: string;
let svgoutline = `<path stroke="${color}" stroke-linecap="round" stroke-linejoin="round" d="M4 6h16M4 12h16M4 18h16"></path> `;
let svgsolid = `<path fill="${color}" clip-rule="evenodd" fill-rule="evenodd" d="M3 5a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 10a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1zM3 15a1 1 0 011-1h12a1 1 0 110 2H4a1 1 0 01-1-1z"></path> `;
$: switch (variation) {
case 'outline':
svgpath = svgoutline;
viewBox = '0 0 24 24';
break;
case 'solid':
svgpath = svgsolid;
viewBox = '0 0 24 24';
break;
default:
svgpath = svgoutline;
viewBox = '0 0 24 24';
}
</script>
<svg xmlns="http://www.w3.org/2000/svg" role="button" tabindex="0" width={size} height={size} class={$$props.class} {...$$restProps} aria-label={ariaLabel} fill="none" {viewBox} stroke-width="2" on:click>
{@html svgpath}
</svg>
<!--
@component
[Go to docs](https://flowbite-svelte.com/)
## Props
@prop export let size = '24';
@prop export let color = 'currentColor';
@prop export let variation: 'solid' | 'outline' = 'outline';
@prop export let ariaLabel = 'bars 3';
-->