User:Arashiryuu0/global.js

/** * Global code - affects all wikias/fandoms I use. * @namespace Global.js */ var has = Object.prototype.hasOwnProperty; importArticles({       type: 'script',        articles: [            'u:dev:RelatedDiscussionsModule/code.js',            'u:bloodborne:MediaWiki:DOMTools.js',            'u:dev:CodeblockLineNumbers/code.js',            'u:dev:DifferentSkinEditor/code.js',            'u:dev:YoutubeModal/code.js',            'u:dev:PurgeButton/code.js',            'u:dev:View_Source/code.js',            'u:dev:UTCClock/code.js',            'u:dev:Message/code.js',            'u:dev:AjaxRC/code.js'        ]    }); function wait { if (!has.call(window, 'DOMTools')) return setTimeout(wait, 1000); run; }   function run { /**        * Purge Button */       window.PurgeButtonText = 'Purge'; /**        * Auto Refresh */       window.AjaxRCRefreshText = 'Auto-refresh'; window.AjaxRCRefreshHoverText = 'Automatically refresh the page'; window.ajaxPages = [ 'Special:RecentChanges', 'Special:WikiActivity', 'Special:AllPages', 'Special:UncategorizedPages' ];       /**         * Material Theme SyntaxHighlight Stuff */       (function {            function loop(e) {                var text = e.textContent,                    word = getWord(text),                    color = getColor(text);                if (word && color && !DOMTools.hasClass(e, word)) {                    DOMTools.addClass(e, word);                    DOMTools.css(e, 'color', color.color);                } else if (text.toLowerCase === 'hasownproperty') {                    DOMTools.addClass(e, 'ownProp');                    DOMTools.css(e, 'color', '#82AAFF');                }            }            function getWord(text) {                if (has.call(keywords, text)) return keywords[text];                return null;            }            function getColor(text) {                if (has.call(colors, text)) return colors[text];                return null;            }            var selectors = [                '.kw1', '.kw3', '.kw4', '.sy0' ],               keywords = { 'prototype': 'prote', 'typeof': 'typeof', 'this': 'this', 'new': 'new', 'in': 'in', '=>': 'aF', '$': 'jQ' },               colors = { 'prototype': { 'color':'#f78c6a' }, 'typeof': { 'color': '#89ddf3' }, 'this': { 'color':'#f95479' }, 'new': { 'color':'#89ddf3' }, 'in': { 'color': '#89ddf3' }, '=>': { 'color':'#c792ea' }, '$': { 'color':'#89ddf3' } };           var i = 0, j = 0, ren, len = selectors.length, elements; for (i; i < len; i++) { elements = DOMTools.queryAll('.javascript.source-javascript ' + selectors[i], document); if (!elements.length) continue; for (j = 0, ren = elements.length; j < ren; j++) loop(elements[j]); }       });        /**         * Remove featured videos         */        (function { var filter = Array.prototype.filter; function hasChild(target) { return has.call(target.attributes, 'itemprop'); }           var videos = document.querySelectorAll('div[itemprop="video"]'), children, len = videos.length, i;           if (!len) return; i = 0; for (i; i < len; i++) { children = filter.call(videos[i].parentElement.children, hasChild); if (children.length) children[i].parentElement.removeChild(children[i]); }       });        /**         * Colour uncoloured keywords         */        (function { var codeblocks = $$('pre.javascript.source-javascript, div.javascript.source-javascript .de1'), blocks = codeblocks.length, len, child, args, arr, j, i;           var keywords = { 'br0': [ '$$',                   '...',                    'typeof' ],               'kw4': [ 'Error', 'Promise', 'RangeError', 'TypeError', 'SyntaxError', 'ReferenceError', 'MutationObserver' ],               'kw1': ['with'], 'kw1 this': ['arguments'] };           var cssblocks = $$('pre.css.source-css, div.css.source-css .de1'), cssHexClass = 'st0', regex = /^#(\w{3,6}|\d{3,6}|((\w{1,2}|\d{1,2})(\w{1,2}|\d{1,2})(\w{1,2}|\d{1,2})))$/i, children, ren; function getKw(text) { var keyword, val, len, kws, i;               kws = Object.keys(keywords); for (i = 0, len = kws.length; i < len; i++) { keyword = kws[i]; val = keywords[keyword]; if (val.includes(text)) return keyword; }               return null; }           if (cssblocks.length) { i = 0; len = cssblocks.length; for (i; i < len; i++) { children = document.querySelectorAll('.re0'); if (!children.length) continue; j = 0; ren = children.length; for (j; j < ren; j++) { child = children[j] || 0; if (!child) continue; if (regex.test(child.textContent)) child.classList.replace('re0', cssHexClass); }               }            }            if (!blocks) return; arr = [ '$',               '...',                'with', 'typeof', 'arguments', 'Error', 'Promise', 'TypeError', 'RangeError', 'SyntaxError', 'ReferenceError', 'MutationObserver' ];           function isNotJQuery(node) { return node.data === '$' && node.previousSibling && node.previousSibling.textContent === '$'; }           function isJQuery(node) { return node.data === '$' && node.previousSibling && node.previousSibling.textContent !== '$'; }           if (wgTitle.includes('Arashiryuu0') && wgTitle.endsWith('.js')) { if (!codeblocks[0].textContent) return; i = 0; len = codeblocks[0].childNodes.length; if (!len) return; for (i; i < len; i++) { child = codeblocks[0].childNodes[i] || 0; if (!child || !child.data || !arr.includes(child.data.trim)) continue; if (isNotJQuery(child)) { args = createElement('span', {                           className: getKw('$$'),                            textContent: '$$'                        }); child.previousSibling.parentElement.removeChild(child.previousSibling); child.replaceWith(args); } else if (isJQuery(child)) continue; args = createElement('span', {                       className: getKw(child.data.trim),                        textContent: child.data                    }); child.replaceWith(args); }           } else { i = 0; j = 0; for (j; j < blocks; j++) { len = codeblocks[j].childNodes.length; if (!len) continue; for (i; i < len; i++) { child = codeblocks[j].childNodes[i] || 0; if (!child || !child.data || !arr.includes(child.data.trim)) continue; if (isNotJQuery(child)) { args = createElement('span', {                               className: getKw('$$'),                                textContent: '$$'                            }); child.previousSibling.parentElement.removeChild(child.previousSibling); child.replaceWith(args); } else if (isJQuery(child)) continue; args = createElement('span', {                           className: getKw(child.data.trim),                            textContent: child.data                        }); child.replaceWith(args); }               }            }        });        /**         * LineNumbers on Codeblocks         * Moved to: https://dev.wikia.com/wiki/CodeblockLineNumbers         */    }    wait; });
 * (function {

/** * Cookies */ function getCookies { if (!window.cookies) { Object.defineProperty(window, 'cookies', {           get: function {                return document.cookie.split(';').reduce(function(cookies, cookie) { cookies[cookie.split('=')[0].trim] = unescape(cookie.split('=')[1]); return cookies; }, {});           }        });        return window.cookies; }   return window.cookies; }

/** * Utility */ function createElement(type, properties) { var attributes, element, events, prop, name, len, val, ev, ty, pr, i;   type = type || ''; properties = properties || {}; ty = type.constructor.name; pr = properties.constructor.name; if (ty !== 'String' || pr !== 'Object') throw new TypeError('Expected: String, Object. Received: ' + ty + ', ' + pr); element = document.createElement(type); attributes = [ 'text', 'class' ];   events = { 'click': 'onclick', 'clicks': 'ondblclick', 'context': 'oncontextmenu', 'keyup': 'onkeyup', 'keydown': 'onkeydown', 'keypress': 'onkeypress', 'mouseup': 'onmouseup', 'mousedown': 'onmousedown', 'mousemove': 'onmousemove', 'mouseover': 'onmouseover', 'mouseout': 'onmouseout', 'mouseenter': 'onmouseenter', 'mouseleave': 'onmouseleave' };   for (prop in properties) { val = properties[prop]; if (!val) continue; name = val.constructor.name; if (attributes.includes(prop)) { if (prop === 'text') { element.textContent = val; continue; }           element.setAttribute(prop, val); } else if (events.hasOwnProperty(prop) && name === 'Function') { ev = events[prop]; element[ev] = val; } else if (prop === 'dataset' && name === 'Object') { for (i in val) element[prop][i] = val[i]; } else if (prop === 'childNodes' && name === 'Array') { i = 0; len = val.length; for (i; i < len; i++) { if (![1, 3].includes(val[i].nodeType)) continue; $a(element, val[i]); }       } else { element[prop] = val; }   }    element.props = properties; return element; }

function $$(selector) { return document.querySelectorAll(selector); }

function $a(target, element) { if (!target || !element) return; return target.appendChild(element); }

/*@end@*/