userstyles.org css highlighter

Formats and highlights CSS code shown after [Show CSS] clicking.

As of 2017-10-20. See the latest version.

  1. // ==UserScript==
  2. // @name userstyles.org css highlighter
  3. // @namespace trespassersW
  4. // @version 2017.10.20
  5. // @description Formats and highlights CSS code shown after [Show CSS] clicking.
  6. // @author trespassersW
  7. // @contributor darkred
  8. //
  9. // @license MIT License
  10. // @released 2013-11-20
  11. // @updated 2017-10-20
  12. //
  13. // 2017.10.19 Modified by darkred to work in the new userstyles.org layout.
  14. // 16.08.28 + keeps highliting status between sessions; 16.08.28.1 - some instead of each
  15. // 2.1.1 2016-01-04 + ctrl-clik copies CSS code to clipboard
  16. // 2.0.1 cut extra empty lines
  17. // 2.0 dark grey background;
  18. // 1.3 icons for toggle button; tiny optimization
  19. // 1.1 fresh versions of formater/hiliter; switching butifying on/off; fixed </& issue
  20. //
  21. // @include http://userstyles.org/styles/*
  22. // @include https://userstyles.org/styles/*
  23. // /include file:///E:/userscripts.org/styles/*
  24. // @include http://web.archive.org/web/20170222172435/https://userstyles.org/styles/118959/darksearch-for-google
  25. // @require https://greasyfork.org/scripts/21927-arrive-js/code/arrivejs.js?version=139586
  26. // @grant GM_setClipboard
  27. // ==/UserScript==
  28.  
  29. /* eslint-disable */
  30.  
  31. document.arrive('#button_middle > .css_button', function () {
  32.  
  33.  
  34.  
  35. (function () { "use strict";
  36.  
  37.  
  38. var Light = 0, Dark = 1 ;
  39. // choose color scheme according to your taste:
  40. var scheme = 1 ; // 0 for light; 1 for dark
  41.  
  42. //function _L(s){console.log(s);}
  43. var sb;
  44.  
  45. if( location.href.indexOf("s.org/styles/") <0 ||
  46. !(sb=document.querySelector("#button_middle > .css_button") )
  47. ) { return;} // else alert();
  48.  
  49.  
  50.  
  51.  
  52. var bt,tc,sc,vc, highlighted;
  53. var hiId="<!--userstyles.org css highlighter-->";
  54.  
  55. // CSSBeautify (C) 2013 Sencha Inc. Author: Ariya Hidayat.
  56. (function(){function a(s,f){var h,m=0,i=s.length,t,e="",p,g,q,k,o,y,u,d,r=true,j=false,n;h=arguments.length>1?f:{};if(typeof h.indent==="undefined"){h.indent=" ";}if(typeof h.openbrace==="string"){r=(h.openbrace==="end-of-line");}if(typeof h.autosemicolon==="boolean"){j=h.autosemicolon;}function l(z){return(z===" ")||(z==="\n")||(z==="\t")||(z==="\r")||(z==="\f");}function b(z){return(z==="'")||(z==='"');}function c(z){return(p>="a"&&p<="z")||(p>="A"&&p<="Z")||(p>="0"&&p<="9")||"-_*.:#[]".indexOf(z)>=0;}function x(){var z;for(z=y;z>0;z-=1){e+=h.indent;}}function w(){e=n(e);if(r){e+=" {";}else{e+="\n";x();e+="{";}if(g!=="\n"){e+="\n";}y+=1;}function v(){var z;y-=1;e=n(e);if(e.length>0&&j){z=e.charAt(e.length-1);if(z!==";"&&z!=="{"){e+=";";}}e+="\n";x();e+="}";t.push(e);e="";}if(String.prototype.trimRight){n=function(z){return z.trimRight();};}else{n=function(z){return z.replace(/\s+$/,"");};}o={Start:0,AtRule:1,Block:2,Selector:3,Ruleset:4,Property:5,Separator:6,Expression:7,URL:8};y=0;k=o.Start;d=false;t=[];s=s.replace(/\r\n/g,"\n");while(m<i){p=s.charAt(m);g=s.charAt(m+1);m+=1;if(b(u)){e+=p;if(p===u){u=null;}if(p==="\\"&&g===u){e+=g;m+=1;}continue;}if(b(p)){e+=p;u=p;continue;}if(d){e+=p;if(p==="*"&&g==="/"){d=false;e+=g;m+=1;}continue;}if(p==="/"&&g==="*"){d=true;e+=p;e+=g;m+=1;continue;}if(k===o.Start){if(t.length===0){if(l(p)&&e.length===0){continue;}}if(p<=" "||p.charCodeAt(0)>=128){k=o.Start;e+=p;continue;}if(c(p)||(p==="@")){q=n(e);if(q.length===0){if(t.length>0){e="\n\n";}}else{if(q.charAt(q.length-1)==="}"||q.charAt(q.length-1)===";"){e=q+"\n\n";}else{while(true){g=e.charAt(e.length-1);if(g!==" "&&g.charCodeAt(0)!==9){break;}e=e.substr(0,e.length-1);}}}e+=p;k=(p==="@")?o.AtRule:o.Selector;continue;}}if(k===o.AtRule){if(p===";"){e+=p;k=o.Start;continue;}if(p==="{"){q=n(e);w();k=(q==="@font-face")?o.Ruleset:o.Block;continue;}e+=p;continue;}if(k===o.Block){if(c(p)){q=n(e);if(q.length===0){if(t.length>0){e="\n\n";}}else{if(q.charAt(q.length-1)==="}"){e=q+"\n\n";}else{while(true){g=e.charAt(e.length-1);if(g!==" "&&g.charCodeAt(0)!==9){break;}e=e.substr(0,e.length-1);}}}x();e+=p;k=o.Selector;continue;}if(p==="}"){v();k=o.Start;continue;}e+=p;continue;}if(k===o.Selector){if(p==="{"){w();k=o.Ruleset;continue;}if(p==="}"){v();k=o.Start;continue;}e+=p;continue;}if(k===o.Ruleset){if(p==="}"){v();k=o.Start;if(y>0){k=o.Block;}continue;}if(p==="\n"){e=n(e);e+="\n";continue;}if(!l(p)){e=n(e);e+="\n";x();e+=p;k=o.Property;continue;}e+=p;continue;}if(k===o.Property){if(p===":"){e=n(e);e+=": ";k=o.Expression;if(l(g)){k=o.Separator;}continue;}if(p==="}"){v();k=o.Start;if(y>0){k=o.Block;}continue;}e+=p;continue;}if(k===o.Separator){if(!l(p)){e+=p;k=o.Expression;continue;}if(b(g)){k=o.Expression;}continue;}if(k===o.Expression){if(p==="}"){v();k=o.Start;if(y>0){k=o.Block;}continue;}if(p===";"){e=n(e);e+=";\n";k=o.Ruleset;continue;}e+=p;if(p==="("){if(e.charAt(e.length-2)==="l"&&e.charAt(e.length-3)==="r"&&e.charAt(e.length-4)==="u"){k=o.URL;continue;}}continue;}if(k===o.URL){if(p===")"&&e.charAt(e.length-1!=="\\")){e+=p;k=o.Expression;continue;}}e+=p;}e=t.join("")+e;return e;}if(typeof exports!=="undefined"){module.exports=exports=a;}else{if(typeof window==="object"){window.cssbeautify=a;}}}());
  57. // Prism (c) Lea Verou, MIT License
  58. (function(){var e=/\blang(?:uage)?-(?!\*)(\w+)\b/i,t=self.Prism={util:{type:function(e){return Object.prototype.toString.call(e).match(/\[object (\w+)\]/)[1]},clone:function(e){var n=t.util.type(e);switch(n){case"Object":var r={};for(var i in e){e.hasOwnProperty(i)&&(r[i]=t.util.clone(e[i]))}return r;case"Array":return e.slice()}return e}},languages:{extend:function(e,n){var r=t.util.clone(t.languages[e]);for(var i in n){r[i]=n[i]}return r},insertBefore:function(e,n,r,i){i=i||t.languages;var s=i[e],o={};for(var u in s){if(s.hasOwnProperty(u)){if(u==n){for(var a in r){r.hasOwnProperty(a)&&(o[a]=r[a])}}o[u]=s[u]}}return i[e]=o},DFS:function(e,n){for(var r in e){n.call(e,r,e[r]);t.util.type(e)==="Object"&&t.languages.DFS(e[r],n)}}},highlight:function(e,r){return n.stringify(t.tkize(e,r))},tkize:function(e,n){var r=t.tk,i=[e],s=n.rest;if(s){for(var o in s){n[o]=s[o]}delete n.rest}e:for(var o in n){if(!n.hasOwnProperty(o)||!n[o]){continue}var u=n[o],a=u.inside,f=!!u.lookbehind||0;u=u.pattern||u;for(var l=0;l<i.length;l++){var c=i[l];if(i.length>e.length){break e}if(c instanceof r){continue}u.lastIndex=0;var h=u.exec(c);if(h){f&&(f=h[1].length);var p=h.index-1+f,h=h[0].slice(f),d=h.length,v=p+d,m=c.slice(0,p+1),g=c.slice(v+1),y=[l,1];m&&y.push(m);var b=new r(o,a?t.tkize(h,a):h);y.push(b);g&&y.push(g);Array.prototype.splice.apply(i,y)}}}return i},hooks:{all:{},add:function(e,n){var r=t.hooks.all;r[e]=r[e]||[];r[e].push(n)},run:function(e,n){var r=t.hooks.all[e];if(!r||!r.length){return}for(var i=0,s;s=r[i++];){s(n)}}}},n=t.tk=function(e,t){this.type=e;this.content=t};n.stringify=function(e){if(typeof e=="string"){return e}if(Object.prototype.toString.call(e)=="[object Array]"){return e.map(n.stringify).join("")}var r={type:e.type,content:n.stringify(e.content),tag:"span",classes:["tk",e.type],attributes:{}};t.hooks.run("wrap",r);var i="";for(var s in r.attributes){i+=s+'="'+(r.attributes[s]||"")+'"'}return"<"+r.tag+' class="'+r.classes.join(" ")+'" '+i+">"+r.content+"</"+r.tag+">"}})();
  59.  
  60. Prism.languages.css = {
  61. com: /\/\*[\w\W]*?\*\//g, // whose guilt?
  62. atr: /@[\w-]+?(\s+[^;{]+)?(?=\s*{|\s*;)/gi,
  63. url: /url\((["']?).*?\1\)/gi,
  64. sel: /[^\{\}\s][^\{\}]*(?=\s*\{)/g,
  65. pro: /(\b|\B)[a-z-]+(?=\s*:)/ig,
  66. str: /("|')(\\?.)*?\1/g,
  67. imp: /!important\b/gi,
  68. pun: /[\{\};:]/g
  69. };
  70.  
  71. /*
  72. .com comment, .atr at-rule, .sel selector, .imp !important,
  73. .pun punctuation, .url url, .str string
  74. */
  75. var prismCSS;
  76. if( scheme==Dark ) {
  77. prismCSS = `
  78. .tk.com {
  79. color:#69A;
  80. }
  81. .tk.pun {
  82. color:#8FC;
  83. }
  84. .tk.pro {
  85. color:#5cf;
  86. }
  87. .tk.sel {
  88. color:#7F5;
  89. }
  90. .tk.str {
  91. color:#F63;
  92. }
  93. .tk.atr {
  94. color:#F8C;
  95. }
  96. .tk.imp {
  97. color:#e90;
  98. }
  99. .tk.url{
  100. color:#B87;
  101. }
  102. #css_text_area_div.hiBeautted {
  103. background-color:#293134 !important;
  104. color: #e0e2e4 !important;}
  105. `} else {
  106. prismCSS = `
  107. .tk.com {
  108. color:slategray;
  109. }
  110. .tk.pun {
  111. color:#488;
  112. }
  113. .tk.pro {
  114. color:#05A;
  115. }
  116. .tk.sel {
  117. color:#470;
  118. }
  119. .tk.str {
  120. color:#E30;
  121. }
  122. .tk.atr {
  123. color:#905;
  124. }
  125. .tk.imp {
  126. color:#e90;
  127. /*font-weight:bold;*/
  128. }
  129. .tk.url{
  130. color:#a75;
  131. }
  132. `
  133. }
  134.  
  135. prismCSS+=`
  136. #css_text_area_div {padding: 1.2em .8em !important;}
  137. #css_text_area_div.hiBeautted {white-space: pre-wrap !important; word-wrap: break-word!important;
  138. }
  139. #hiBeauty:before{
  140. content:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAACXBIWXMAAC4jAAAuIwF4pT92AAACjklEQVR42pXTz0/TYBgH8Nf/gaMJhoAXZzx7NhJviiZ6wmiWXRbRxBjjSYEQN8PPjbGxsWwgOjQYCVHWQoQM2IYDYbCta1e6tfvRTRMVjffnsW9HFkGzuMPnfd68ab79vk1KfD7fYrlcxv8lCAJWKhWUZVnfh8PhXwaD4TLxer2LqqoCRR88vv/zjFIUBXmeh0P6fmRkhCETExOsWiyAkt6jMC+k6gb962Xj4+MM8Xg8bCnowwNrh+6bpQOLyS1s5Loul4shbrebLc874EdPO4V0FncjDTVyOp0M0Wqx6pshOHh0nsLv2izurDceRGup2yH4/KJH042VQB+ostRQ0NjYWDVISb7H3LK5aqULC1kO0+5V5B0hnbS0W/cb6UF0KcSeQeXdOQrplOPLIN5dwOw9BjQouSN1GzkcjmqQEu3D0tvWGnlnCfnbcyga56vsa3UbjY6OMoSmybFhkAInKZRmTkGe24BE5ywmb7wGDWac63Ub6UF0kQoShDNrFEbFMJTUEixnshjkJdBgUslDWlAgFN2nMLol/R1kt9uZQHoazbvGmlUxhmciGTTEsrr7cRGHn+fwVndRd/NxDmWlVLuazWYLEvqf+FNe6Ny6TiGdH4QItK0ksC3EwekQh12bPDz15uDaQ4XCqw+ykJVLtUYDAwMsGRwcZNx7TrgSuUQhnUv8OjQHN7F5cRs0aI4m4IlTgvY7OQovmvePBFkslgXS39/PxpUdnOYmdQFuGvOlPHr2BLTFeV1oX8bIpwL65xTdq6CiBeghKEkSmkymIWK1WllRFIHjOEilUphMpuAQHptHzhOJJIUbGx9/NjU1nSVGo2nW73/5dWpqpiGTk4Evvb3WtZaW1guEkBO/ARQgDsZ2Sv7VAAAAAElFTkSuQmCC);
  141. opacity:.75; display: block; position: absolute;
  142. top: 0px; left: 33%; z-index: 1;
  143. }
  144. #hiBeauty.hiBeautted:before{
  145. content:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAACXBIWXMAAC4jAAAuIwF4pT92AAACf0lEQVR42qWSW09aURCF9x9srJd6ARGqtf0nVUHkJreDtCrIRX/AjlFjQjUxISpXNdZ7DeC7rX1a0xm6TU6IjQ99+DIz+8xayVl7q06nox8eHoiBqb29fX5xRzxUu93WDJqNBj5NTeLjew8+TLgwOe6ExzEG9+gIXMNDcA4NwDHwFo16DbLfg1atVkszxMgBGey9fYbZ7e7beq3u7+81QxcXF9goFmmjWKD1Qh7r+TwVczkq5NaosJZFPpulfDaDXGaVcqsrtLayzH9RJ9GKh7q7u9MMzs7OsJxO4+vSEr6kUoyFtJXEUjKBVCKOVDwGKxZFMrrIRJBYjOD46AiiFQ91c3Ojb29viYGpvb19fnFHPNTV1ZW+vr7G4eEhpj3ubsgTHLBzaBDTbhfk22uIh+Js9OXlJTEwtbe3zy/uiIc6Pz/XDNVqNcmIOCOSjNKWRZwRcUYkGVnxGCX/ZkSNep1YA9EZtOKQNUOV42MYEzawOOQkG7BJPE5sAjahBAfNIVO1WiG5HNEZtGo2m/rk5AT/g3ioer2uGfpWKmHKPUGTrnHyOB1wj42Sa2SYnO8GyTHYj9H+PhrpeyOvXGIg1kB0Bq0qlYpmiEG1WiWDvbfP3fq8b6qgFV+7PuKHtb+/j0gwiHAwgFBgAaEFP4L+eQTmfQj4vFjweuH3zsE/N4v52Rn4Zj5jZ3sLohUPVS6XNUN7e3tImYAtvqVk95ZilOiGHAUHTXF+zbFImGLhEEXDIezsbJNoxUMdHBxohhiY2tvb53/taLW5uekrlUqPzE/mF/PE/H6FJ7MrmkfxUNlsdpcpZzKZU67fmR/ct7i2mY7A83OVs5bZkd1To939A6wgCBc2cNwFAAAAAElFTkSuQmCC);
  146. }
  147. #css_text_area_div {position: relative !important; }
  148. #hiBeauty {
  149. padding: 0;
  150. margin: 0;
  151. width: auto;
  152. cursor: pointer;
  153. border: none
  154. }
  155. `;
  156. function hiStat(x){
  157. vc.className=bt.className= x;
  158. bt.setAttribute('title',x? 'raw text': 'highlight');
  159. if(locStor) locStor.setItem('HiliteUsoCod', !!x);
  160. }
  161. function isBeauty(){
  162. sc=document.getElementById("stylish-code");
  163. if(!sc || !(sc.textContent)) return -1;
  164. if(sc.innerHTML.substr(0,hiId.length)===hiId){
  165. if(bt.className){
  166. sc.innerHTML='';
  167. sc.textContent=tc;
  168. hiStat('');
  169. }
  170. else hiStat('hiBeautted');
  171. return 1;
  172. }
  173. hiStat('');
  174. return 0;
  175. }
  176.  
  177. function hiBeauty(e){
  178. sc=document.getElementById("stylish-code");
  179. if(e){
  180. e.preventDefault(),e.stopPropagation();
  181. if(e.shiftKey || e.altKey) return;
  182. if(e.ctrlKey) { // 2016-01-04
  183. GM_setClipboard(sc.textContent);
  184. window.status = 'CSS copied to clipboard';
  185. return;
  186. }}
  187. if(isBeauty()!=0) return;
  188. if(!( highlighted && tc && tc === sc.textContent )){
  189. tc = sc.textContent;
  190. // console.log(tc);
  191. highlighted = cssbeautify(tc, {
  192. // autosemicolon: true ,
  193. // openbrace: "newline",
  194. indent: "\u0020\u0020" // 14-02-26 o_0
  195. // indent: " " // 14-02-26 o_0
  196. // indent: "\u00a0\u00a0"
  197. } );
  198. // console.log(highlighted);
  199.  
  200. highlighted=highlighted.replace(/\n(\s*)@\s+/g,'\n$1@'); // 2014-03-12 dirty patch
  201. highlighted=highlighted.replace(/,\n\n+/g,',\n'); // 2014-03-12 4freecyber
  202. highlighted=highlighted.replace(/\n\n+/g,'\n\n'); // 2014-02-25
  203. highlighted=highlighted.replace(/&/g,'&amp;').replace(/</g,'&lt;')
  204. highlighted = hiId +
  205. Prism.highlight(highlighted, Prism.languages.css) /* */;
  206. }
  207. // console.log(highlighted);
  208. sc.innerHTML = highlighted ;
  209. hiStat('hiBeautted');
  210. }
  211. /* * /
  212. function insAfter(n,e){
  213. if(e.nextElementSibling)
  214. return e.parentNode.insertBefore(n,e.nextElementSibling);
  215. return e.parentNode.appendChild(n);
  216. } /* */
  217. function insBefore(n,e){
  218. return e.parentNode.insertBefore(n,e);
  219. }
  220. function cE(t, aA, eL, ht) {
  221. var n = document.createElement(t);
  222. for (var at in aA)
  223. if(aA.hasOwnProperty(at)) n.setAttribute(at, aA[at]);
  224. if(eL) n.addEventListener(eL[0], eL[1], eL[2]?true:false);
  225. if(ht) n.innerHTML = ht;
  226. return n;
  227. }
  228. function sbclik(){
  229.  
  230. if (document.querySelector('#stylish-code').outerHTML.indexOf('<textarea') !== -1 ) {
  231. document.querySelector('#stylish-code').outerHTML = document.querySelector('#stylish-code').outerHTML.replace('<textarea','<code');
  232. document.querySelector('#stylish-code').style.whiteSpace = 'pre-wrap';
  233. document.querySelector('#stylish-code').style.display = 'block';
  234. document.querySelector('#stylish-code').style.width = '700px';
  235. }
  236.  
  237. if(!bt){
  238. vc = document.getElementById("stylish-code");
  239. if(!vc) return;
  240. var pz = cE('style');
  241. pz.textContent = prismCSS;
  242. document.head.appendChild(pz);
  243. bt=cE('div',{id: 'hiBeauty',title: 'Highlight'},['click', hiBeauty ],'');
  244. insBefore( bt, vc);
  245. }
  246. bt.className='';
  247. //if(HiliteOn) alert('HiOn'),HiliteOn=0;
  248. }
  249.  
  250. sb.addEventListener('mousedown', sbclik, false);
  251.  
  252. var locStor,HiliteUsoCod=false;
  253. try { // localStorage throws 'security error' when cookies are disabled
  254. locStor = localStorage;
  255. HiliteUsoCod = locStor.getItem("HiliteUsoCod")==='true';
  256. // see SQlite manager -> %FFpath%\webappstore.sqlite -> find -> key -> contains HiliteUso
  257. } catch(e){ locStor = false; };
  258.  
  259.  
  260.  
  261. document.arrive('#stylish-code', function () {
  262. var toggle = document.querySelector('#hiBeauty');
  263. if (toggle.title === 'Highlight' && localStorage.getItem('HiliteUsoCod') == 'true'){
  264. toggle.click();
  265. }
  266. });
  267.  
  268.  
  269.  
  270. })();
  271.  
  272.  
  273.  
  274. });
  275.