//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 = '<div id="convList' + tlid + '">' + dmListParse(json, type, acct_id, tlid, "", mute) + '</div>';
		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);
	});

}
function dmmore(tlid) {
	var multi = localStorage.getItem("column");
	var obj = JSON.parse(multi);
	var acct_id = obj[tlid].domain;
	var domain = localStorage.getItem("domain_" + acct_id);
	var at = localStorage.getItem("acct_" + acct_id + "_at");
	var sid = $("#timeline_" + tlid + " .cvo").last().attr("unique-id");
	var start = "https://" + domain + "/api/v1/conversations?max_id=" + sid;
	var type = "dm";
	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 = '<div id="convList' + tlid + '">' + dmListParse(json, type, acct_id, tlid, "", mute) + '</div>';
		$("#timeline_" + tlid).append(templete);
		additional(acct_id, tlid);
		jQuery("time.timeago").timeago();
		moreloading = false;
	})
}
//DMオブジェクトパーサー(トゥート)
function dmListParse(obj, mix, acct_id, tlid, popup, mutefilter) {
	var templete = '';
	if (obj[0]) {
		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 conv_id = obj[key].id;
		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="fas fa-lock red-text"></i>';
		} else {
			var locked = "";
		}
		if (!toot.application) {
			var via = '';
			viashow = "hide";
		} else {
			var via = escapeHTML(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 (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">' + escapeHTML(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 = "";
		}
		if (toot.favourited) {
			var if_fav = " yellow-text";
			var fav_app = "faved";
		} else {
			var if_fav = "";
			var fav_app = "";
		}
		//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;"> ' + escapeHTML(value.name) + '</span></div>';
						break;
					}
				}
			}
		}
		templete = templete + '<div id="pub_' + toot.id + '" class="cvo ' +
			boostback + ' ' + fav_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="far 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 + '' +
			'<br><a onclick="details(\'' + toot.id + '\',' + acct_id +
			',\'' + tlid + '\',\'dm\')" class="pointer waves-effect">' + lang.lang_parse_thread + '</a></div>' +
			'<div class="area-vis"></div>' +
			'</div></div>';
	});
	return templete;
}