// ==UserScript== // @name Tieba Coder // @namespace http://nota.moe/ // @version 0.2 // @description 在贴吧发表格式美观、语法高亮的代码片段 // @author NotaStudio // @match http://tieba.baidu.com/p/* // @match http://tieba.baidu.com/f?kw=* // @grant GM_addStyle // @grant GM_xmlhttpRequest // @run-at document-end // @license GPLv3 // @downloadURL https://update.greasyfork.icu/scripts/11542/Tieba%20Coder.user.js // @updateURL https://update.greasyfork.icu/scripts/11542/Tieba%20Coder.meta.js // ==/UserScript== /* ChangeLog * 20150807 0.1-alpha * 初次发布 * 20150811 0.2 * 加入语言显示支持,加入 Java 语法高亮支持,加入发布到 Ubuntu Pastebin 支持,修复 !!indexOf 返回 true 的问题,修复出现多个按钮的问题,修复头像显示不正确的问题,修复 innerHTML 相关的性能问题,修复替换 innerHTML 造成的事件监听丢失问题,其它小 bug 修复,CSS 微调,精简代码 */ console.log(" Tieba Coder 0.2\n Created by Nota\n 2015.08.11\n┏┛┻━━━┛┻┓\n┃|||||||┃\n┃ ━ ┃\n┃ ┳┛ ┗┳ ┃\n┃ ┃\n┃ ┻ ┃\n┃ ┃\n┗━┓ ┏━┛\n ┃ ┃\n ┃ ┃\n ┃ ┃\n ┃ ┃\n ┃ ┗━━━┓\n ┃ Tieba Coder ┣┓\n ┃ 吉翔物 ┃\n ┗┓┓┏━┳┓┏┛\n ┃┫┫ ┃┫┫\n ┗┻┛ ┗┻┛\n "); GM_addStyle("code{display:inline}.tc_input_code_button{display:inline;cursor:pointer;color:#990000}.tc_container{border-radius:5px;position:fixed;width:480px;height:320px;z-index:9999998;margin:0 auto;left:0;right:0;top:100px;bottom:0;background:rgba(169,169,169,0.8);text-align:center}.tc_lang_select,.tc_tab_select{margin:5px}.tc_tip{display:inline}.tc_input_box{overflow:auto;display:block;margin:2px;width:474px}.tc_code_div{border-radius:7px;border-color:#666;border-width:1px;background-color:#f5f2f0}.tc_p{display:none}.tc_code_pre{font-family:Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace}.tc_submit_button,.tc_cancel_button{margin:3px}.tc_loading{width:45px;height:45px;border-radius:7px;position:fixed;z-index:9999999;margin:0 auto;background:rgba(169,169,169,0.8);background-image:url('');background-size:cover;left:50%;top:50%}"); GM_addStyle("code[class*='language-'],pre[class*='language-']{color:black;text-shadow:0 1px white;font-family:Consolas,Monaco,'Andale Mono','Ubuntu Mono',monospace;direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*='language-']::-moz-selection,pre[class*='language-']::-moz-selection,code[class*='language-']::-moz-selection,code[class*='language-']::-moz-selection{text-shadow:none;background:#b3d4fc}pre[class*='language-']::selection,pre[class*='language-']::selection,code[class*='language-']::selection,code[class*='language-']::selection{text-shadow:none;background:#b3d4fc}@media print{code[class*='language-'],pre[class*='language-']{text-shadow:none}}pre[class*='language-']{padding:1em;margin:.5em 0;overflow:auto}:not(pre) > code[class*='language-'],pre[class*='language-']{background:#f5f2f0}:not(pre) > code[class*='language-']{padding:.1em;border-radius:.3em}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:slategray}.token.punctuation{color:#999}.namespace{opacity:.7}.token.property,.token.tag,.token.boolean,.token.number,.token.constant,.token.symbol,.token.deleted{color:#905}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:#690}.token.operator,.token.entity,.token.url,.language-css .token.string,.style .token.string{color:#a67f59;background:hsla(0,0%,100%,.5)}.token.atrule,.token.attr-value,.token.keyword{color:#07a}.token.function{color:#DD4A68}.token.regex,.token.important,.token.variable{color:#e90}.token.important,.token.bold{font-weight:bold}.token.italic{font-style:italic}.token.entity{cursor:help}pre[class*='language-']{position:relative}pre[class*='language-'][data-language]::before{content:attr(data-language);color:black;background-color:#CFCFCF;display:inline-block;position:absolute;top:0;right:0;font-size:0.9em;border-radius:0 0 0 5px;padding:0 0.5em;text-shadow:none}");// Prism.js stylesheet window.addNode = function (sTagName,oAttr,sTagContent,oParentNode) { var e = document.createElement(sTagName); if (sTagContent) { var c = document.createTextNode(sTagContent); e.appendChild(c); } if (oAttr) { for (var a in oAttr) { e.setAttribute(a,oAttr[a]); } } if (oParentNode) { oParentNode.appendChild(e); return; } else { return e; } }; // oAttr 可选,接受用对象形式表示的属性-值对,sTagContent 可选,oParentNode 可选,若有,则把新建的元素添加为 oParentNode 的子节点并返回 undefined ;若无,则直接返回新建的元素 // e.g. addNode("div",{"width":"100px","height":"50px","dir":"rtl"},"bbb",document.getElementById("content_wrap")); // 发帖 GM_addStyle("@keyframes nodeInserted{from{opacity:.99}to{opacity:1}}.edui-btn-toolbar{animation-duration:.01s;animation-name:nodeInserted}"); //为 edui-btn-toolbar 类增加动画,方便通过 animationstart 事件获取相应节点 window.tcPostInit = function() { addNode("button",{"class":"tc_input_code_button"},"插入代码",document.getElementsByClassName("edui-btn-toolbar")[0]); document.getElementsByClassName("tc_input_code_button")[0].addEventListener("click",inputCode,false); document.removeEventListener("animationstart", insertListener, false); }; var insertListener = function(event){ if (event.animationName == "nodeInserted") {// This is the debug for knowing our listener worked! event.target is the new node! tcPostInit(); } }; document.addEventListener("animationstart", insertListener, false); window.inputCode = function() { addNode("div",{"class":"tc_container"},"",document.body); document.getElementsByClassName("tc_container")[0].innerHTML = "
语言
Tab Width
同时发表到 Ubuntu Pastebin
// ==Tieba Coder lang:" + postLang + "==
" + code + "
// 这段代码使用 Tieba Coder 进行格式化和语法高亮,您可以在 https://greasyfork.org/zh-CN/scripts/11542-tieba-coder 下载 Tieba Coder 使用
// 注意:这段代码中的空格可能是全角空格
");
if(x.indexOf("// 这段代码使用 Tieba Coder")>=0)x=x.replace(/\/\/ 这段代码使用 Tieba Coder.*您可以在/g,"");
if(x.indexOf(" 下载 Tieba Coder 使用")>=0)x=x.replace(/ 下载 Tieba Coder 使用/g,"");
if(x.indexOf("// 注意:这段代码中的空格")>=0)x=x.replace(/\/\/ 注意:这段代码.*全角空格/g,"");
list.push([k,x]);
}
list.forEach(function(item,index,array){
var node = document.createElement("a");
item[0].parentElement.replaceChild(node,item[0]);
node.outerHTML = item[1];
});
list = [];
}
// 参考了 CC Code 的 replace_nodes() 函数 (https://greasyfork.org/zh-CN/scripts/281-cc-code/)
var gfoLinks = $("a[href*='jump.bdimg.com']");
for (var n = 0; n < gfoLinks.length; n++) {
if (gfoLinks[n].innerText == "https://greasyfork.org/zh-CN/scripts/11542-tieba-coder") {
node = document.createElement("a");
gfoLinks[n].parentElement.replaceChild(node,gfoLinks[n]);
node.outerHTML = "";
}
}
gfoLinks = $("a[href='https://greasyfork.org/zh-CN/scripts/11542-tieba-coder']");
for (var n = 0; n < gfoLinks.length; n++) {
if (gfoLinks[n].innerText == "https://greasyfork.org/zh-CN/scripts/11542-tieba-coder") {
node = document.createElement("a");
gfoLinks[n].parentElement.replaceChild(node,gfoLinks[n]);
node.outerHTML = "";
}
}
var codeTags = $("pre[class*='language-']>code");
for (var v = 0; v < codeTags.length; v++) {
codeTags[v].innerText = codeList[v];
}
}
// Prism.js START
// MIT license http://www.opensource.org/licenses/mit-license.php/
/* http://prismjs.com/download.html?themes=prism&languages=markup+css+clike+javascript+bash+c+cpp+java+php+python&plugins=show-language */
var _self="undefined"!=typeof window?window:"undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope?self:{},Prism=function(){var e=/\blang(?:uage)?-(?!\*)(\w+)\b/i,t=_self.Prism={util:{encode:function(e){return e instanceof n?new n(e.type,t.util.encode(e.content),e.alias):"Array"===t.util.type(e)?e.map(t.util.encode):e.replace(/&/g,"&").replace(/e.length)break e;if(!(d instanceof a)){u.lastIndex=0;var m=u.exec(d);if(m){c&&(f=m[1].length);var y=m.index-1+f,m=m[0].slice(f),v=m.length,k=y+v,b=d.slice(0,y+1),w=d.slice(k+1),N=[p,1];b&&N.push(b);var O=new a(l,g?t.tokenize(m,g):m,h);N.push(O),w&&N.push(w),Array.prototype.splice.apply(r,N)}}}}}return r},hooks:{all:{},add:function(e,n){var a=t.hooks.all;a[e]=a[e]||[],a[e].push(n)},run:function(e,n){var a=t.hooks.all[e];if(a&&a.length)for(var r,i=0;r=a[i++];)r(n)}}},n=t.Token=function(e,t,n){this.type=e,this.content=t,this.alias=n};if(n.stringify=function(e,a,r){if("string"==typeof e)return e;if("Array"===t.util.type(e))return e.map(function(t){return n.stringify(t,a,e)}).join("");var i={type:e.type,content:n.stringify(e.content,a,r),tag:"span",classes:["token",e.type],attributes:{},language:a,parent:r};if("comment"==i.type&&(i.attributes.spellcheck="true"),e.alias){var l="Array"===t.util.type(e.alias)?e.alias:[e.alias];Array.prototype.push.apply(i.classes,l)}t.hooks.run("wrap",i);var s="";for(var o in i.attributes)s+=o+'="'+(i.attributes[o]||"")+'"';return"<"+i.tag+' class="'+i.classes.join(" ")+'" '+s+">"+i.content+""+i.tag+">"},!_self.document)return _self.addEventListener?(_self.addEventListener("message",function(e){var n=JSON.parse(e.data),a=n.language,r=n.code;_self.postMessage(JSON.stringify(t.util.encode(t.tokenize(r,t.languages[a])))),_self.close()},!1),_self.Prism):_self.Prism;var a=document.getElementsByTagName("script");return a=a[a.length-1],a&&(t.filename=a.src,document.addEventListener&&!a.hasAttribute("data-manual")&&document.addEventListener("DOMContentLoaded",t.highlightAll)),_self.Prism}();"undefined"!=typeof module&&module.exports&&(module.exports=Prism);;
Prism.languages.markup={comment://,prolog:/<\?[\w\W]+?\?>/,doctype://,cdata://i,tag:{pattern:/<\/?[^\s>\/]+(?:\s+[^\s>\/=]+(?:=(?:("|')(?:\\\1|\\?(?!\1)[\w\W])*\1|[^\s'">=]+))?)*\s*\/?>/i,inside:{tag:{pattern:/^<\/?[^\s>\/]+/i,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"attr-value":{pattern:/=(?:('|")[\w\W]*?(\1)|[^\s>]+)/i,inside:{punctuation:/[=>"']/}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\s>\/:]+:/}}}},entity:/?[\da-z]{1,8};/i},Prism.hooks.add("wrap",function(t){"entity"===t.type&&(t.attributes.title=t.content.replace(/&/,"&"))});;
Prism.languages.css={comment:/\/\*[\w\W]*?\*\//,atrule:{pattern:/@[\w-]+?.*?(;|(?=\s*\{))/i,inside:{rule:/@[\w-]+/}},url:/url\((?:(["'])(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1|.*?)\)/i,selector:/[^\{\}\s][^\{\};]*?(?=\s*\{)/,string:/("|')(\\(?:\r\n|[\w\W])|(?!\1)[^\\\r\n])*\1/,property:/(\b|\B)[\w-]+(?=\s*:)/i,important:/\B!important\b/i,"function":/[-a-z0-9]+(?=\()/i,punctuation:/[(){};:]/},Prism.languages.css.atrule.inside.rest=Prism.util.clone(Prism.languages.css),Prism.languages.markup&&(Prism.languages.insertBefore("markup","tag",{style:{pattern:/