<script lang="ts" setup> import type { mastodon } from 'masto' import sparkline from '@fnando/sparkline' const { history, width = 60, height = 40, } = $defineProps<{ history?: mastodon.v1.TagHistory[] width?: number height?: number }>() const historyNum = $computed(() => { if (!history) return [1, 1, 1, 1, 1, 1, 1] return [...history].reverse().map(item => Number(item.accounts) || 0) }) const sparklineEl = $ref<SVGSVGElement>() const sparklineFn = typeof sparkline !== 'function' ? (sparkline as any).default : sparkline watch([$$(historyNum), $$(sparklineEl)], ([historyNum, sparklineEl]) => { if (!sparklineEl) return sparklineFn(sparklineEl, historyNum) }) </script> <template> <svg ref="sparklineEl" class="sparkline" :width="width" :height="height" stroke-width="3" /> </template>