Raw Source
doomred / hacer

// ==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
                    }
                }
            }
        }
    }
}