import { decode } from 'blurhash'
import { getDataUrlFromArr } from '~/composables/utils'

export default defineComponent({
  inheritAttrs: false,
  props: {
    blurhash: {
      type: String,
      required: true,
    },
    src: {
      type: String,
      required: true,
    },
  },
  setup(props, { attrs }) {
    const placeholderSrc = ref<string>()
    const isLoaded = ref(false)

    onMounted(() => {
      const img = document.createElement('img')
      isLoaded.value = img.complete
      img.onload = () => {
        isLoaded.value = true
      }
      img.src = props.src
      setTimeout(() => {
        isLoaded.value = true
      }, 3_000)

      if (props.blurhash) {
        const pixels = decode(props.blurhash, 32, 32)
        placeholderSrc.value = getDataUrlFromArr(pixels, 32, 32)
      }
    })

    return () => isLoaded.value || !placeholderSrc.value
      ? h('img', { ...attrs, src: props.src })
      : h('img', { ...attrs, src: placeholderSrc.value })
  },
})