akkoma-fe/src/components/still-image/still-image.js

41 lines
953 B
JavaScript
Raw Normal View History

2018-01-29 07:47:26 +00:00
import fileTypeService from '../../services/file_type/file_type.service.js'
const StillImage = {
props: [
'src',
'referrerpolicy',
'mimetype'
],
data () {
return {
hideNsfwLocal: this.$store.state.config.hideNsfw,
}
},
computed: {
animated: {
get () {
// If mimetype is gif then it is certainly animated, if it's undefined - we don't know YET
return this.mimetype === 'image/gif' ? true : this.mimetype == null ? 'maybe' : false
},
set (val) {
this.mimetype = val
}
2018-01-29 07:47:26 +00:00
}
},
methods: {
onLoad () {
2018-01-29 07:47:26 +00:00
const canvas = this.$refs.canvas
if (!canvas) return
canvas.getContext('2d').drawImage(this.$refs.src, 1, 1, canvas.width, canvas.height)
if (this.animated === 'maybe') {
fetch(this.src).then((data) => {
console.log(data)
this.animated = data.type
})
}
2018-01-29 07:47:26 +00:00
}
}
}
export default StillImage