<script lang="ts">
  import type { HTMLAttributes } from 'svelte/elements'
  import { icon_data, type IconName } from './icons'

  interface Props extends HTMLAttributes<SVGSVGElement> {
    icon: IconName
  }
  let { icon, ...rest }: Props = $props()

  const { path, ...svg_props } = $derived.by(() => {
    if (!(icon in icon_data)) {
      console.error(`Icon '${icon}' not found`)
      return icon_data.Alert // fallback
    }
    return icon_data[icon]
  })
</script>

<svg fill="currentColor" aria-hidden="true" {...svg_props} {...rest}>
  {#if path.trim().startsWith(`<`)}
    {@html path}
  {:else}
    <path d={path} />
  {/if}
</svg>

<style>
  svg {
    width: 1em;
    height: 1em;
    display: inline-block;
    vertical-align: middle;
  }
</style>
