Whalebird-desktop-client-ma.../src/renderer/components/atoms/FailoverImg.vue

94 lines
5.6 KiB
Vue

<template>
<img
:src="originalSrc"
:title="title"
:alt="alt"
v-on:error="failover"
v-on:load="loading = false"
:class="loading ? 'loading' : ''"
@click="$emit('click')"
/>
</template>
<script lang="ts">
import { defineComponent, ref, toRefs, onMounted, watch } from 'vue'
import exifImageUrl from '@/components/utils/exifImageUrl'
export default defineComponent({
name: 'FailoverImg',
props: {
src: {
type: String,
default: ''
},
title: {
type: String,
default: ''
},
alt: {
type: String,
default: ''
},
readExif: {
type: Boolean,
default: false
},
failoverSrc: {
type: String,
default:
''
}
},
setup(props) {
const { src, readExif, failoverSrc } = toRefs(props)
const loading = ref<boolean>(false)
const originalSrc = ref<string>(src.value)
onMounted(async () => {
if (readExif.value) {
try {
const transformed = await exifImageUrl(src.value)
originalSrc.value = transformed
} catch (err) {
console.warn(err)
}
}
})
watch(src, async (newSrc, _oldSrc) => {
originalSrc.value = newSrc
if (readExif.value) {
try {
const transformed = await exifImageUrl(newSrc)
originalSrc.value = transformed
} catch (err) {}
}
})
const failover = () => {
originalSrc.value = failoverSrc.value
}
return {
loading,
originalSrc,
failover
}
}
})
</script>
<style lang="scss" scoped>
img {
min-width: 1em;
min-height: 1em;
&.loading {
background-image: url('../../assets/images/loading-spinner.svg');
background-position: center center;
background-repeat: no-repeat;
background-size: contain;
}
}
</style>