partly working thumbnail work

master
f0x 5 years ago
parent 29cf53ac6a
commit 347a0a1759

@ -56,6 +56,7 @@ let App = create({
}, },
startClient: function(client) { startClient: function(client) {
console.log(client)
client.on("sync", (state, prevState, data) => { client.on("sync", (state, prevState, data) => {
if (state == "ERROR") { if (state == "ERROR") {
} else if (state == "SYNCING") { } else if (state == "SYNCING") {

@ -10,7 +10,8 @@ const User = require('./user.js')
const elements = { const elements = {
"m.text": require('./text.js'), "m.text": require('./text.js'),
"m.image": require('./image.js') "m.image": require('./image.js'),
"m.video": require('./video.js')
} }
const mxReplyRegex = /^<mx-reply>[\s\S]+<\/mx-reply>/ const mxReplyRegex = /^<mx-reply>[\s\S]+<\/mx-reply>/

@ -3,6 +3,7 @@ const React = require('react')
const ReactDOM = require('react-dom') const ReactDOM = require('react-dom')
const create = require('create-react-class') const create = require('create-react-class')
const Promise = require('bluebird') const Promise = require('bluebird')
const defaultValue = require('default-value')
const Text = require('./text.js') const Text = require('./text.js')
@ -10,22 +11,43 @@ let Event = create({
displayName: "m.image", displayName: "m.image",
getInitialState: function() { getInitialState: function() {
let client = this.props.client
let hs = this.props.client.baseUrl let hs = this.props.client.baseUrl
let event = this.props.event let event = this.props.event
if (event.content.url == undefined) { if (event.content.url == undefined) {
return {url: {media: null, thumb: null}} return {url: {media: null, thumb: null}}
} }
let media_mxc = event.content.url.slice(6) console.log(event)
let thumb_mxc = media_mxc
if (event.content.info != undefined && event.content.info.thumbnail_info != undefined) { let h = 1000
thumb_mxc = event.content.info.thumbnail_url.slice(6) let w = 1000
try {
if (event.content.info.h < h) {
h = event.content.info.h
}
if (event.content.info.w < w) {
w = event.content.info.w
}
if (event.content.info.thumbnail_info < h) {
h = event.content.info.thumbnail_info.h
}
if (event.content.info.thumbnail_info < w) {
w = event.content.info.thumbnail_info.w
}
} catch(error) {
} }
let download = `${hs}/_matrix/media/v1/download`
let thumbnail = `${hs}/_matrix/media/v1/thumbnail/${thumb_mxc}?width=1000&height=1000&method=scale` let media_url = client.mxcUrlToHttp(event.content.url)
let thumb_url = client.mxcUrlToHttp(event.content.url, w, h, "scale", false)
return { return {
url: { url: {
media: `${download}/${media_mxc}`, media: media_url,
thumb: thumbnail thumb: thumb_url
} }
} }
}, },

Loading…
Cancel
Save