// ==UserScript== // @name NGA Pins // @namespace https://greasyfork.org/zh-CN/scripts/36246-nga-pins // @version 0.1.4.20200528 // @icon http://bbs.nga.cn/favicon.ico // @description NGA Pins 可将顶部菜单、导航栏、页码栏固定在窗口顶部,亦可通过设置取消其中某项;主帖内容较长时将作者信息固定在主帖左侧(不包含回复) // @author AgLandy // @include /^https?:\/\/(bbs\.ngacn\.cc|nga\.178\.com|bbs\.nga\.cn)/ // @grant none // @require https://greasyfork.org/scripts/39014-nga-user-script-loader/code/NGA%20User%20Script%20Loader.js // @license MIT License // @downloadURL https://update.greasyfork.icu/scripts/36246/NGA%20Pins.user.js // @updateURL https://update.greasyfork.icu/scripts/36246/NGA%20Pins.meta.js // ==/UserScript== //发布地址:http://bbs.ngacn.cc/read.php?tid=13033636 (function(){ function init(usl){ let $ = usl.$, p = commonui.pins = { init: function(){ let args = {}; if(localStorage.pins) args = JSON.parse(localStorage.pins); else{ args = {a: 56, b: 42, c: 43}; localStorage.pins = JSON.stringify(args); } return args; }, f: function(){ let args = p.args, hA = args.a + 8, hB = args.b && args.b + 8, hC = args.c && args.c + 8, a = $('#mainmenu'), b = $('#m_nav'), c = $('#m_pbtntop'), t = $('#posterinfo0').closest('td'), h = c[0] && c.offset().top - hA - hB || b.offset().top - hA, o = $('body > #pinsPins')[0] ? $('body > #pinsPins') : $('
').appendTo('body'), //为导航栏和页码栏创建外部div z = [[a, 'pinsTopBar'], [b, 'pinsNavBar'], [c, 'pinsPageBar'], [t, 'pinsAuthorInfo']], newDiv = function(i){ return $('
').append(z[i][0].children()).appendTo(z[i][0]); }; //还原默认 for(let i = 0; i < z.length; i++){ if($('#' + z[i][1])[0]) if(i % 3 != 0 && o.find('#' + z[i][1])[0] && z[i][0].children()[0]) o.find('#' + z[i][1]).remove(); else $('#' + z[i][1]).appendTo(z[i][0]).contents().unwrap(); } $(window).unbind('.pins'); //顶部菜单 if(args.a){ let d = newDiv(0); d.css({'height':a.css('height'), 'width':'100%', 'overflow':'hidden', 'position':'fixed', 'top':'0px', 'z-index':'3', 'opacity':'0.95'}); $(window).bind('scroll.pins', function(){ if($(window).scrollTop() > $('#custombg').height()) d.css({'border-bottom':'1px solid #' + __COLOR.shadow1.replace(/;.+;/,'').replace(/^.+#/,'')}); else d.css({'border-bottom':''}); }); } //导航栏 if(args.b){ let d = newDiv(1); b.css({'height':b.css('height')}); b.find('.bbsinfo').prependTo(b); $(window).bind('scroll.pins', function(){ if($(window).scrollTop() > h) d.css({'position':'fixed', 'top':hA + 'px', 'z-index':'3', 'opacity':'0.95'}).appendTo(o); else d.css({'position':'', 'top':'', 'z-index':'', 'opacity':''}).appendTo(b); }); } //页码栏 if(args.c){ let d = newDiv(2); c.css({'height':c.css('height')}); $(window).bind('scroll.pins', function(){ if($(window).scrollTop() > h) d.css({'width':'calc(100% - 20px)', 'position':'fixed', 'top':(hA + hB) + 'px', 'z-index':'2', 'opacity':'0.95', 'pointer-events':'none'}).appendTo(o); else d.css({'width':'', 'position':'', 'top':'', 'z-index':'', 'opacity':'', 'pointer-events':''}).appendTo(c); }); } //作者信息 if($('#posterinfo0')[0] && $('#posterinfo0').closest('td').outerHeight() > 600){ t.css({'min-width':'197px'}); let d = newDiv(3), h1 = hA + hB + hC + 6, h2 = d.offset().top - h1, w = function(){ d.css('width', t.css('width')); }; if(/firefox/.test(navigator.userAgent.toLowerCase())){ $('.postcontent').bind('click.pins', function(){setTimeout(w,5);}); $(window).bind('transitionend.pins', function(){setTimeout(w,5);}); } else{ let mo = new MutationObserver(w); mo.observe($('#posterinfo0').closest('table')[0], { childList: true, subtree: true, attributes: true }); } $(window).bind('resize.pins', w); $(window).bind('scroll.pins', function(){ if($(window).scrollTop() > h2 && $(window).scrollTop() < t.height() - d.height() + h2) d.css({'width':t.css('width'), 'position':'fixed', 'top':h1 + 'px'}); else if($(window).scrollTop() >= t.height() - d.height() + h2) d.css({'width':t.css('width'), 'position':'fixed', 'top':(h1 - $(window).scrollTop() + t.height() - d.height() + h2) + 'px'}); else d.css({'width':'', 'position':'', 'top':''}); }); } $(window).triggerHandler('scroll.pins'); } }; commonui.mainMenu.data[401] = {innerHTML: 'Pins 设置', on: {event: 'click', func: function(e){ let o = __SETTING.o = commonui.createadminwindow(), z = [['a', '56', '顶部菜单'], ['b','42', '导航栏'], ['c','43', '页码栏']]; o._.addContent(null); o._.addTitle('Pins 设置'); $.each(z, function(i, zi){ let k = _$('/input').$0('type','checkbox','checked',0,'name',zi[0],'value',zi[1])._.on('click', function(){ p.args[this.name] = this.checked ? parseInt(this.value) : 0; localStorage.pins = JSON.stringify(p.args); p.f(); }); o._.addContent( k, zi[2], _$('/br') ); if(p.args[zi[0]]) k._.attr('checked', 1); }); o._.show(e); }}, parent: 18}; commonui.mainMenu.data[18].subKeys.push(401); $('div#mainmenu input[placeholder$="搜索"]')[0]._on = function(){ var o = this.__w; if(!o){ o = (this.__w = commonui.createCommmonWindow(2)); o._.addContent( _$('/span')._.add( commonui.uniSearchInput(this) ) ); o.firstChild.lastChild.style.backgroundColor = __COLOR.bg4; with(o.style){ left = top = '0'; visibility = 'hidden'; display = 'block'; boxShadow = 'none'; borderTop = 'none'; marginTop = '-1px'; } document.body.appendChild(o); o._b = o.getBoundingClientRect(); var se = this; commonui.aE(document.body, 'click', function(e){ var h = e.target || e.srcElement; for(var i = 0; i < 7; i++){ if(h == o || h == se.parentNode.parentNode) return; h = h.parentNode; if(!h) break; } o._.hide(); }); } if(o.style.display == 'none' || o.style.visibility == 'hidden'){ var p = this.parentNode.parentNode.getBoundingClientRect(); if(commonui.pins.args.a != 0) $(o).css({left: p.left + p.width - o._b.width + 'px', top: p.top + p.height + 'px', position: 'fixed', visibility: 'inherit'}).fadeIn('fast'); else o._.css('position','')._.show(p.left + p.width - o._b.width, p.top + p.height); } }; //default.js commonui.mainMenuItems[162] $('