thedesk/app/js/tl/parse.js

314 lines
11 KiB
JavaScript
Raw Normal View History

2018-01-28 23:22:43 +11:00
//オブジェクトパーサー(トゥート)
function parse(obj, mix, acct_id) {
var templete = '';
var datetype = localStorage.getItem("datetype");
var nsfwtype = localStorage.getItem("nsfw");
var sent = localStorage.getItem("sentence");
2018-02-24 03:02:44 +11:00
var ltr = localStorage.getItem("letters");
2018-02-18 18:29:06 +11:00
var gif = localStorage.getItem("gif");
2018-01-28 23:22:43 +11:00
if (!sent) {
var sent = 500;
}
if (!nsfwtype || nsfwtype == "yes") {
var nsfw = "ok";
} else {
var nsfw;
}
var cwtype = localStorage.getItem("cw");
if (!cwtype || cwtype == "yes") {
var cw = "ok";
} else {
var cw;
}
if (!datetype) {
datetype = "absolute";
}
2018-02-24 03:02:44 +11:00
if (!gif) {
var gif = "yes";
2018-02-18 18:29:06 +11:00
}
2018-01-28 23:22:43 +11:00
var local = [];
Object.keys(obj).forEach(function(key) {
var toot = obj[key];
var id = toot.id;
//Integratedである場合はUnix時間をキーに配列を生成しておく
if (mix == "mix") {
local[date(obj[key].created_at, 'unix')] = toot.id;
2018-02-24 03:02:44 +11:00
var divider = '<div class="divider"></div>';
2018-01-28 23:22:43 +11:00
}
if (mix == "home") {
var home = "Home TLより"
2018-02-24 03:02:44 +11:00
var divider = "";
2018-01-28 23:22:43 +11:00
} else {
var home = "";
2018-02-24 03:02:44 +11:00
var divider = '<div class="divider"></div>';
2018-01-28 23:22:43 +11:00
}
if (toot.reblog) {
var notice = toot.account.display_name + "(" + toot.account.acct +
")がブースト<br>";
var boostback = "shared";
var toot = toot.reblog;
} else {
var notice = "";
var boostback = "";
}
if (toot.account.locked) {
var locked = ' <i class="fa fa-lock red-text"></i>';
} else {
var locked = "";
}
if (!toot.application) {
2018-02-18 16:43:11 +11:00
var via = '<span style="font-style: italic;">Unknown</span>';
2018-01-28 23:22:43 +11:00
} else {
var via = toot.application.name;
}
if (toot.spoiler_text && cw) {
var content = toot.content;
var spoil = toot.spoiler_text;
var spoiler = "cw cw_hide_" + toot.id;
var api_spoil = "gray";
var spoiler_show = '<a href="#" onclick="cw_show(\'' + toot.id +
'\')" class="nex parsed">見る</a>';
} else {
var ct = toot.content.split('</p>').length + toot.content.split('<br />').length -
2;
2018-02-24 03:02:44 +11:00
if ((sent < ct && $.mb_strlen($.strip_tags(toot.content)) > 5) || ($.strip_tags(toot.content).length > ltr && $.mb_strlen($.strip_tags(toot.content)) > 5)) {
2018-01-28 23:22:43 +11:00
var content = '<span class="gray">以下全文</span><br>' + toot.content
2018-02-24 03:02:44 +11:00
var spoil = '<span class="cw-long-' + toot.id + '">' + $.mb_substr($.strip_tags(
toot.content), 0, 100) +
2018-02-13 06:16:46 +11:00
'</span><span class="gray">自動折りたたみ</span>';
2018-01-28 23:22:43 +11:00
var spoiler = "cw cw_hide_" + toot.id;
var spoiler_show = '<a href="#" onclick="cw_show(\'' + toot.id +
2018-02-24 03:02:44 +11:00
'\')" class="nex parsed">続き…</a><br>';
2018-01-28 23:22:43 +11:00
} else {
var content = toot.content;
var spoil = toot.spoiler_text;
var spoiler = "";
var spoiler_show = "";
}
}
2018-02-13 06:16:46 +11:00
var urls = content.match(
2018-02-24 03:02:44 +11:00
/https?:\/\/([-a-zA-Z0-9@.]+)\/?(?!.*((media|tags)|mentions)).*([-_.!~*\'()a-zA-Z0-9;\/?:\@&=+\$,%#]+)?/
2018-02-13 06:16:46 +11:00
);
2018-02-24 03:02:44 +11:00
if (urls) {
var analyze = '<a onclick="additionalIndv(\'' + tlid + '\',' + acct_id +
',\'' + id + '\')" class="add-show pointer">URL解析</a><br>';
} else {
var analyze = '';
2018-02-13 06:16:46 +11:00
}
2018-01-28 23:22:43 +11:00
var viewer = "";
2018-02-24 03:02:44 +11:00
var hasmedia = "";
2018-01-28 23:22:43 +11:00
var youtube = "";
var emojick = toot.emojis[0];
//絵文字があれば
if (emojick) {
Object.keys(toot.emojis).forEach(function(key5) {
var emoji = toot.emojis[key5];
var shortcode = emoji.shortcode;
var emoji_url = '<img src="' + emoji.url +
2018-02-14 03:19:44 +11:00
'" style="width:1em" class="emoji-img">';
2018-01-28 23:22:43 +11:00
var regExp = new RegExp(":" + shortcode + ":", "g");
content = content.replace(regExp, emoji_url);
});
}
var mediack = toot.media_attachments[0];
//メディアがあれば
if (mediack) {
2018-02-18 03:44:03 +11:00
hasmedia = "hasmedia";
2018-02-24 03:02:44 +11:00
var cwdt = 100 / toot.media_attachments.length
2018-01-28 23:22:43 +11:00
Object.keys(toot.media_attachments).forEach(function(key2) {
var media = toot.media_attachments[key2];
var purl = media.preview_url;
var url = media.url;
if (toot.sensitive && nsfw) {
var sense = "sensitive"
} else {
var sense = ""
}
2018-02-24 03:02:44 +11:00
viewer = viewer + '<a onclick="imgv(\'' + id + '\',\'' + key2 + '\',' +
acct_id + ')" id="' + id + '-image-' + key2 + '" data-url="' + url +
'" data-type="' + media.type + '" class="img-parsed"><img src="' +
purl + '" class="' + sense +
' toot-img pointer" style="width:' + cwdt + '%"></a></span>';
2018-01-28 23:22:43 +11:00
});
} else {
viewer = "";
2018-02-18 03:44:03 +11:00
hasmedia = "nomedia";
2018-01-28 23:22:43 +11:00
}
var menck = toot.mentions[0];
var mentions = "";
//メンションであれば
if (menck) {
mentions = "Links: ";
Object.keys(toot.mentions).forEach(function(key3) {
var mention = toot.mentions[key3];
mentions = mentions + '<a onclick="udg(\'' + mention.id + '\',' +
acct_id + ')" class="pointer">@' + mention.acct + '</a> ';
});
2018-02-24 03:02:44 +11:00
mentions = '<div style="float:right">' + mentions + '</div>';
2018-01-28 23:22:43 +11:00
}
var tagck = toot.tags[0];
var tags = "";
//タグであれば
if (tagck) {
if (!menck) {
tags = "Links: ";
}
Object.keys(toot.tags).forEach(function(key4) {
var tag = toot.tags[key4];
tags = tags + '<a onclick="tl(\'tag\',\'' + tag.name + '\',' + acct_id +
',\'add\')" class="pointer">#' + tag.name + '</a> ';
});
2018-02-24 03:02:44 +11:00
tags = '<div style="float:right">' + tags + '</div>';
2018-01-28 23:22:43 +11:00
}
2018-02-18 16:43:11 +11:00
//公開範囲を取得
2018-02-24 03:02:44 +11:00
var vis = "";
var visen = toot.visibility;
if (visen == "public") {
var vis =
'<i class="text-darken-3 material-icons gray sml" title="公開">public</i>';
} else if (visen == "unlisted") {
var vis =
'<i class="text-darken-3 material-icons blue-text" title="未収載">lock_open</i>';
} else if (visen == "plivate") {
var vis =
'<i class="text-darken-3 material-icons orange-text" title="非公開">lock</i>';
} else if (visen == "direct") {
var vis =
'<i class="text-darken-3 material-icons red-text" title="ダイレクト">mail</i>';
2018-02-18 16:43:11 +11:00
}
2018-01-28 23:22:43 +11:00
if (toot.account.acct == localStorage.getItem("user_" + acct_id)) {
var if_mine = "";
} else {
var if_mine = "hide";
}
if (toot.favourited) {
var if_fav = " yellow-text";
var fav_app = "faved";
} else {
var if_fav = "";
var fav_app = "";
}
if (toot.reblogged) {
var if_rt = "teal-text";
var rt_app = "rted";
} else {
var if_rt = "";
var rt_app = "";
}
2018-02-18 18:29:06 +11:00
//アニメ再生
2018-02-24 03:02:44 +11:00
if (gif == "yes") {
var avatar = toot.account.avatar;
} else {
var avatar = toot.account.avatar_static;
2018-02-18 18:29:06 +11:00
}
2018-02-18 16:43:11 +11:00
templete = templete + '<div id="pub_' + toot.id + '" class="cvo ' +
2018-02-24 03:02:44 +11:00
boostback + ' ' + fav_app + ' ' + rt_app +
' ' + hasmedia + '" toot-id="' + id + '" unixtime="' + date(obj[
key].created_at, 'unix') + '">' +
'<div class="area-notice"><span class="gray sharesta">' + notice + home +
'</span></div>' +
'<div class="area-icon"><a onclick="udg(\'' + toot.account.id +
'\',' + acct_id + ');" user="' + toot.account.acct + '" class="udg">' +
'<img src="' + avatar +
'" width="40" class="prof-img" user="' + toot.account.acct +
'"></a></div>' +
'<div class="area-display_name"><span class="user">' +
toot.account.display_name +
2018-02-25 18:21:13 +11:00
'</span><span class="sml gray" style="overflow: hidden;white-space: nowrap;text-overflow: ellipsis; cursor:text;"> @' +
2018-02-24 03:02:44 +11:00
toot.account.acct + locked + '</span></div>' +
'<div class="area-acct"><div><span class="cbadge pointer" onclick="tootUriCopy(\'' +
toot.url + '\');" title="' + date(toot.created_at, 'absolute') +
'(クリックでトゥートURLをコピー)"><i class="fa fa-clock-o"></i>' +
date(toot.created_at, datetype) + '</span></div></div>' +
'<div class="area-toot"><span class="toot ' + spoiler + '">' + content +
'</span><span class="' +
api_spoil + ' cw_text_' + toot.id + '">' + spoil + spoiler_show +
'</span>' +
'' + viewer + '' +
'</div><div class="area-additional"><span class="additional">' + analyze +
'</span>' +
'' + mentions + tags + '</div>' +
'<div class="area-actions" style="padding:0; margin:0; top:-20px; display:flex; justify-content:space-around; max-width:100%; ">' +
'<div class="action"><span class="waves-effect waves-dark btn-flat" style="padding:0">' +
vis + '</span></div><div class="action"><a onclick="re(\'' + toot.id +
'\',\'' + toot.account.acct + '\',' +
acct_id +
')" class="waves-effect waves-dark btn-flat" style="padding:0"><i class="fa fa-share"></i></a></div>' +
'<div class="action"><a onclick="rt(\'' + toot.id + '\',' + acct_id +
',\'' + tlid +
'\')" class="waves-effect waves-dark btn-flat" style="padding:0"><i class="text-darken-3 fa fa-retweet ' +
if_rt + ' rt_' + toot.id + '"></i><span class="rt_ct">' + toot.reblogs_count +
'</span></a></div>' +
'<div class="action"><a onclick="fav(\'' + toot.id + '\',' + acct_id +
',\'' + tlid +
'\')" class="waves-effect waves-dark btn-flat" style="padding:0"><i class="fa text-darken-3 fa-star' +
if_fav + ' fav_' + toot.id + '"></i><span class="fav_ct">' + toot.favourites_count +
'</a></span></div>' +
'<div class="' + if_mine + ' action"><a onclick="del(\'' + toot.id + '\',' +
acct_id +
')" class="waves-effect waves-dark btn-flat" style="padding:0"><i class="fa fa-trash-o"></i></a></div>' +
'<div class="action"><a onclick="details(\'' + toot.id + '\',' + acct_id +
')" class="waves-effect waves-dark btn-flat details" style="padding:0"><i class="text-darken-3 material-icons">more_vert</i></a></div>' +
'</div><div class="area-date_via">' +
'<div><span class="cbadge" title="via ' + $.strip_tags(via) + '">via ' +
via +
'</span></div></div></div>' +
'</div>' + divider;
2018-01-28 23:22:43 +11:00
});
if (mix == "mix") {
return [templete, local]
} else {
return templete;
}
}
//オブジェクトパーサー(ユーザーデータ)
2018-02-25 02:59:53 +11:00
function userparse(obj, auth, acct_id, notf) {
2018-01-28 23:22:43 +11:00
var templete = '';
2018-02-24 03:02:44 +11:00
var datetype = localStorage.getItem("datetype");
2018-01-28 23:22:43 +11:00
Object.keys(obj).forEach(function(key) {
var toot = obj[key];
if (toot.locked) {
var locked = ' <i class="fa fa-lock red-text"></i>';
} else {
var locked = "";
}
if (auth) {
var auth = '<i class="material-icons gray pointer" onclick="request(\'' +
toot.id + '\',\'authorize\',' + acct_id + ')">person_add</i>';
} else {
var auth = "";
}
2018-02-24 03:02:44 +11:00
if(notf){
var notftext='<span class="cbadge"title="' + date(toot.created_at,
'absolute') + '(通知された時間)"><i class="fa fa-clock-o"></i>' + date(toot.created_at,
datetype) +
'</span>フォローされました。<br>';
}else{
var notftext="";
}
2018-01-28 23:22:43 +11:00
templete = templete +
2018-02-24 03:02:44 +11:00
'<div class="" style="padding-top:5px;" user-id="' + toot.id + '">' +
notftext +
2018-01-28 23:22:43 +11:00
'<div style="padding:0; margin:0; width:400px; max-width:100%; display:flex; align-items:flex-end;">' +
'<div style="flex-basis:40px;"><a onclick="udg(\'' + toot.id + '\',' +
acct_id + ');" user="' + toot.acct + '" class="udg">' +
'<img src="' + toot.avatar + '" width="40" class="prof-img" user="' + toot
.acct + '"></a></div>' +
2018-02-25 18:21:13 +11:00
'<div style="flex-grow:3; overflow: hidden;white-space: nowrap;text-overflow: ellipsis;user-select:auto; cursor:text;"><big>' +
2018-01-28 23:22:43 +11:00
toot.display_name + '</big></div>' +
2018-02-25 18:21:13 +11:00
'<div class="sml gray" style="overflow: hidden;white-space: nowrap;text-overflow: ellipsis;user-select:auto; cursor:text;"> @' +
2018-01-28 23:22:43 +11:00
toot.acct + locked + '</div>' +
'</div>' + auth +
2018-02-24 03:02:44 +11:00
'<div style="justify-content:space-around"> <div class="cbadge" style="width:100px;">Follows:' +
toot.following_count +
'</div><div class="cbadge" style="width:100px;">Followers:' + toot.followers_count +
2018-01-28 23:22:43 +11:00
'</div>' +
'<div class="divider"></div>' +
'</div>' +
'</div>';
});
return templete;
}