2016-12-30 11:57:17 +09:00
|
|
|
const riot = require('riot');
|
2017-03-01 14:32:18 +09:00
|
|
|
//const emojinize = require('emojinize');
|
2017-02-22 04:19:53 +09:00
|
|
|
const CONFIG = require('./config');
|
2016-12-30 11:57:17 +09:00
|
|
|
|
2017-03-01 14:19:59 +09:00
|
|
|
const escape = text =>
|
|
|
|
text
|
2017-02-09 01:07:06 +09:00
|
|
|
.replace(/>/g, '>')
|
|
|
|
.replace(/</g, '<');
|
|
|
|
|
2017-03-01 14:19:59 +09:00
|
|
|
module.exports = (tokens, shouldBreak) => {
|
2016-12-31 18:41:52 +09:00
|
|
|
if (shouldBreak == null) {
|
|
|
|
shouldBreak = true;
|
2016-12-29 07:49:51 +09:00
|
|
|
}
|
2016-12-30 11:57:17 +09:00
|
|
|
|
|
|
|
const me = riot.mixin('i').me;
|
|
|
|
|
2017-03-01 14:19:59 +09:00
|
|
|
let text = tokens.map(token => {
|
2016-12-29 07:49:51 +09:00
|
|
|
switch (token.type) {
|
|
|
|
case 'text':
|
2017-02-09 01:07:06 +09:00
|
|
|
return escape(token.content)
|
|
|
|
.replace(/(\r\n|\n|\r)/g, shouldBreak ? '<br>' : ' ');
|
2016-12-29 07:49:51 +09:00
|
|
|
case 'bold':
|
2017-02-09 01:07:06 +09:00
|
|
|
return '<strong>' + escape(token.bold) + '</strong>';
|
2017-03-18 01:16:32 +09:00
|
|
|
case 'url':
|
2017-02-09 01:07:06 +09:00
|
|
|
return '<mk-url href="' + escape(token.content) + '" target="_blank"></mk-url>';
|
2017-03-18 01:16:32 +09:00
|
|
|
case 'link':
|
|
|
|
return '<a class="link" href="' + escape(token.url) + '" target="_blank">' + escape(token.title) + '</a>';
|
2016-12-29 07:49:51 +09:00
|
|
|
case 'mention':
|
2017-02-11 08:49:50 +09:00
|
|
|
return '<a href="' + CONFIG.url + '/' + escape(token.username) + '" target="_blank" data-user-preview="' + token.content + '" ' + (me && me.username == token.username ? 'data-is-me' : '') + '>' + token.content + '</a>';
|
2016-12-29 07:49:51 +09:00
|
|
|
case 'hashtag': // TODO
|
2017-02-09 01:07:06 +09:00
|
|
|
return '<a>' + escape(token.content) + '</a>';
|
|
|
|
case 'code':
|
2017-02-12 02:38:47 +09:00
|
|
|
return '<pre><code>' + token.html + '</code></pre>';
|
2017-02-11 23:41:57 +09:00
|
|
|
case 'inline-code':
|
2017-02-12 02:38:47 +09:00
|
|
|
return '<code>' + token.html + '</code>';
|
2017-03-01 05:33:27 +09:00
|
|
|
case 'emoji':
|
2017-03-01 14:32:18 +09:00
|
|
|
return '<i>' + token.content + '</i>';
|
|
|
|
//return emojinize.encode(token.content)
|
2016-12-29 07:49:51 +09:00
|
|
|
}
|
|
|
|
}).join('');
|
2016-12-30 11:57:17 +09:00
|
|
|
|
2017-03-01 14:22:56 +09:00
|
|
|
// Remove needless whitespaces
|
2017-03-01 14:22:29 +09:00
|
|
|
text = text
|
|
|
|
.replace(/ <code>/g, '<code>').replace(/<\/code> /g, '</code>')
|
|
|
|
.replace(/<br><code><pre>/g, '<code><pre>').replace(/<\/code><\/pre><br>/g, '</code></pre>');
|
2017-02-09 01:07:06 +09:00
|
|
|
|
2016-12-30 11:57:17 +09:00
|
|
|
return text;
|
2017-03-01 14:19:59 +09:00
|
|
|
};
|