2021-01-14 02:56:14 +00:00
Vue . component ( 'tf-message' , {
2021-01-20 02:20:40 +00:00
props : [ 'message' , 'messages' , 'votes' ] ,
2021-01-14 02:56:14 +00:00
data : function ( ) { return { showRaw : false } } ,
computed : {
content _json : function ( ) {
try {
return JSON . parse ( this . message . content ) ;
} catch {
return undefined ;
}
} ,
sub _messages : function ( ) {
var id = this . message . id ;
return this . messages . filter ( function ( x ) {
try {
return JSON . parse ( x . content ) . root == id ;
} catch { }
} ) ;
} ,
2021-01-20 02:20:40 +00:00
votes2 : function ( ) {
2021-01-14 02:56:14 +00:00
var id = this . message . id ;
2021-01-20 02:20:40 +00:00
var votes = this . votes [ id ] || [ ] ;
return votes . reduce ( function ( accum , value ) {
2021-01-14 02:56:14 +00:00
var expression = JSON . parse ( value . content ) . vote . expression ;
if ( ! accum [ expression ] ) {
accum [ expression ] = [ ] ;
}
accum [ expression ] . push ( value ) ;
return accum ;
} , { } ) ;
}
} ,
methods : {
markdown : function ( md ) {
var reader = new commonmark . Parser ( { safe : true } ) ;
var writer = new commonmark . HtmlRenderer ( ) ;
return writer . render ( reader . parse ( md ) ) ;
} ,
json : function ( message ) {
try {
return JSON . parse ( message . content ) ;
} catch {
return undefined ;
}
} ,
} ,
template : ` <md-app class="md-elevation-8" style="margin: 1em" v-if="!content_json || ['pub', 'vote'].indexOf(content_json.type) == -1">
< md - app - toolbar >
< h3 >
< tf - user : id = "message.author" > < / t f - u s e r >
< / h 3 >
< div style = "font-size: x-small" > { { new Date ( message . timestamp ) } } < / d i v >
< div class = "md-toolbar-section-end" >
< md - menu >
< md - button md - menu - trigger class = "md-icon-button" > < md - icon > more _vert < / m d - i c o n > < / m d - b u t t o n >
< md - menu - content >
< md - menu - item v - if = "!showRaw" v - on : click = "showRaw = true" > View Raw < / m d - m e n u - i t e m >
< md - menu - item v - else v - on : click = "showRaw = false" > View Message < / m d - m e n u - i t e m >
< / m d - m e n u - c o n t e n t >
< / m d - m e n u >
< / d i v >
< / m d - a p p - t o o l b a r >
< md - app - content >
< div v - if = "showRaw" > { { message . content } } < / d i v >
< div v - else >
< div v - if = "content_json && content_json.type == 'post'" >
< div v - html = "this.markdown(content_json.text)" > < / d i v >
< img v - for = "mention in content_json.mentions" v - if = "mention.link && typeof(mention.link) == 'string' && mention.link.startsWith('&')" : src = "'/' + mention.link + '/view'" > < / i m g >
< / d i v >
< div v - else - if = "content_json && content_json.type == 'tildefriends-app'" >
< div v - html = "this.markdown(content_json.text)" > < / d i v >
< md - button target = "_top" : href = "'/' + message.id + '/'" > { { content _json . name || 'tildefriends-app' } } < / m d - b u t t o n >
< / d i v >
< div v - else - if = "content_json && content_json.type == 'contact'" > < tf - user : id = "message.author" > < /tf-user> {{content_json.following ? '==>' : '=/ = & gt ; ' } } < tf - user : id = "content_json.contact" > < / t f - u s e r > < / d i v >
< div v - else > { { message . content } } < / d i v >
< / d i v >
2021-01-20 02:20:40 +00:00
< tf - message v - for = "sub_message in sub_messages" v - bind : message = "sub_message" v - bind : messages = "messages" v - bind : votes = "votes" v - bind : key = "sub_message.id" > < / t f - m e s s a g e >
< md - chip v - for = "vote in Object.keys(votes2)" v - bind : key = "vote" >
{ { vote + ( votes2 [ vote ] . length > 1 ? ' (' + votes2 [ vote ] . length + ')' : '' ) } }
2021-01-14 02:56:14 +00:00
< / m d - c h i p >
< / m d - a p p - c o n t e n t >
< / m d - a p p > ` ,
} ) ;