unfinished fetch() version that doesn't work

This commit is contained in:
Henry Jameson 2018-02-03 19:55:45 +03:00
parent b10787d23c
commit 3257991f41
5 changed files with 45 additions and 12 deletions

View File

@ -127,7 +127,6 @@
flex: 1; flex: 1;
img { img {
object-fit: contain;
width: 100%; width: 100%;
height: 100%; /* If this isn't here, chrome will stretch the images */ height: 100%; /* If this isn't here, chrome will stretch the images */
max-height: 500px; max-height: 500px;

View File

@ -4,6 +4,7 @@ import RetweetButton from '../retweet_button/retweet_button.vue'
import DeleteButton from '../delete_button/delete_button.vue' import DeleteButton from '../delete_button/delete_button.vue'
import PostStatusForm from '../post_status_form/post_status_form.vue' import PostStatusForm from '../post_status_form/post_status_form.vue'
import UserCardContent from '../user_card_content/user_card_content.vue' import UserCardContent from '../user_card_content/user_card_content.vue'
import StillImage from '../still-image/still-image.vue'
import { filter, find } from 'lodash' import { filter, find } from 'lodash'
const Status = { const Status = {
@ -76,7 +77,8 @@ const Status = {
RetweetButton, RetweetButton,
DeleteButton, DeleteButton,
PostStatusForm, PostStatusForm,
UserCardContent UserCardContent,
StillImage
}, },
methods: { methods: {
linkClicked ({target}) { linkClicked ({target}) {

View File

@ -34,7 +34,7 @@
<div class="media status container"> <div class="media status container">
<div class="media-left"> <div class="media-left">
<a :href="status.user.statusnet_profile_url"> <a :href="status.user.statusnet_profile_url">
<img @click.prevent="toggleUserExpanded" :class="{retweeted: retweet}" class='avatar' :src="status.user.profile_image_url_original"> <StillImage @click.native.prevent="toggleUserExpanded" :class="{retweeted: retweet}" class='avatar' :src="status.user.profile_image_url_original"/>
<img v-if="retweet" class='avatar-retweeter' :src="statusoid.user.profile_image_url_original"></img> <img v-if="retweet" class='avatar-retweeter' :src="statusoid.user.profile_image_url_original"></img>
</a> </a>
</div> </div>
@ -84,7 +84,7 @@
</div> </div>
<div class="status-preview base00-background base03-border" v-if="showPreview && preview"> <div class="status-preview base00-background base03-border" v-if="showPreview && preview">
<img class="avatar" :src="preview.user.profile_image_url_original"> <StillImage class="avatar" :src="preview.user.profile_image_url_original"/>
<div class="text"> <div class="text">
<h4> <h4>
{{ preview.user.name }} {{ preview.user.name }}
@ -146,6 +146,7 @@
box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5); box-shadow: 2px 2px 3px rgba(0, 0, 0, 0.5);
margin-top: 0.5em; margin-top: 0.5em;
margin-left: 1em; margin-left: 1em;
z-index: 50;
.avatar { .avatar {
flex-shrink: 0; flex-shrink: 0;
@ -266,7 +267,6 @@
margin: 0.2em 0.3em 0 0; margin: 0.2em 0.3em 0 0;
img { img {
float: right; float: right;
border-radius: 5px;
} }
} }
@ -330,6 +330,17 @@
.status .avatar { .status .avatar {
width: 48px; width: 48px;
height: 48px; height: 48px;
border-radius: 5px;
overflow: hidden;
img {
width: 100%;
height: 100%;
}
&.animated::before {
display: none;
}
&.retweeted { &.retweeted {
width: 40px; width: 40px;
@ -339,6 +350,15 @@
} }
} }
.status:hover .animated.avatar {
canvas {
display: none;
}
img {
visibility: visible;
}
}
.status img.avatar-retweeter { .status img.avatar-retweeter {
width: 24px; width: 24px;
height: 24px; height: 24px;

View File

@ -12,16 +12,27 @@ const StillImage = {
} }
}, },
computed: { computed: {
animated () { animated: {
return this.mimetype === 'image/gif' 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
}
} }
}, },
methods: { methods: {
drawCanvas() { onLoad () {
const canvas = this.$refs.canvas const canvas = this.$refs.canvas
if (!canvas) return if (!canvas) return
const ctx = canvas.getContext('2d') canvas.getContext('2d').drawImage(this.$refs.src, 1, 1, canvas.width, canvas.height)
ctx.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
})
}
} }
} }
} }

View File

@ -1,7 +1,7 @@
<template> <template>
<div class='still-image' :class='{ animated: animated }' > <div class='still-image' :class='{ animated: animated }' >
<canvas ref="canvas" v-if="animated"></canvas> <canvas ref="canvas" v-if="animated"></canvas>
<img ref="src" :src="src" :referrerpolicy="referrerpolicy" v-on:load="drawCanvas"/> <img ref="src" :src="src" :referrerpolicy="referrerpolicy" v-on:load="onLoad"/>
</div> </div>
</template> </template>
@ -31,9 +31,10 @@
position: absolute; position: absolute;
top: 5px; top: 5px;
left: 5px; left: 5px;
background: rgba(255,255,255,.5); background: rgba(127,127,127,.7);
display: block; display: block;
padding: 2px; padding: 2px;
border-radius: 3px;
z-index: 2; z-index: 2;
} }
} }