543 lines
17 KiB
JavaScript
543 lines
17 KiB
JavaScript
//DM(Conv) TL
|
||
function dm(acct_id, tlid, type,delc,voice) {
|
||
|
||
var domain = localStorage.getItem("domain_" + acct_id);
|
||
var at = localStorage.getItem("acct_"+ acct_id + "_at");
|
||
var start = "https://" + domain + "/api/v1/conversations";
|
||
fetch(start, {
|
||
method: 'GET',
|
||
headers: {
|
||
'content-type': 'application/json',
|
||
'Authorization': 'Bearer ' + at
|
||
},
|
||
}).then(function(response) {
|
||
return response.json();
|
||
}).catch(function(error) {
|
||
todo(error);
|
||
console.error(error);
|
||
}).then(function(json) {
|
||
var templete = dmParse(json, type, acct_id, tlid, "", mute);
|
||
localStorage.setItem("lastobj_"+ tlid,json[0].id)
|
||
$("#timeline_" + tlid).html(templete);
|
||
additional(acct_id, tlid);
|
||
jQuery("time.timeago").timeago();
|
||
todc();
|
||
//reload(type, '', acct_id, tlid, data, mute, delc,voice);
|
||
$(window).scrollTop(0);
|
||
});
|
||
|
||
}
|
||
//DMオブジェクトパーサー(トゥート)
|
||
function dmParse(obj, mix, acct_id, tlid, popup, mutefilter) {
|
||
console.log(obj);
|
||
var templete = '';
|
||
if(obj[0]){
|
||
if(tlid==1){
|
||
console.log("testalive:"+"lastunix_"+ tlid+":"+date(obj[0].created_at, 'unix'))
|
||
}
|
||
localStorage.setItem("lastunix_"+ tlid,date(obj[0].created_at, 'unix'));
|
||
}
|
||
|
||
var actb = localStorage.getItem("action_btns");
|
||
var actb='re,rt,fav,qt,del,pin,red';
|
||
if(actb){
|
||
var actb = actb.split(',');
|
||
var disp={};
|
||
for(var k=0;k<actb.length;k++){
|
||
if(k<4){
|
||
var tp="type-a";
|
||
}else{
|
||
var tp="type-b";
|
||
}
|
||
disp[actb[k]]=tp;
|
||
}
|
||
}
|
||
var datetype = localStorage.getItem("datetype");
|
||
var nsfwtype = localStorage.getItem("nsfw");
|
||
var sent = localStorage.getItem("sentence");
|
||
var ltr = localStorage.getItem("letters");
|
||
var gif = localStorage.getItem("gif");
|
||
var imh = localStorage.getItem("img-height");
|
||
//独自ロケール
|
||
var locale = localStorage.getItem("locale");
|
||
if(locale=="yes"){
|
||
var locale=false;
|
||
}
|
||
//ネイティブ通知
|
||
var native=localStorage.getItem("nativenotf");
|
||
if(!native){
|
||
native="yes";
|
||
}
|
||
//クライアント強調
|
||
var emp = localStorage.getItem("client_emp");
|
||
if(emp){
|
||
var emp = JSON.parse(emp);
|
||
}
|
||
//クライアントミュート
|
||
var mute = localStorage.getItem("client_mute");
|
||
if(mute){
|
||
var mute = JSON.parse(mute);
|
||
}
|
||
//ユーザー強調
|
||
var useremp = localStorage.getItem("user_emp");
|
||
if(useremp){
|
||
var useremp = JSON.parse(useremp);
|
||
}
|
||
//ワード強調
|
||
var wordemp = localStorage.getItem("word_emp");
|
||
if(wordemp){
|
||
var wordemp = JSON.parse(wordemp);
|
||
}
|
||
//ワードミュート
|
||
var wordmute = localStorage.getItem("word_mute");
|
||
if(wordmute){
|
||
var wordmute = JSON.parse(wordmute);
|
||
wordmute = wordmute.concat(mutefilter);
|
||
}else{
|
||
wordmute = mutefilter;
|
||
}
|
||
//Ticker
|
||
var tickerck = localStorage.getItem("ticker_ok");
|
||
if(tickerck){
|
||
var ticker=true;
|
||
}else{
|
||
var ticker=false;
|
||
}
|
||
//Cards
|
||
var card = localStorage.getItem("card_" + tlid);
|
||
|
||
if (!sent) {
|
||
var sent = 500;
|
||
}
|
||
if (!ltr) {
|
||
var ltr = 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";
|
||
}
|
||
if (!gif) {
|
||
var gif = "yes";
|
||
}
|
||
if (!imh) {
|
||
var imh = "200";
|
||
}
|
||
if(!emp){
|
||
var emp=[];
|
||
}
|
||
if(!mute){
|
||
var mute=[];
|
||
}
|
||
if(!useremp){
|
||
var useremp=[];
|
||
}
|
||
if(!wordemp){
|
||
var wordemp=[];
|
||
}
|
||
if(!wordmute){
|
||
var wordmute=[];
|
||
}
|
||
//via通知
|
||
var viashow=localStorage.getItem("viashow");
|
||
if(!viashow){
|
||
viashow="via-hide";
|
||
}
|
||
if(viashow=="hide"){
|
||
viashow="via-hide";
|
||
}
|
||
//認証なしTL
|
||
if(mix=="noauth"){
|
||
var noauth="hide";
|
||
var antinoauth="";
|
||
}else{
|
||
var noauth="";
|
||
var antinoauth="hide";
|
||
}
|
||
//マウスオーバーのみ
|
||
var mouseover=localStorage.getItem("mouseover");
|
||
if(!mouseover){
|
||
mouseover="";
|
||
}else if(mouseover=="yes" || mouseover=="click"){
|
||
mouseover="hide";
|
||
}else if(mouseover=="no"){
|
||
mouseover="";
|
||
}
|
||
var local = [];
|
||
var times=[];
|
||
Object.keys(obj).forEach(function(key) {
|
||
var toot = obj[key].last_status;
|
||
var dis_name=escapeHTML(toot.account.display_name);
|
||
if(toot.account.emojis){
|
||
var actemojick = toot.account.emojis[0];
|
||
}else{
|
||
var actemojick=false;
|
||
}
|
||
//絵文字があれば
|
||
if (actemojick) {
|
||
Object.keys(toot.account.emojis).forEach(function(key5) {
|
||
var emoji = toot.account.emojis[key5];
|
||
var shortcode = emoji.shortcode;
|
||
var emoji_url = '<img src="' + emoji.url +
|
||
'" class="emoji-img" data-emoji="'+shortcode+'" alt=" :'+shortcode+': ">';
|
||
var regExp = new RegExp(":" + shortcode + ":", "g");
|
||
dis_name = dis_name.replace(regExp, emoji_url);
|
||
|
||
});
|
||
}
|
||
var noticeavatar="";
|
||
var if_notf="";
|
||
var uniqueid=toot.id;
|
||
var notice = "";
|
||
var boostback = "";
|
||
//ユーザー強調
|
||
if(toot.account.username!=toot.account.acct){
|
||
var fullname=toot.account.acct;
|
||
}else{
|
||
var domain = localStorage.getItem("domain_" + acct_id);
|
||
var fullname=toot.account.acct+"@"+domain;
|
||
}
|
||
if(useremp){
|
||
Object.keys(useremp).forEach(function(key10) {
|
||
var user = useremp[key10];
|
||
if(user==fullname){
|
||
boostback = "emphasized";
|
||
}
|
||
});
|
||
}
|
||
var id = toot.id;
|
||
var home = "";
|
||
if (toot.account.locked) {
|
||
var locked = ' <i class="fa fa-lock red-text"></i>';
|
||
} else {
|
||
var locked = "";
|
||
}
|
||
if (!toot.application) {
|
||
var via = '';
|
||
viashow="hide";
|
||
} else {
|
||
var via = toot.application.name;
|
||
//強調チェック
|
||
Object.keys(emp).forEach(function(key6) {
|
||
var cli = emp[key6];
|
||
if(cli == via){
|
||
boostback = "emphasized";
|
||
}
|
||
});
|
||
//ミュートチェック
|
||
Object.keys(mute).forEach(function(key7) {
|
||
var cli = mute[key7];
|
||
if(cli == via){
|
||
boostback = "hide";
|
||
}
|
||
});
|
||
}
|
||
if(mix=="pinned"){
|
||
boostback = "emphasized";
|
||
}
|
||
if (toot.spoiler_text && cw) {
|
||
var content = toot.content;
|
||
var spoil = escapeHTML(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">'+lang.lang_parse_cwshow+'</a><br>';
|
||
} else {
|
||
var ct1 = toot.content.split('</p>').length + toot.content.split('<br />').length -2;
|
||
var ct2 = toot.content.split('</p>').length + toot.content.split('<br>').length -2;
|
||
if(ct1>ct2){ var ct= ct1; }else{ var ct= ct2; }
|
||
if ((sent < ct && $.mb_strlen($.strip_tags(toot.content)) > 5) || ($.strip_tags(toot.content).length > ltr && $.mb_strlen($.strip_tags(toot.content)) > 5)) {
|
||
var content = '<span class="gray">'+lang.lang_parse_fulltext+'</span><br>' + toot.content
|
||
var spoil = '<span class="cw-long-' + toot.id + '">' + $.mb_substr($.strip_tags(
|
||
toot.content), 0, 100) +
|
||
'</span><span class="gray">'+lang.lang_parse_autofold+'</span>';
|
||
var spoiler = "cw cw_hide_" + toot.id;
|
||
var spoiler_show = '<a href="#" onclick="cw_show(\'' + toot.id +
|
||
'\')" class="nex parsed">'+lang.lang_parse_more+'</a><br>';
|
||
} else {
|
||
var content = toot.content;
|
||
var spoil = escapeHTML(toot.spoiler_text);
|
||
var spoiler = "";
|
||
var spoiler_show = "";
|
||
}
|
||
}
|
||
var urls = $.strip_tags(content).replace(/\n/g, " ").match(
|
||
/https?:\/\/([-a-zA-Z0-9@.]+)\/?(?!.*((media|tags)|mentions)).*([-_.!~*\'()a-zA-Z0-9;\/?:\@&=+\$,%#]+)?/
|
||
);
|
||
if (urls) {
|
||
var analyze = '<a onclick="additionalIndv(\'' + tlid + '\',' + acct_id +
|
||
',\'' + id + '\')" class="add-show pointer">'+lang.lang_parse_url+'</a><br>';
|
||
} else {
|
||
var analyze = '';
|
||
}
|
||
var viewer = "";
|
||
var hasmedia = "";
|
||
var youtube = "";
|
||
if(toot.emojis){
|
||
var emojick = toot.emojis[0];
|
||
}else{
|
||
var emojick=false;
|
||
}
|
||
//絵文字があれば
|
||
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 +
|
||
'" class="emoji-img" data-emoji="'+shortcode+'" alt=" :'+shortcode+': ">';
|
||
var regExp = new RegExp(":" + shortcode + ":", "g");
|
||
content = content.replace(regExp, emoji_url);
|
||
spoil = spoil.replace(regExp, emoji_url);
|
||
});
|
||
}
|
||
//ニコフレ絵文字
|
||
if(toot.profile_emojis){
|
||
var nicoemojick = toot.profile_emojis[0];
|
||
}else{
|
||
var nicoemojick=false;
|
||
}
|
||
//絵文字があれば
|
||
if (nicoemojick) {
|
||
Object.keys(toot.profile_emojis).forEach(function(keynico) {
|
||
var emoji = toot.profile_emojis[keynico];
|
||
var shortcode = emoji.shortcode;
|
||
var emoji_url = '<img src="' + emoji.url +
|
||
'" class="emoji-img" data-emoji="'+shortcode+'" alt=" :'+shortcode+': ">';
|
||
var regExp = new RegExp(":" + shortcode + ":", "g");
|
||
content = content.replace(regExp, emoji_url);
|
||
spoil = spoil.replace(regExp, emoji_url);
|
||
});
|
||
}
|
||
//デフォ絵文字
|
||
content=twemoji.parse(content);
|
||
if(dis_name){
|
||
dis_name=twemoji.parse(dis_name);
|
||
}
|
||
if(spoil){
|
||
spoil=twemoji.parse(spoil);
|
||
}
|
||
var mediack = toot.media_attachments[0];
|
||
//メディアがあれば
|
||
var media_ids="";
|
||
if (mediack) {
|
||
hasmedia = "hasmedia";
|
||
var cwdt = 100 / toot.media_attachments.length;
|
||
Object.keys(toot.media_attachments).forEach(function(key2) {
|
||
var media = toot.media_attachments[key2];
|
||
var purl = media.preview_url;
|
||
media_ids=media_ids+media.id+",";
|
||
var url = media.url;
|
||
if (toot.sensitive && nsfw) {
|
||
var sense = "sensitive"
|
||
} else {
|
||
var sense = ""
|
||
}
|
||
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 + '%; height:'+imh+'px;"></a></span>';
|
||
});
|
||
media_ids = media_ids.slice(0, -1) ;
|
||
} else {
|
||
viewer = "";
|
||
hasmedia = "nomedia";
|
||
}
|
||
var menck = toot.mentions[0];
|
||
var mentions = "";
|
||
//メンションであれば
|
||
if (menck) {
|
||
mentions = "";
|
||
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> ';
|
||
});
|
||
mentions = '<div style="float:right">' + mentions + '</div>';
|
||
}
|
||
var tagck = toot.tags[0];
|
||
var tags = "";
|
||
//タグであれば
|
||
if (tagck) {
|
||
Object.keys(toot.tags).forEach(function(key4) {
|
||
var tag = toot.tags[key4];
|
||
tags = tags + '<span class="hide" data-tag="' + tag.name + '">#' + tag.name + ':<a onclick="tl(\'tag\',\'' + tag.name + '\',' + acct_id +
|
||
',\'add\')" class="pointer" title="' +lang.lang_parse_tagTL.replace("{{tag}}" ,'#'+tag.name)+ '">TL</a> <a onclick="brInsert(\'#' + tag.name + '\')" class="pointer" title="' + lang.lang_parse_tagtoot.replace("{{tag}}" ,'#'+tag.name) + '">Toot</a> '+
|
||
'<a onclick="tagPin(\'' + tag.name + '\')" class="pointer" title="' +lang.lang_parse_tagpin.replace("{{tag}}" ,'#'+tag.name)+ '">Pin</a></span> ';
|
||
});
|
||
tags = '<div style="float:right">' + tags + '</div>';
|
||
}
|
||
//リプ数
|
||
if(toot.replies_count || toot.replies_count===0){
|
||
var replyct=toot.replies_count;
|
||
}else{
|
||
var replyct="";
|
||
}
|
||
//公開範囲を取得
|
||
var vis = "";
|
||
var visen = toot.visibility;
|
||
if (visen == "public") {
|
||
var vis =
|
||
'<i class="text-darken-3 material-icons gray sml vis-data pointer" title="'+lang.lang_parse_public+'('+lang.lang_parse_clickcopy+')" data-vis="public" onclick="staCopy(\''+id+'\')" style="font-size:1rem;">public</i>';
|
||
var can_rt = "";
|
||
} else if (visen == "unlisted") {
|
||
var vis =
|
||
'<i class="text-darken-3 material-icons blue-text vis-data pointer" title="'+lang.lang_parse_unlisted+'('+lang.lang_parse_clickcopy+')" data-vis="unlisted" onclick="staCopy(\''+id+'\')" style="font-size:1rem;">lock_open</i>';
|
||
var can_rt = "";
|
||
} else if (visen == "private") {
|
||
var vis =
|
||
'<i class="text-darken-3 material-icons orange-text vis-data pointer" title="'+lang.lang_parse_private+'('+lang.lang_parse_clickcopy+')" data-vis="private" onclick="staCopy(\''+id+'\')" style="font-size:1rem;">lock</i>';
|
||
var can_rt = "hide";
|
||
} else if (visen == "direct") {
|
||
var vis =
|
||
'<i class="text-darken-3 material-icons red-text vis-data pointer" title="'+lang.lang_parse_direct+'('+lang.lang_parse_clickcopy+')" data-vis="direct" onclick="staCopy(\''+id+'\')" style="font-size:1rem;">mail</i>';
|
||
var can_rt = "hide";
|
||
}
|
||
if (toot.account.acct == localStorage.getItem("user_" + acct_id)) {
|
||
var if_mine = "";
|
||
var mine_via="type-b";
|
||
} else {
|
||
var if_mine = "hide";
|
||
var mine_via="";
|
||
}
|
||
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 = "";
|
||
}
|
||
if (toot.pinned) {
|
||
var if_pin = "blue-text";
|
||
var pin_app = "pinned";
|
||
} else {
|
||
var if_pin = "";
|
||
var pin_app = "";
|
||
}
|
||
//アニメ再生
|
||
if (gif == "yes") {
|
||
var avatar = toot.account.avatar;
|
||
} else {
|
||
var avatar = toot.account.avatar_static;
|
||
}
|
||
//ワードミュート
|
||
if(wordmute){
|
||
Object.keys(wordmute).forEach(function(key8) {
|
||
var worde = wordmute[key8];
|
||
if(worde){
|
||
if(worde.tag){
|
||
var word=worde.tag;
|
||
}else{
|
||
var word=worde
|
||
}
|
||
var regExp = new RegExp( word, "g" ) ;
|
||
if($.strip_tags(content).match(regExp)){
|
||
boostback = "hide by_filter";
|
||
}
|
||
}
|
||
});
|
||
}
|
||
//ワード強調
|
||
if(wordemp){
|
||
Object.keys(wordemp).forEach(function(key9) {
|
||
var word = wordemp[key9];
|
||
if(word){
|
||
var word=word.tag;
|
||
var regExp = new RegExp( word, "g" ) ;
|
||
content=content.replace(regExp,'<span class="emp">'+word+"</span>");
|
||
}
|
||
});
|
||
}
|
||
//日本語じゃない
|
||
if(toot.language!="ja"){
|
||
var trans='<div class="action pin"><a onclick="trans(\''+toot.language+'\')" class="waves-effect waves-dark btn-flat" style="padding:0" title="'+lang.lang_parse_trans+'"><i class="material-icons">g_translate</i></a></div>';
|
||
}else{
|
||
var trans="";
|
||
}
|
||
//Cards
|
||
if (!card && toot.card) {
|
||
var cards=toot.card;
|
||
if (cards.provider_name=="Twitter"){
|
||
if(cards.image){
|
||
var twiImg='<br><img src="'+cards.image+'">';
|
||
}else{
|
||
var twiImg='';
|
||
}
|
||
analyze='<blockquote class="twitter-tweet"><b>'+escapeHTML(cards.author_name)+'</b><br>'+escapeHTML(cards.description)+twiImg+'</blockquote>';
|
||
}
|
||
if (cards.title) {
|
||
analyze="<span class=\"gray\">URL"+lang.lang_cards_check+":<br>Title:" + escapeHTML(cards.title) + "<br>" +
|
||
escapeHTML(cards.description) + "</span>";
|
||
}
|
||
if (cards.html) {
|
||
analyze=cards.html+'<i class="material-icons" onclick="pip('+id+')" title="'+lang.lang_cards_pip+'">picture_in_picture_alt</i>';
|
||
}
|
||
|
||
}
|
||
//Ticker
|
||
var tickerdom="";
|
||
if(ticker){
|
||
var tickerdata=localStorage.getItem("ticker")
|
||
if(tickerdata){
|
||
var tickerdata=JSON.parse(tickerdata);
|
||
|
||
var thisdomain=toot.account.acct.split("@");
|
||
if(thisdomain.length>1){
|
||
thisdomain=thisdomain[1];
|
||
}
|
||
for( var i=0; i<tickerdata.length; i++) {
|
||
var value=tickerdata[i];
|
||
if(value.domain==thisdomain){
|
||
var tickerdom='<div style="background:linear-gradient(to left,transparent, '+value.bg+' 96%) !important; color:'+value.text+';width:100%; height:0.9rem; font-size:0.8rem;"><img src="'+value.image+'" style="height:100%;"><span style="position:relative; top:-0.2rem;"> '+value.name+'</span></div>';
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
templete = templete + '<div id="pub_' + toot.id + '" class="cvo ' +
|
||
boostback + ' ' + fav_app + ' ' + rt_app + ' ' + pin_app +
|
||
' ' + hasmedia + '" toot-id="' + id + '" unique-id="' + uniqueid + '" data-medias="'+media_ids+' " unixtime="' + date(obj[
|
||
key].created_at, 'unix') + '" '+if_notf+' onclick="dmStatus()">' +
|
||
'<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>'+noticeavatar+'</div>' +
|
||
'<div class="area-display_name"><div class="flex-name"><span class="user">' +
|
||
dis_name +
|
||
'</span><span class="sml gray" style="overflow: hidden;white-space: nowrap;text-overflow: ellipsis; cursor:text;"> @' +
|
||
toot.account.acct + locked + '</span></div>' +
|
||
'<div class="flex-time"><span class="cbadge cbadge-hover pointer waves-effect" onclick="tootUriCopy(\'' +
|
||
toot.url + '\');" title="' + date(toot.created_at, 'absolute') +
|
||
'('+lang.lang_parse_clickcopyurl+')"><i class="fa fa-clock-o"></i>' +
|
||
date(toot.created_at, datetype) + '</span>' +
|
||
'</div></div>' +
|
||
'<div class="area-toot">'+tickerdom+'<span class="' +
|
||
api_spoil + ' cw_text_' + toot.id + '"><span class="cw_text">' + spoil + "</span>" + spoiler_show +
|
||
'</span><span class="toot ' + spoiler + '">' + content +
|
||
'</span>' +
|
||
'' + viewer + '' +
|
||
'</div>'+
|
||
'<div class="area-vis"></div>'+
|
||
'</div></div>';
|
||
});
|
||
return templete;
|
||
} |