NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name hacer // @namespace https://github.com/doomred // @description Provide a better HTML architecture for add functions and CSS design. This script is by hacers for hacers. // @version 0.0.10 // @encoding utf-8 // @license ISC // @copyright hacer contributors // @author dye `Eric' jarhoo // @homepageURL http://saltyremix.com // @icon https://raw.github.com/doomred/hacer/master/hacer_icon.png // @updateURL https://raw.github.com/doomred/hacer/master/hacer.meta.js // @include http://h.acfun.tv/* // @exclude http://h.acfun.tv/homepage/ref* // @run-at document-end // @grant GM_openInTab // @grant GM_getResourceText // @grant GM_registerMenuCommand // @grant GM_getValue // @grant GM_setValue // @require https://raw.github.com/doomred/hacer/devvel/gm_config/easycfg.js // @resource mburl https://raw.github.com/doomred/hacer/master/hacer.meta.js // ==/UserScript== /*********** * Many thanks for the followings, without you the mates, * `hacer' would not make hacers this kinds of happy!! * zjworks, * \*********************************************************/ /* init global foobar varible */ var i = 0, k = 0; /* init variable Handler */ var hacerVersion = '0.0.10'; var currentStyle = GM_getValue('gm_currentstyle', 'day'); var hboxCSS, nightCSS, frameNightCSS, frameDayCSS; frameNightCSS = ' html body tbody tr td font[color="#cc1105"],font[color="#117743"] {display: none;}html body tbody tr td font[color="#789922"] {color: red;}.posttime {display: none;}.report {display: none;}.threadpost {margin: 0;}img {width: 30%;height: 30%;}table {padding: 0;width: 18em;}body{margin: 0;background-color: black;color:rgb(198,198,198) !important;}td{z-index: -50;background:rgba(50,50,60,0.7) !important;padding:9px !important;transition:background .1s ease-in-out;}td:hover {background:rgb(50,50,60) !important;}td:active {background:rgb(50,50,100) !important;}a{transition:color .1s ease-in-out;}a:link{color:rgb(100,100,224) !important}a:visited{color:rgb(100,100,190) !important}a:hover{color:lightblue !important}img{z-index: 50;opacity:0.3;transition:all .3s ease-in-out;}img:hover{opacity:0.9;}'; frameDayCSS = ' html body tbody tr td font[color="#cc1105"],font[color="#117743"] {display: none;}html body tbody tr td font[color="#789922"] {color: red;}.posttime {display: none;}.report {display: none;}.threadpost {margin: 0;}img {width: 30%;height: 30%;}table {padding: 0;width: 18em;}'; nightCSS = ' body{background-color:black;background-image:url("http://avdot.net/cover.php");background-position: center;background-repeat: no-repeat;background-attachment: fixed;background-repeat: no-repeat;color:rgb(198,198,198) !important;transition:background .5s ease-in-out;}#right_content{// background:black !important;background-image: linear-gradient(rgba(0,0,0,0.8),rgba(0,0,0,0.5), rgba(0,0,0,0.9)) !important;background-attachment: fixed;transition:background .5s ease-in-out;}td{z-index: -50;background:rgba(50,50,60,0.7) !important;border: solid 0;border-radius: 1em;padding:9px !important;transition:background .1s ease-in-out;}td:hover, .originpost {background:rgb(50,50,60) !important;// padding: 6em !important;}td:active {background:rgb(50,50,100) !important;}a{transition:color .1s ease-in-out;}a:link{color:rgb(100,100,224) !important}a:visited{color:rgb(100,100,190) !important}a:hover{color:lightblue !important}#right_content img{z-index: 50;opacity:0.3;transition:all .3s ease-in-out;}#right_content img:hover{opacity:0.9;}#menu{background:rgb(12,12,30) !important;}.toolbar-bottom {color:#ffffff !important;background-image: url("");transition:background .1s ease-in-out;}#postform_tbl input, #emotion, textarea {background-color:black !important;color:rgb(150,150,150) !important;}font[color="#707070"]{color:rgb(100,100,100);}'; hboxCSS = ' #thebox {display: table-cell;vertical-align: middle;background-position: center;background-repeat: no-repeat;filter: Alpha(Opacity=100);visibility: hidden;z-index: 120;margin-left: auto;margin-right: auto;}#box-bg {position: fixed;display: table;z-index: 110;top: 0;left: 0;text-align: center;width: 100% !important;height: 100% !important;background-color: rgba(0, 0, 0, 0.8);visibility: hidden;transition: all 0.5s ease-in-out;}'; /* overwrite bad CSS plus must have CSS, custom style goto altCSS */ var htmlHead, htmlBody, owCSS; htmlHead = window.document.getElementsByTagName('head')[0]; htmlBody = window.document.getElementsByTagName('body')[0]; owCSS = window.document.createElement('style'); owCSS.type = 'text/css'; owCSS.id = 'overwritecss'; owCSS.innerHTML += '#postform_tbl p {line-height: 1.5em; padding-bottom: 2em;}'; owCSS.innerHTML += 'body {margin: -2em; min-width: 50em; overflow-x: hidden;}'; owCSS.innerHTML += '#right_content {margin: 0 50px;}'; owCSS.innerHTML += '.nav-bottom {position: fixed; bottom: 1em; right: 0; z-index: 100; font-size: 12pt !important;}'; owCSS.innerHTML += '.originpost {padding-bottom:6em !important; }'; owCSS.innerHTML += '#hacerfeedback, #dangerarea, #dangerswitcher, #cssswitcher, #writepadswitcher, #settingswitcher {text-decoration: underline; margin: 0 0.5em;}'; owCSS.innerHTML += '#hacerfeedback:hover, #dangerarea:hover, #dangerswitcher:hover, #cssswitcher:hover, #writepadswitcher:hover, #settingswitcher:hover {color: #810400; cursor: pointer; text-decoration: underline; margin: 0 0.5em;}'; owCSS.innerHTML += '#alertbox {opacity: 0.9; border-color: white; border-width: 5px; border-style: solid; font-size: 18pt; position: fixed; top: 80%; left: 0.5em; transition: all 0.66s ease-in-out; background: black; z-index: 200;}'; owCSS.innerHTML += '#alertbox {opacity: 0.9; border-color: white; border-width: 5px; border-style: solid; font-size: 18pt; position: fixed; top: 80%; left: 0.5em; transition: all 0.66s ease-in-out; background: black; z-index: 200;}'; htmlHead.appendChild(owCSS); /* init global alertNotice function */ var alertDiv; alertDiv = document.createElement('div'); alertDiv.id = 'alertbox'; alertDiv.style.display = 'none'; htmlBody.appendChild(alertDiv); function alertoff() { alertDiv.style.display = 'none'; } function alertNotice(alertContent, delay) { var alertDiv = document.getElementById('alertbox'); alertDiv.innerHTML = alertContent; alertDiv.style.display = 'inline'; window.setTimeout(alertoff, delay); } function giveup(x) { return x; } function forceupdate() { GM_openInTab('https://raw.github.com/doomred/hacer/master/beauty.user.js'); giveup(0); } function checkupdate() { var updateMB = GM_getResourceText('mburl'); if (updateMB.search(hacerVersion) === -1) { alertNotice('New version Found, please wait awhile to install.', 3000); GM_openInTab('https://raw.github.com/doomred/hacer/master/beauty.user.js'); giveup(0); } else { alertNotice('`hacer\' is up-to-date', 1500); } } GM_registerMenuCommand('hacer | check update', checkupdate, 'h'); GM_registerMenuCommand('hacer | force update', forceupdate, 'f'); function makegrabbable(targetDiv) { // make position=fixed div grabbable targetDiv.addEventListener('mousedown', function (e) { if (!e && window.event) { e = window.event; } var pleft, ptop, xcoor, ycoor; pleft = parseInt(targetDiv.style.left, 10); ptop = parseInt(targetDiv.style.top, 10); xcoor = e.clientX; ycoor = e.clientY; window.document.onmousemove = function (e) { targetDiv.style.left = pleft + e.clientX - xcoor + 'px'; targetDiv.style.top = ptop + e.clientY - ycoor + 'px'; }; window.document.onmouseup = function () { document.onmousemove = null; }; }, false); } /* add CSS class toolbar-bottom */ var classToolbar = document.body.getElementsByTagName('div'); for (i = 0; i < classToolbar.length; i++) { if (classToolbar[i].style.width === '100%') { classToolbar[i].classList.add('toolbar-bottom'); } } /* init GM_config container */ var classToolbar = document.getElementsByClassName('toolbar-bottom')[0]; var gmconfigDiv = document.createElement('div'); /* plan to contain setting panel */ gmconfigDiv.id = 'gm-config'; gmconfigDiv.style.transition = 'height 5s ease-in-out'; classToolbar.appendChild(gmconfigDiv); function feedreportback() { var strWindowFeatures = 'left=50, top=50 location, resizable, scrollbars, status'; if (window.confirm('YES for github, NO for acfun')) { window.open('https://github.com/doomred/hacer/issues', 'FEED_ME_BUGS', strWindowFeatures); } else { window.open('http://h.acfun.tv/t/4288535', 'Report & Suggestion', strWindowFeatures); } } /* add feedback element */ var fbAnchor = document.createElement('span'); fbAnchor.id = 'hacerfeedback'; fbAnchor.addEventListener('click', feedreportback, false); fbAnchor.style.textAlign = 'right'; fbAnchor.innerHTML = 'feedback'; GM_config.init({ 'id': 'GM_config', 'title': 'hacer setting', 'fields': { 'twoupOn': { 'label': 'Use 2-up style: ', 'type': 'checkbox', 'default': true }, 'menuHide': { 'label': 'If menu auto hide: ', 'type': 'checkbox', 'default': true }, 'hboxOn': { 'label': 'If enable hbox: ', 'type': 'checkbox', 'default': true }, 'wpOn': { 'label': 'If enable writepad: ', 'type': 'checkbox', 'default': false }, 'adminOn': { 'label': 'If enable adminTool: ', 'type': 'checkbox', 'default': false }, 'altCSS': { 'label': 'The alternative CSS', 'type': 'textarea', 'default': '' }, 'twOn': { 'label': 'If enable Chinese time format: ', 'type': 'checkbox', 'default': true }, 'navFix': { 'label': 'If fix page-navigation position', 'type': 'checkbox', 'default': true }, 'bqOn': { 'label': 'If enable betterquote', 'type': 'checkbox', 'default': true }, 'quoteSize': { 'label': 'Quotes recursive time(enable betterquote first): ', 'type': 'int', 'min': 1, 'max': 999, 'default': '4' } }, 'events': { 'init': function () { dynamicparts(); }, 'open': function () { window.setTimeout(function() { document.getElementById('GM_config').style.height = '400px'; }, 100); //100 MAGIC }, 'save': function () { alertNotice('Reload to active!', 1000); }, 'close': function () { } }, 'css': '#GM_config {position: static !important; width: 99% !important; margin: 1.5em auto !important;' + 'background: rgba(0,0,0,0); border: 0 !important; transition: height 1s ease-in-out !important;}', 'frame': gmconfigDiv }); function dynamicparts() { /* init foobar varibles */ var i = 0, k = 0, tmp = null; /* Initilize for switchers */ function nullHandler() { // useless for now return false; } var currentCSS; currentCSS = document.createElement('style'); currentCSS.type = 'text/css'; currentCSS.id = 'currentcss'; if(currentStyle === 'day') { currentCSS.innerHTML = GM_config.get('altCSS'); parseframescss(frameDayCSS); } else { currentCSS.innerHTML = nightCSS; parseframescss(frameNightCSS); } htmlHead.appendChild(currentCSS); /* initialize alternative CSS */ function parseframescss(targetCSS) { var i, k; for (k = 0; k < window.top.frames.length; k++) { (function recursive(tmpWindow) { tmpWindow.document.getElementsByTagName('style')[0].innerHTML = targetCSS; for (i = 0; i < tmpWindow.frames.length; i++) { tmpWindow.frames[i].document.getElementsByTagName('style')[0].innerHTML = targetCSS; if (tmpWindow.frames[i].frames.length) { tmpWindow = tmpWindow.frames[i]; recursive(tmpWindow); } } return false; })(window.frames[k]); } } function cssSwitchHandler() { if (currentStyle === 'day') { currentCSS.innerHTML = nightCSS; parseframescss(frameNightCSS); document.getElementById('cssswitcher') .innerHTML = 'CSS on'; GM_setValue('gm_currentstyle', 'night'); } else { currentCSS.innerHTML = GM_config.get('altCSS'); parseframescss(frameDayCSS); document.getElementById('cssswitcher') .innerHTML = 'CSS off'; GM_setValue('gm_currentstyle', 'day'); } currentStyle = GM_getValue('gm_currentstyle'); } /* init dynamic toolbar links, innerHTML@classToolbar will break GM_config */ idCSSSwitcher = document.createElement('span'); idCSSSwitcher.id = 'cssswitcher'; classToolbar.appendChild(idCSSSwitcher); if (currentStyle === 'day') { idCSSSwitcher.innerHTML += 'CSS off'; } else { idCSSSwitcher.innerHTML += 'CSS on'; } if (GM_config.get('wpOn')) { idWpSwitcher = document.createElement('span'); idWpSwitcher.id = 'writepadswitcher'; idWpSwitcher.innerHTML += 'writepad'; classToolbar.appendChild(idWpSwitcher); } idSetSwitcher = document.createElement('span'); idSetSwitcher.id = 'settingswitcher'; idSetSwitcher.innerHTML += 'SETTING'; classToolbar.appendChild(idSetSwitcher); classToolbar.appendChild(fbAnchor); idCSSSwitcher.addEventListener('click', cssSwitchHandler, false); idSetSwitcher.addEventListener('click', function () { if(!GM_config.fields['quoteSize'].toValue()) { //dirty hack, to find out panel status GM_config.open(); idSetSwitcher.innerHTML = '[SAVE]'; } else { GM_config.save(); idSetSwitcher.innerHTML = 'SETTING'; } }, false); /* add class threadfly */ var divThreads, divThreadsName, divThreadsStyle, bqOP, bqOPPic, classThreadfly; divThreads = document.getElementById('right_content') .getElementsByTagName('div'); k = 1; for (i = 0; i < divThreads.length; i++) { divThreadsName = divThreads[i].className; divThreadsStyle = divThreads[i].style; if (GM_config.get('twoupOn')) { if (divThreadsStyle.clear.search('both') !== -1) { /* del nonsense clear:both */ if (k === 1) { divThreadsStyle.clear = 'none'; } k *= -1; } } if (divThreadsName.search('threads') !== -1) { divThreads[i].classList.add('threadfly'); } } classThreadfly = document.getElementsByClassName('threadfly'); for (i = 0; i < classThreadfly.length; i++) { /* add class originpost and originpost-pic*/ bqOP = classThreadfly[i].getElementsByTagName('blockquote')[0]; bqOPPic = classThreadfly[i].getElementsByTagName('a')[0]; bqOP.classList.add('originpost'); bqOPPic.classList.add('originpost-pic'); } function disablescroll(e) { e.preventDefault(); e.returnValue = false; } if (GM_config.get('menuHide')) { owCSS.innerHTML += '#menu {left: -125px; opacity: 0; transition: all 0.66s ease-in-out; padding: 0 0 0 1em; overflow: hidden; height: 100%}'; function scrollmenu(e) { var delta, idMenu; idMenu = document.getElementById('menu'); if (!e && window.event) { e = window.event; } if (e.wheelDelta) { delta = e.wheelDelta / 30; } else { delta = - e.detail * 10; } idMenu.scrollTop -= delta; } /* initialize left menu */ var menuBlock, idRightContent, idMenu; idRightContent = window.document.getElementById('right_content'); idMenu = window.document.getElementById('menu'); if(GM_config.get('twoupOn')) { idRightContent.style.margin = 0; /* fix right_content */ } else { idRightContent.style.margin = ''; /* overwrite dynamic generated style */ } idMenu.style.margin = idMenu.style.padding = idMenu.style.overflow = ''; /* overwrite dynamic generated style */ idMenu.style.left = '-125px'; /* overwrite dynamic style */ menuBlock = window.document.createElement('span'); /* dirty hack, depend on dynamic generate height */ menuBlock.innerHTML = '<br />'; idMenu.appendChild(menuBlock); idMenu.onmouseover = function () { window.addEventListener('DOMMouseScroll', disablescroll, false); window.onmousewheel = window.document.onmousewheel = disablescroll; idMenu.addEventListener('DOMMouseScroll', scrollmenu, false); idMenu.style.left = '0px'; idMenu.style.opacity = 1; idMenu.style.zIndex = 9999; }; idMenu.onmouseout = function () { window.removeEventListener('DOMMouseScroll', disablescroll, false); window.onmousewheel = document.onmousewheel = null; idMenu.style.left = '-125px'; idMenu.style.opacity = 0; }; } if (GM_config.get('adminOn')) { /* enable hidden adminTools */ var classAdminTool = document.getElementsByClassName('adminTool'); for (i = 0; i < classAdminTool.length; i++) { classAdminTool[i].style.display = 'inline'; } } if (GM_config.get('twoupOn')) { owCSS.innerHTML += '.threadfly {width: 45%; float: left; margin-left: 1%; margin-bottom: 2em;}'; owCSS.innerHTML += '.threadfly table font {display: none;}'; owCSS.innerHTML += '.rthreads {border-left-width: 15px; border-left-style: solid; padding: 0 0 0 2%; margin: 0 0 2em 2%;}'; /* dirty hack, check if in thread reply page */ if (classThreadfly.length === 1) { owCSS.innerHTML += '.threadfly {width: 80%; margin: 2em 10%; } .threadpost {padding: 0 5em;}'; } /* remove all hr */ owCSS.innerHTML += 'hr {display:none;}'; /* add left border and related */ k = -1; for (i = 0; i < classThreadfly.length; i++, k *= -1) { if (k === 1) { classThreadfly[i].classList.add('rthreads'); } } } if (GM_config.get('twOn')) { owCSS.innerHTML += '.posttime {margin-left: 0.5em;} p, body {margin: 0;} '; /* use good time format */ var tmpWeekdayPost, tmpMonthPost, tmpDayPost, objDate; var classPosttime = document.getElementsByClassName('posttime'); for (i = 0; i < classPosttime.length; i++) { tmp = classPosttime[i].innerHTML; tmpWeekdayPost = tmp.substr(0, 3); tmpMonthPost = tmp.substr(4, 3); tmpDayPost = tmp.substr(8, 2); tmp = tmpWeekdayPost + ', ' + tmpDayPost + ' ' + tmpMonthPost + tmp.slice(10, - 5); objDate = new Date(tmp); classPosttime[i].innerHTML = '<span>' + objDate.toLocaleDateString() + ' ' + objDate.toLocaleTimeString('zh-CN', 'Asia/Berjing') + '</span><br />'; } } if (GM_config.get('navFix')) { /* replace the page navigation */ var key, tableNavigation; tableNavigation = document.getElementsByTagName('table'); key = tableNavigation.length -1; /* dirty hack, may failed later */ if (tableNavigation[key].align === 'left') { tableNavigation[key].classList.add('nav-bottom'); tableNavigation[key].align = ''; } } if (GM_config.get('hboxOn')) { /* Use hbox to popup the Images * Rewrite from: http://www.codeproject.com/Articles/32819/JavaScript-Image-Popup * Start Initializing */ var hboxLoadImage = 'url("")'; var hboxDiv = document.createElement('div'); hboxDiv.id = 'thebox'; hboxDiv.style.backgroundImage = hboxLoadImage; var hboxbgDiv = document.createElement('div'); hboxbgDiv.id = 'box-bg'; hboxbgDiv.appendChild(hboxDiv); document.body.appendChild(hboxbgDiv); /* add hboxstuff style */ var hboxStyle = document.createElement('style'); hboxStyle.type = 'text/css'; hboxStyle.id = 'hboxcss'; hboxStyle.innerHTML = hboxCSS; htmlHead.appendChild(hboxStyle); function hboxCloseHandler(e) { var eventSender; if (!e && window.event) { e = window.event; } eventSender = (window.event) ? e.srcElement : e.target; if (eventSender.id === 'thebox' || eventSender.id === 'box-bg') { hboxDiv.style.visibility = 'hidden'; hboxbgDiv.style.visibility = 'hidden'; hboxDiv.style.position = ''; window.removeEventListener('DOMMouseScroll', disablescroll); window.onmousewheel = document.onmousewheel = null; hboxDiv.style.backgroundImage = hboxLoadImage; // revoke the loading gif } } function scrollimage(e) { var delta, idThebox, topThebox; if (!e && window.event) { e = window.event; } if (e.wheelDelta) { delta = e.wheelDelta / 10; } else { delta = - e.detail * 30; } idThebox = document.getElementById('thebox'); topThebox = parseInt(idThebox.style.top.slice(0, - 2), 10); topThebox += delta; idThebox.style.top = topThebox + 'px'; } function imageOnloadHandler() { // image resize on oversized var idThebox, idImageinbox, idBoxBg, heightPic, heightWindow, widthWindow, widthPic; idImageinbox = document.getElementById('imageinbox'); heightPic = idImageinbox.clientHeight; widthPic = idImageinbox.clientWidth; heightWindow = window.innerHeight || document.documentElement.offsetHeight; widthWindow = window.innerWidth || document.documentElement.offsetWidth; if (heightPic > heightWindow && (widthPic / heightPic) < 0.8) { /* over 8:10, make scrollable */ idImageinbox.width = widthWindow - 80; // 80 is MAGIC idThebox = document.getElementById('thebox'); idBoxBg = document.getElementById('box-bg'); idThebox.style.left = '40px'; idThebox.style.top = 0; idThebox.style.position = 'fixed'; idBoxBg.addEventListener('DOMMouseScroll', scrollimage, false); window.addEventListener('DOMMouseScroll', disablescroll, false); // disable window scroll event window.onmousewheel = document.onmousewheel = disablescroll; alertNotice('Use Mouse Wheel to ajust!', 1500); } else if (heightPic > heightWindow) { idImageinbox.height = heightWindow - 50; /* 50 is MAGIC */ alertNotice('The image is ' + parseInt(idImageinbox.height / heightPic * 100) + '% shrinked', 3000); } else if (widthPic > widthWindow) { idImageinbox.width = widthWindow - 50; alertNotice('The image is ' + parseInt(idImageinbox.width / widthPic * 100) + '% shrinked', 3000); } hboxDiv.style.backgroundImage = ''; /* remove the loading gif */ } function hboxLauncher(e) { var eventSender, imageSource, hboxImg; if (!e && window.event) { e = window.event; } eventSender = (window.event) ? e.srcElement : e.target; eventSender = eventSender.parentNode; /* cant click empty anchor */ imageSource = eventSender.rel; hboxbgDiv.addEventListener('click', hboxCloseHandler, false); hboxDiv.style.visibility = 'visible'; hboxbgDiv.style.visibility = 'visible'; hboxImg = document.createElement('img'); hboxImg.id = 'imageinbox'; hboxImg.src = imageSource; hboxImg.onload = imageOnloadHandler; hboxDiv.innerHTML = ''; hboxDiv.appendChild(hboxImg); } /* anchor @thread image parse */ var imgThread, anchorThread; for (k = 0; k < classThreadfly.length; k++) { anchorThread = classThreadfly[k].getElementsByTagName('a'); for (i = 0; i < anchorThread.length; i++) { imgThread = anchorThread[i].getElementsByTagName('img'); if (imgThread.length) { // fix the origin anchor anchorThread[i].rel = anchorThread[i].href; anchorThread[i].addEventListener('click', hboxLauncher, false); anchorThread[i].target = ''; anchorThread[i].href = 'javascript:void(0);'; // dirty hack, use span instead } } } function imageparse(targetObj) { // make anchor useless and parse image var imgThread, anchorThread; anchorThread = targetObj.document.getElementsByTagName('a'); for (i = 0; i < anchorThread.length; i++) { imgThread = anchorThread[i].getElementsByTagName('img'); if (imgThread.length) { // fix the origin anchor anchorThread[i].rel = anchorThread[i].href; anchorThread[i].addEventListener('click', hboxLauncher, false); anchorThread[i].target = ''; anchorThread[i].href = 'javascript:void(0);'; // dirty hack, use span instead } } } } if (GM_config.get('wpOn')) { function padSwitchHandler() { if (padDisplay) { padDisplay = 0; padDiv.style.display = 'none'; } else { padDisplay = 1; padDiv.style.display = 'inline'; } } owCSS.innerHTML += '#postform_tblabandon p {line-height: 1.5em; padding-bottom: 2em;}'; owCSS.innerHTML += '#writepad {border: 2px solid; background-color: #a09797;}'; owCSS.innerHTML += '#writepad-close:hover {cursor: pointer; text-decoration: underline;}'; owCSS.innerHTML += '#writepad-close {width: 100% ; color: white; background-color: #810400; text-align: center; font-weight: bold; font-size: 1.5em;}'; /* add writepad */ var padDisplay, idPostformMain, padDiv; padDisplay = 0; idPostformMain = document.getElementById('postform_main') .innerHTML; padDiv = document.createElement('div'); padDiv.id = 'writepad'; /* replace origin element */ var idToAbandon, padListAbandon; padListAbandon = [ 'postform_tbl', '_csrf', 'emotion', 'content', 'postform_main' ]; for (i = 0; i < padListAbandon.length; i++) { idToAbandon = document.getElementById(padListAbandon[i]); idToAbandon.id += 'abandon'; // abandon original id, move into pad smoothly } /* rebuild the postform_main */ var padForm = document.createElement('form'); padForm.id = 'postform_main'; padForm.enctype = 'multipart/form-data'; padForm.method = 'post'; padForm.action = '/综合版1/create'; padForm.innerHTML = idPostformMain; /* hide origin form at top */ var trBad = document.getElementById('postform_tblabandon') .getElementsByTagName('tr'); for (i = 0; i < trBad.length -1; i++) { /* save the notice board */ trBad[i].style.display = 'none'; } /* add a close button */ var padClose = document.createElement('div'); padClose.id = 'writepad-close'; padClose.innerHTML = 'CLOSE'; padClose.addEventListener('click', padSwitchHandler, false); padDiv.appendChild(padClose); /* style the writepad */ padDiv.style.position = 'fixed'; padDiv.style.top = '50px'; padDiv.style.left = '50px'; padDiv.id = 'writepad'; padDiv.style.display = 'none'; padDiv.appendChild(padForm); document.body.appendChild(padDiv); makegrabbable(padDiv); /* make the pad grabbable */ if (GM_config.get('wpOn')) { document.getElementById('writepadswitcher') .addEventListener('click', padSwitchHandler, false); } } if (GM_config.get('bqOn')) { /* remove refView divbox */ var idRefView = window.top.document.getElementById('refView'); if (idRefView) { window.document.body.removeChild(idRefView); } function callResize(objWindow) { var frameWinList, frameList, heightNew, widthNew; frameWinList = objWindow.frames; frameList = objWindow.document.getElementsByTagName('iframe'); for (i = 0; i < frameWinList.length; i++) { heightNew = frameWinList[i].document.getElementsByTagName('table')[0].clientHeight + 8; /* 8 is MAGIC */ widthNew = frameWinList[i].document.getElementsByTagName('table')[0].clientWidth + 5; /* 5 is MAGIC */ frameList[i].style.height = heightNew + 'px'; frameList[i].style.width = widthNew + 'px'; frameList[i].scrolling = 'no'; } } function betterquote(targetObj) { /* betterQuote display */ var numFrames, quoteFrame, quoteFrameParent, fontBar, tmpColor, quoteFrameSrc, tpBar; numFrames = 0; quoteFrame = [ ]; quoteFrameParent = [ ]; tpBar = targetObj.document.getElementsByClassName('threadpost'); for (k = 0; k < tpBar.length; k++) { fontBar = tpBar[k].getElementsByTagName('font'); for (i = 0; i < fontBar.length; i++) { tmpColor = fontBar[i].color; if (tmpColor.search('789922') !== -1) { // replace font with iframe tag tmp = fontBar[i].innerHTML; tmp = tmp.substr(tmp.search('No') + 3); if (!isNaN(parseInt(tmp, 10))) { // abandon on nonsense numFrames += 1; quoteFrameSrc = 'http://h.acfun.tv/homepage/ref?tid=' + tmp; quoteFrame[i] = document.createElement('iframe'); quoteFrame[i].src = quoteFrameSrc; quoteFrame[i].onload = frameOnloadHandler; // use onload Handler, instead of checkonload quoteFrameParent[i] = fontBar[i].parentNode; quoteFrameParent[i].replaceChild(quoteFrame[i], fontBar[i]); i--; // dirty hack, onSuccess, fontBar.length will minus one } else { fontBar[i].color = 'blue'; // recolor nonsense quotes } } } } if (numFrames) { return 1; } return false; } function styletheframe(targetObj) { /* insert css into iframe */ var headFrame, iframeCSS, tdFirst, anchorInFrame; if (!targetObj.document.getElementsByClassName('fivehundred') .length) { // handle 40x page headFrame = targetObj.document.getElementsByTagName('head')[0]; iframeCSS = document.createElement('style'); iframeCSS.type = 'text/css'; iframeCSS.id = 'framecss'; if(currentStyle === 'day') { iframeCSS.innerHTML = frameDayCSS; } else { iframeCSS.innerHTML = frameNightCSS; } /* add condition on css switch */ headFrame.appendChild(iframeCSS); tdFirst = targetObj.document.getElementsByTagName('td')[0]; tdFirst.parentElement.removeChild(tdFirst); anchorInFrame = targetObj.document.getElementsByTagName('a'); for (i = 0; i < anchorInFrame.length; i++) { // fix in_frame link anchorInFrame[i].target = '_top'; } } else { targetObj.document.body.innerHTML = 'QUOTE_ERROR'; /* EDGE handler */ window.alert('HOLLLY SHIT!! It looks like you have met some boobs not able to handle the quote usage, please either hate them or blame monkeys@h.acfun.tv for not setting just a timeoutID for 40x pages\' nonsense setTimeout() event.'); if (window.confirm('YES: Automatic open current into new tab, i.e: to save yourselves. NO&Cancel: Waiting for the doomsday.')) { GM_openInTab(window.location.href); } } } function frameOnloadHandler(e) { var eventSender, windowCaller, tmp, mainFrameKey, recurKey, tmpWindow, fontBar, tmpBuffer; /* gl: mainFrameList, quoteSize */ if (!e && window.event) { e = window.event; } eventSender = (window.event) ? e.srcElement : e.target; windowCaller = eventSender.contentWindow || eventSender; if (GM_config.get('hboxOn')) { imageparse(windowCaller); } /* get mainFrameId */ tmp = windowCaller; while (tmp.name === '' || tmp.name.search('iframe') === -1) { tmp = tmp.parent; } mainFrameKey = tmp.name.substr(7); recurKey = mainFrameList[mainFrameKey]; mainFrameList.splice(mainFrameKey, 1, recurKey + 1); if (mainFrameList[mainFrameKey] < GM_config.get('quoteSize')) { if (!betterquote(windowCaller)) { styletheframe(windowCaller); tmpWindow = windowCaller.parent; while (window.top !== tmpWindow) { styletheframe(tmpWindow); callResize(tmpWindow); tmpWindow = tmpWindow.parent; } setTimeout(function () { callResize(window); }, 500); // dirty hack, MAGIC reduce error } } else { fontBar = windowCaller.document.getElementsByTagName('font'); for (i = 0; i < fontBar.length; i++) { if (fontBar[i].color === '#789922') { fontBar[i].title = 'Reached quoteSize limit.'; tmpBuffer = fontBar[i].innerHTML; tmpBuffer = tmpBuffer.substr(tmpBuffer.search('No') + 3); fontBar[i].onclick = function () { GM_openInTab('http://h.acfun.tv/homepage/ref?tid=' + tmpBuffer); }; } } styletheframe(windowCaller); tmpWindow = windowCaller.parent; while (window.top !== tmpWindow) { styletheframe(tmpWindow); callResize(tmpWindow); tmpWindow = tmpWindow.parent; } callResize(window); } } /* betterquote @window */ var mainFrameKey, mainFramList, quoteFrame, quoteFrameParent, fontBar, tmpColor, quoteFrameSrc, tpBar; mainFrameKey = 0; mainFrameList = []; quoteFrame = []; quoteFrameParent = []; tpBar = window.document.getElementsByClassName('threadpost'); for (k = 0; k < tpBar.length; k++) { fontBar = tpBar[k].getElementsByTagName('font'); for (i = 0; i < fontBar.length && i >= 0; i++) { // left when parsed all tmpColor = fontBar[i].color; if (tmpColor.search('789922') !== -1) { // replace font with iframe tag tmp = fontBar[i].innerHTML; tmp = tmp.substr(tmp.search('No') + 3); if (!isNaN(parseInt(tmp, 10))) { // abandon on nonsense mainFrameList.push(0); quoteFrameSrc = 'http://h.acfun.tv/homepage/ref?tid=' + tmp; quoteFrame[i] = document.createElement('iframe'); quoteFrame[i].src = quoteFrameSrc; quoteFrame[i].name = 'iframe_' + mainFrameKey; quoteFrame[i].onload = frameOnloadHandler; // use onload Handler, instead of checkonload quoteFrameParent[i] = fontBar[i].parentNode; quoteFrameParent[i].replaceChild(quoteFrame[i], fontBar[i]); mainFrameKey += 1; i--; // dirty hack, onSuccess, fontBar.length will minus one } else { fontBar[i].color = 'blue'; // recolor the nonsense } } } } } }