//BBCodeとMarkdownの入力・パーサー //アカウント変えた時にBBとかMDとか function mdCheck() { var acct_id = $("#post-acct-sel").val(); var profimg = localStorage.getItem("prof_" + acct_id); if (!profimg) { profimg = "../../img/missing.svg"; } $("#acct-sel-prof").attr("src", profimg); if (localStorage.getItem("post_" + acct_id)) { $("#toot-post-btn").text(localStorage.getItem("post_" + acct_id) + "(" + localStorage.getItem("domain_" + acct_id) + ")"); } else { $("#toot-post-btn").text(lang.lang_toot + "(" + localStorage.getItem("domain_" + acct_id) + ")"); } if (!localStorage.getItem("bb_" + acct_id) && !localStorage.getItem("md_" + acct_id)) { $(".markdown").addClass("hide"); $(".anti-markdown").addClass("hide"); } else { $(".anti-markdown").removeClass("hide"); } if ($(".markdown").hasClass("hide")) { localStorage.setItem("md", "hide"); } else { localStorage.removeItem("md"); } var domain = localStorage.getItem("domain_" + acct_id); if (domain == "itabashi.0j0.jp") { $("#limited-button").removeClass("hide"); } else { $("#limited-button").addClass("hide"); } if (domain == "kirishima.cloud") { $("#faicon-btn").show(); } else { $("#faicon-btn").hide(); } if (domain == "imastodon.net") { trendTag(); } else { $("#trendtag").html(""); } if (localStorage.getItem("mode_" + domain) == "misskey") { M.toast({ html: lang.lang_bbmd_misskey, displayLength: 5000 }) } if (idata[domain + "_letters"]) { $("#textarea").attr("data-length", idata[domain + "_letters"]) } else { $("#textarea").attr("data-length", 500) } if (idata[domain + "_glitch"] === "true") { $("#local-button").removeClass("hide"); } else { $("#local-button").addClass("hide"); } var multi = localStorage.getItem("multi"); if (multi) { var obj = JSON.parse(multi); if (obj[acct_id].background && obj[acct_id].background != "def" && obj[acct_id].text && obj[acct_id].text != "def") { $("#toot-post-btn").removeClass("indigo"); $("#toot-post-btn").css("background-color", "#" + obj[acct_id].background); $("#toot-post-btn").css("color", obj[acct_id].text); } else { $("#toot-post-btn").css("background-color", ""); $("#toot-post-btn").css("color", ""); $("#toot-post-btn").addClass("indigo"); } } loadVis(); } //BOXのトグルボタン function mdToggle() { $(".markdown").toggleClass("hide"); $(".anti-markdown").toggleClass("hide"); if ($(".markdown").hasClass("hide")) { localStorage.setItem("md", "hide"); } else { localStorage.removeItem("md"); } } //最初に読み込みます(MD対応インスタンスかチェック) if (localStorage.getItem("md") == "hide") { $(".markdown").addClass("hide"); $(".anti-markdown").removeClass("hide"); } //タグを選んだ時に(BB版) function tagsel(tag) { var acct_id = $("#post-acct-sel").val(); if (!localStorage.getItem("bb_" + acct_id)) { return false; } if (tag == "large" || tag == "size" || tag == "color" || tag == "colorhex") { var sub = $("#" + tag).val(); var sub = sub.replace(/#/g, ""); surroundHTML(tag + "=" + sub, tag); } else if (tag == "flip=vertical" || tag == "flip=horizontal") { surroundHTML(tag, "flip"); } else { surroundHTML(tag, tag); } $("#textarea").focus(); } //HTMLをエスケープしてXSSを防ぐ function escape_html(string) { if (typeof string !== 'string') { return string; } return string.replace(/[&'`"<>]/g, function (match) { return { '&': '&', "'": ''', '`': '`', '"': '"', '<': '<', '>': '>', }[match] }); } //テキストボックスで選択したやつをタグで囲む(BB版) function surroundHTML(tagS, tagE) { var acct_id = $("#post-acct-sel").val(); if (!localStorage.getItem("bb_" + acct_id)) { return false; } var target = document.getElementById("textarea"); var pos = getAreaRange(target); var val = target.value; var range = val.slice(pos.start, pos.end); var beforeNode = val.slice(0, pos.start); var afterNode = val.slice(pos.end); var insertNode; if (range || pos.start != pos.end) { insertNode = '[' + tagS + ']' + range + '[/' + tagE + ']'; target.value = beforeNode + insertNode + afterNode; } else if (pos.start == pos.end) { insertNode = '[' + tagS + ']' + '[/' + tagE + ']'; target.value = beforeNode + insertNode + afterNode; } } function markdown(tag, ck, br, space) { if (space == "before") { tagE = tag; tag = " " + tag; } else { tagE = tag; } surroundMD(tag, tagE, ck, br); $("#textarea").focus(); } function surroundMD(tagS, tagE, ck, br) { var acct_id = $("#post-acct-sel").val(); if (!localStorage.getItem("md_" + acct_id)) { return false; } var target = document.getElementById("textarea"); var pos = getAreaRange(target); var val = target.value; var range = val.slice(pos.start, pos.end); var beforeNode = val.slice(0, pos.start); var afterNode = val.slice(pos.end); var insertNode; if (br == "yes") { var br = "\n"; } else { var br = ""; } if ((range || pos.start != pos.end) && ck == "yes") { insertNode = tagS + range + tagE; target.value = beforeNode + insertNode + br + afterNode; } else if (pos.start == pos.end || ck == "no") { insertNode = tagS + range; target.value = beforeNode + insertNode + br + afterNode; } } //テキストボックスの前後チェック function getAreaRange(obj) { var pos = new Object(); if (window.getSelection()) { pos.start = obj.selectionStart; pos.end = obj.selectionEnd; } return pos; } //Markdownのリンク挿入 function markdownLink() { var acct_id = $("#post-acct-sel").val(); if (!localStorage.getItem("md_" + acct_id)) { return false; } var linkIns = "[" + $("#linkt").val() + "]" + "(" + $("#link2").val() + ")"; if (linkIns != "[]()") { $("#textarea").val($("#textarea").val() + linkIns); $("#linkt").val(""); $("#link2").val(""); $("#textarea").focus(); } } //Markdownのimg挿入 function markdownImage() { var acct_id = $("#post-acct-sel").val(); if (!localStorage.getItem("md_" + acct_id)) { return false; } var imgIns = "![" + $("#image").val() + "]" + "(" + $("#image2").val() + ")"; if (imgIns != "![]()") { $("#textarea").val($("#textarea").val() + imgIns); $("#image").val(""); $("#image2").val(""); $("#textarea").focus(); } } //文字数をチェック(hタグ用) function str_count(all, part) { return (all.match(new RegExp(part, "g")) || []).length; } //プレビュー function preview() { $("#preview-field").show(); $("#toot-field").hide(); $("#preview-btn").hide(); var bb = escape_html($("#textarea").val()); //quote var bb = bb.replace(/>(.+)$/g, '<blockquote>$1<\/blockquote>'); //spin var bb = bb.replace(/\[spin\](.+)\[\/spin\]/g, '<span class="fa fa-spin">$1<\/span>'); //pulse var bb = bb.replace(/\[pulse\](.+)\[\/pulse\]/g, '<span class="bbcode-pulse-loading">$1<\/span>'); //large var bb = bb.replace(/\[large=([0-9]{1,2})x\](.+)\[\/large\]/g, '<span class="fa fa-$1x">$2<\/span>'); //vertical var bb = bb.replace(/\[flip=vertical\](.+)\[\/flip\]/g, '<span class="fa fa-flip-vertical">$1<\/span>'); //horizontal var bb = bb.replace(/\[flip=horizontal\](.+)\[\/flip\]/g, '<span class="fa fa-flip-horizontal">$1<\/span>'); //b var bb = bb.replace(/\[b\](.+)\[\/b\]/g, '<b>$1<\/b>'); //i var bb = bb.replace(/\[i\](.+)\[\/i\]/g, '<i>$1<\/i>'); //u var bb = bb.replace(/\[u\](.+)\[\/u\]/g, '<u>$1<\/u>'); //s var bb = bb.replace(/\[s\](.+)\[\/s\]/g, '<s>$1<\/s>'); //size var bb = bb.replace(/\[size=([0-9]{1,2})\](.+)\[\/size\]/g, '<span style="font-size:$1px">$2<\/span>'); //colorhex var bb = bb.replace(/\[colorhex=([A-Fa-f0-9]+)\](.+)\[\/colorhex\]/g, '<span style="color:#$1">$2<\/span>'); //code var bb = bb.replace(/`(.+)`/g, '<code>$1<\/code>'); //head var m; m = bb.match(/^#{1,6}(.+)$/gm); if (m) { for (let i = 0; i < m.length; i++) { var t = m[i].match(/^#{1,6}(.+)$/); var indexct = '<h' + str_count(m[i], "#") + '>' + t[1] + '</h' + str_count(m[i], "#") + '>'; var bb = bb.replace(new RegExp(m[i], ""), indexct); } } //list(ul) var li; li = bb.match(/^\- (.+)$/gm); if (li) { for (let l = 0; l < li.length; l++) { var u = li[l].match(/^\- (.+)$/); var listUl = '<li>' + u[1] + '</li>'; if (l == 0) { listUl = '<ul>' + listUl; } if (l == li.length - 1) { listUl = listUl + '</ul>'; } var bb = bb.replace(new RegExp(li[l], ""), listUl); } } //list(ol) var li; li = bb.match(/^1\. (.+)$/gm); if (li) { for (let l = 0; l < li.length; l++) { var u = li[l].match(/^1\. (.+)$/); var listUl = '<li>' + u[1] + '</li>'; if (l === 0) { listUl = '<ol>' + listUl; } if (l === li.length - 1) { listUl = listUl + '</ol>'; } var bb = bb.replace(new RegExp(li[l], ""), listUl); } } //img var bb = bb.replace(/!\[(.+)\]\((https:\/\/[-_.!~*\'()a-zA-Z0-9;\/?:\@&=+\$,%#]+)\)/g, '<img src="$2" text="$1" style="width:100%">'); //link var bb = bb.replace(/\[(.+)\]\((https?:\/\/[-_.!~*\'()a-zA-Z0-9;\/?:\@&=+\$,%#]+)\)/g, '<a href="$2" target="_blank">$1<\/a>'); bb = nl2br(bb); bb = bb.replace(new RegExp("</li><br />", "g"), ""); $("#md-preview").html(bb); } //Editで戻る function previewEdit() { $("#preview-field").hide(); $("#toot-field").show(); $("#preview-btn").show(); $("#md-preview").html(""); }