无编辑摘要 |
无编辑摘要 |
||
第1行: | 第1行: | ||
− | /* MediaWiki:Gadget-site-lib.js */ |
||
− | window.wgUXS = function (wg, hans, hant, cn, tw, hk, sg, zh, mo, my) { |
||
− | var ret = { |
||
− | 'zh': zh || hans || hant || cn || tw || hk || sg || mo || my, |
||
− | 'zh-hans': hans || cn || sg || my, |
||
− | 'zh-hant': hant || tw || hk || mo, |
||
− | 'zh-cn': cn || hans || sg || my, |
||
− | 'zh-sg': sg || hans || cn || my, |
||
− | 'zh-tw': tw || hant || hk || mo, |
||
− | 'zh-hk': hk || hant || mo || tw, |
||
− | 'zh-mo': mo || hant || hk || tw |
||
− | } |
||
− | return ret[wg] || zh || hant || hans || tw || cn || hk || sg || mo || my; //保證每一語言有值 |
||
− | } |
||
− | |||
− | window.wgULS = function (hans, hant, cn, tw, hk, sg, zh, mo, my) { |
||
− | return wgUXS(mw.config.get('wgUserLanguage'), hans, hant, cn, tw, hk, sg, zh, mo, my); |
||
− | }; |
||
− | |||
− | window.wgUVS = function (hans, hant, cn, tw, hk, sg, zh, mo, my) { |
||
− | return wgUXS(mw.config.get('wgUserVariant'), hans, hant, cn, tw, hk, sg, zh, mo, my); |
||
− | }; |
||
− | |||
− | window.importScriptCallback = function(page, ready) { |
||
− | importScriptURICallback(mw.config.get('wgServer') + mw.config.get('wgScript') + '?title=' + mw.util.wikiUrlencode(page) + '&action=raw&ctype=text/javascript', ready); |
||
− | }; |
||
− | |||
− | window.importScriptURICallback = jQuery.getScript;// |
||
− | |||
− | |||
============================================================ |
============================================================ |
||
// BEGIN Dynamic Navigation Bars (experimantal) |
// BEGIN Dynamic Navigation Bars (experimantal) |
2021年7月18日 (日) 06:25的最新版本
============================================================
// BEGIN Dynamic Navigation Bars (experimantal)
// This script is from Wikipedia. For author attribution, please see https://en.wikipedia.org/w/index.php?title=MediaWiki:Common.js&action=history
/* Test if an element has a certain class **************************************
*
* Description: Uses regular expressions and caching for better performance.
* Maintainers: User:Mike Dillon, User:R. Koot, User:SG
*/
var hasClass = (function () {
var reCache = {};
return function (element, className) {
return (reCache[className] ? reCache[className] : (reCache[className] = new RegExp("(?:\\s|^)" + className + "(?:\\s|$)"))).test(element.className);
};
})();
/** Collapsible tables *********************************************************
*
* Description: Allows tables to be collapsed, showing only the header. See
* [[Wikipedia:NavFrame]].
* Maintainers: [[User:R. Koot]]
*/
var autoCollapse = 2;
var collapseCaption = "less";
var expandCaption = "more";
function collapseTable( tableIndex ) {
var Button = document.getElementById( "collapseButton" + tableIndex );
var Table = document.getElementById( "collapsibleTable" + tableIndex );
if ( !Table || !Button ) {
return false;
}
var Rows = Table.getElementsByTagName( "tr" );
if ( Button.firstChild.data == collapseCaption ) {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = "none";
}
Button.firstChild.data = expandCaption;
} else {
for ( var i = 1; i < Rows.length; i++ ) {
Rows[i].style.display = Rows[0].style.display;
}
Button.firstChild.data = collapseCaption;
}
}
function createCollapseButtons() {
var tableIndex = 0;
var NavigationBoxes = new Object();
var Tables = document.getElementsByTagName( "table" );
for ( var i = 0; i < Tables.length; i++ ) {
if ( hasClass( Tables[i], "collapsible" ) ) {
NavigationBoxes[ tableIndex ] = Tables[i];
Tables[i].setAttribute( "id", "collapsibleTable" + tableIndex );
var Button = document.createElement( "span" );
var ButtonLink = document.createElement( "a" );
var ButtonText = document.createTextNode( collapseCaption );
Button.style.styleFloat = "right";
Button.style.cssFloat = "right";
Button.style.fontWeight = "normal";
Button.style.textAlign = "right";
Button.style.width = "6em";
ButtonLink.setAttribute( "id", "collapseButton" + tableIndex );
ButtonLink.setAttribute( "href", "javascript:collapseTable(" + tableIndex + ");" );
ButtonLink.appendChild( ButtonText );
Button.appendChild( document.createTextNode( "[" ) );
Button.appendChild( ButtonLink );
Button.appendChild( document.createTextNode( "]" ) );
var Header = Tables[i].getElementsByTagName( "tr" )[0].getElementsByTagName( "th" )[0];
/* only add button and increment count if there is a header row to work with */
if (Header) {
Header.insertBefore( Button, Header.childNodes[0] );
tableIndex++;
}
}
}
for ( var i = 0; i < tableIndex; i++ ) {
if ( hasClass( NavigationBoxes[i], "collapsed" ) || ( tableIndex >= autoCollapse && hasClass( NavigationBoxes[i], "autocollapse" ) ) ) {
collapseTable( i );
}
}
}
addOnloadHook( createCollapseButtons );
/** Dynamic Navigation Bars (experimental) *************************************
*
* Description: See [[Wikipedia:NavFrame]].
* Maintainers: UNMAINTAINED
*/
// set up the words in your language
var NavigationBarHide = '[' + collapseCaption + ']';
var NavigationBarShow = '[' + expandCaption + ']';
// set up max count of Navigation Bars on page,
// if there are more, all will be hidden
// NavigationBarShowDefault = 0; // all bars will be hidden
// NavigationBarShowDefault = 1; // on pages with more than 1 bar all bars will be hidden
var NavigationBarShowDefault = autoCollapse;
// shows and hides content and picture (if available) of navigation bars
// Parameters:
// indexNavigationBar: the index of navigation bar to be toggled
function toggleNavigationBar(indexNavigationBar) {
var NavToggle = document.getElementById("NavToggle" + indexNavigationBar);
var NavFrame = document.getElementById("NavFrame" + indexNavigationBar);
if (!NavFrame || !NavToggle) {
return false;
}
// if shown now
if (NavToggle.firstChild.data == NavigationBarHide) {
for (
var NavChild = NavFrame.firstChild;
NavChild != null;
NavChild = NavChild.nextSibling
) {
if ( hasClass( NavChild, 'NavPic' ) ) {
NavChild.style.display = 'none';
}
if ( hasClass( NavChild, 'NavContent') ) {
NavChild.style.display = 'none';
}
}
NavToggle.firstChild.data = NavigationBarShow;
// if hidden now
} else if (NavToggle.firstChild.data == NavigationBarShow) {
for (
var NavChild = NavFrame.firstChild;
NavChild != null;
NavChild = NavChild.nextSibling
) {
if (hasClass(NavChild, 'NavPic')) {
NavChild.style.display = 'block';
}
if (hasClass(NavChild, 'NavContent')) {
NavChild.style.display = 'block';
}
}
NavToggle.firstChild.data = NavigationBarHide;
}
}
// adds show/hide-button to navigation bars
function createNavigationBarToggleButton() {
var indexNavigationBar = 0;
// iterate over all < div >-elements
var divs = document.getElementsByTagName("div");
for(
var i=0;
NavFrame = divs[i];
i++
) {
// if found a navigation bar
if (hasClass(NavFrame, "NavFrame")) {
indexNavigationBar++;
var NavToggle = document.createElement("a");
NavToggle.className = 'NavToggle';
NavToggle.setAttribute('id', 'NavToggle' + indexNavigationBar);
NavToggle.setAttribute('href', 'javascript:toggleNavigationBar(' + indexNavigationBar + ');');
var NavToggleText = document.createTextNode(NavigationBarHide);
NavToggle.appendChild(NavToggleText);
// Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked)
for(
var j=0;
j < NavFrame.childNodes.length;
j++
) {
if (hasClass(NavFrame.childNodes[j], "NavHead")) {
NavFrame.childNodes[j].appendChild(NavToggle);
}
}
NavFrame.setAttribute('id', 'NavFrame' + indexNavigationBar);
}
}
// if more Navigation Bars found than Default: hide all
if (NavigationBarShowDefault < indexNavigationBar) {
for(
var i=1;
i<=indexNavigationBar;
i++
) {
toggleNavigationBar(i);
}
}
}
addOnloadHook( createNavigationBarToggleButton );
// END Dynamic Navigation Bars
// ============================================================
// </nowiki></pre>
/* Replaces {{USERNAME}} with the name of the user browsing the page.
Requires copying Template:USERNAME. */
$(function UserNameReplace() {
if(typeof(disableUsernameReplace) != 'undefined' && disableUsernameReplace || wgUserName === null) return;
$("span.insertusername").text(wgUserName);
});
/* End of the {{USERNAME}} replacement */
// **************************************************
// Experimental javascript countdown timer (Splarka)
// Version 0.0.3
// **************************************************
//
// Usage example:
// <span class="countdown" style="display:none;">
// Only <span class="countdowndate">January 01 2007 00:00:00 PST</span> until New years.
// </span>
// <span class="nocountdown">Javascript disabled.</span>
function updatetimer(i) {
var now = new Date();
var then = timers[i].eventdate;
var diff = count=Math.floor((then.getTime()-now.getTime())/1000);
// catch bad date strings
if(isNaN(diff)) {
timers[i].firstChild.nodeValue = '** ' + timers[i].eventdate + ' **' ;
return;
}
// determine plus/minus
if(diff<0) {
diff = -diff;
var tpm = ' ';
} else {
var tpm = ' ';
}
// calcuate the diff
var left = (diff%60) + ' seconds';
diff=Math.floor(diff/60);
if(diff > 0) left = (diff%60) + ' minutes ' + left;
diff=Math.floor(diff/60);
if(diff > 0) left = (diff%24) + ' hours ' + left;
diff=Math.floor(diff/24);
if(diff > 0) left = diff + ' days ' + left
timers[i].firstChild.nodeValue = tpm + left;
// a setInterval() is more efficient, but calling setTimeout()
// makes errors break the script rather than infinitely recurse
timeouts[i] = setTimeout('updatetimer(' + i + ')',1000);
}
function checktimers() {
//hide 'nocountdown' and show 'countdown'
var nocountdowns = getElementsByClassName(document, 'span', 'nocountdown');
for(var i in nocountdowns) nocountdowns[i].style.display = 'none'
var countdowns = getElementsByClassName(document, 'span', 'countdown');
for(var i in countdowns) countdowns[i].style.display = 'inline'
//set up global objects timers and timeouts.
timers = getElementsByClassName(document, 'span', 'countdowndate'); //global
timeouts = new Array(); // generic holder for the timeouts, global
if(timers.length == 0) return;
for(var i in timers) {
timers[i].eventdate = new Date(timers[i].firstChild.nodeValue);
updatetimer(i); //start it up
}
}
addOnloadHook(checktimers);
// **************************************************
// - end - Experimental javascript countdown timer
// **************************************************
/* User Tags */
window.UserTagsJS = {
modules: {},
tags: {
// group: { associated tag data }
founder: { u:'创建者', order: -1/0 },
bureaucrat: { u:'行政员', order: -1/0 },
usermonth: { u:'本月最佳使用者', order: -1/0 },
captures: '海绵宝宝屏幕快取管理者'
}
};
UserTagsJS.modules.custom = {
'AW10': ['captures'],
'Msnhinet8': ['founder'],
};
UserTagsJS.modules.inactive = 30;
UserTagsJS.modules.newuser = true;
UserTagsJS.modules.autoconfirmed = true;
UserTagsJS.modules.mwGroups = ['bureaucrat', 'patroller', 'rollback', 'bannedfromchat', 'bot', 'bot-global', 'assistant', 'moderator'];
/* End of User Tags */
/* AjaxRC */
AjaxRCRefreshText = '自动刷新';
AjaxRCRefreshHoverText = '自动刷新本页面';
ajaxPages = ["Special:RecentChanges", "Special:WikiActivity"];
/* End of AjaxRC */
/* LockForums、LockOldBlogs 與 LockOldComments */
window.LockForums = {
lockMessageWalls: true,
expiryDays: 90
};
window.LockOldBlogs = {
expiryDays: 90
};
/* LockForums、LockOldBlogs 與 LockOldComments 結尾 */
/*
importArticles({ type: 'script', articles: [
'u:dev:Standard_Edit_Summary/code.js'
]});
*/
/* Message Wall User Tags */
window.MessageWallUserTags = {
tagColor: 'red',
glow: true,
glowSize: '15px',
glowColor: '#f77',
users: {
'username': 'usergroup',
'Msnhinet8': '创建者 • 行政员 • 管理员',
'列维劳德': '管理员',
'Laundry Machine': '管理员',
'Wenny086': '管理员'
}
};
/* End of Message Wall User Tags */
var quizName = "海绵百科海绵宝宝小测验";
var quizLang = "zh";
var resultsTextArray = [
"你需要收看更多海绵宝宝!",
"不错。你有相当不错的海绵宝宝知识。",
"你是海绵宝宝专家!"
];
var questions = [
["(截至2020年8月)角色海绵宝宝多大了?",
"34岁",
"28岁",
"20岁",
"16岁"],
["章鱼哥怎么知道帅章鱼的?",
"他们相遇在高中。",
"他们是兄弟。",
"他们在交响乐期间相遇。",
"他们是堂兄弟。"],
["在集数《我要小蜗》中,海绵宝宝买的虫虫名字是什么?",
"雷斯",
"杰利",
"马斯",
"小虫"],
["在集数《会说话的钱》中,蟹老板为了和钱钱说话卖给了飞行荷兰人什么?",
"他的灵魂",
"他的金牙",
"海绵宝宝",
"他的女儿,珍珍"],
["比奇堡位于哪里?",
"太平洋",
"大西洋",
"印度洋",
"荒凉人海"],
["为什么海绵宝宝在凌晨3点来蟹堡王?",
"来数芝麻粒",
"来预热蟹堡",
"来检查警报系统是否在工作",
"去吃宵夜"],
["那首歌在第一部电影中唱过?",
"《我们是大人》",
"《破裤子》",
"《欢乐歌》",
"《露营歌曲》"],
["在《蟹老板去度假》中,导游鱼的名字是什么?",
"比尔",
"吉姆",
"巴克",
"阿乔"],
["珊迪的孪生兄弟名字是什么?",
"兰迪",
"厄尔",
"史考特",
"布兰迪"],
["在集数《圆裤裤》中的日期是什么?",
"1月10日",
"1月7日",
"1月14日",
"1月18日"]
];
/* voting system begin */
var WorldCupIterators = document.getElementsByClassName("WorldCupIterate");
if ( WorldCupIterators.length > 0 ) {
//declaring variables
var HasAllowedUserRights = false;
var AllowedUserRights = ["bureaucrat", "sysop", "assistant", "threadmoderator", "rollback"];
//determining user rights
for (var i = 0; i < AllowedUserRights.length; i++) {
HasAllowedUserRights = wgUserGroups.includes(AllowedUserRights[i]);
if (HasAllowedUserRights) break;
}
//hiding if neccessary
if (!HasAllowedUserRights) {
for (var i = 0; i < WorldCupIterators.length; i++) {
if (!WorldCupIterators[i].innerHTML.includes("Maxed")) {
WorldCupIterators[i].innerHTML = "<div>NoRights</div>";
}
}
}
}
if ( document.getElementById("ScoreVoteCountContainer") !== null ) {
//determining outputWord
var outputWord = document.getElementsByClassName("Notice2")[0].innerHTML.includes("archive") ? "result" : "status";
//collecting all votes
var SupportVoteScores = document.getElementsByClassName("SupportVoteNum");
var NeutralVoteScores = document.getElementsByClassName("NeutralVoteNum");
var OpposeVoteScores = document.getElementsByClassName("OpposeVoteNum");
var votesCount = SupportVoteScores.length + NeutralVoteScores.length + OpposeVoteScores.length;
var votesNumSum = 0;
//processing support votes
for (var i = 0; i < SupportVoteScores.length; i++) {
if (SupportVoteScores[i].innerHTML === "NaN") {
votesCount--;
} else {
votesNumSum += parseInt(SupportVoteScores[i].innerHTML);
}
}
//processing oppose votes
for (var i = 0; i < OpposeVoteScores.length; i++) {
if (OpposeVoteScores[i].innerHTML === "NaN") {
votesCount--;
} else {
votesNumSum -= parseInt(OpposeVoteScores[i].innerHTML);
}
}
//getting configuration
var ScoreVoteCount = document.getElementById("ScoreVoteCount");
var ScoreVoteConfig = ScoreVoteCount.className.split(" ");
var PassScoreRaw = ScoreVoteConfig[0].substring(2);
var PassScore = !isNaN(PassScoreRaw) ? parseInt(PassScoreRaw) / 100.00 : 0.00;
var WordRaw = ScoreVoteConfig[1].substring(1).split(/[0-9]/).slice(1);
var WordZero = WordRaw[0].replace("_"," ");
var WordMinus = WordRaw[1].replace("_"," ");
var WordPlus = WordRaw[2].replace("_"," ");
var TargetNameRaw = ScoreVoteConfig[2].substring(2);
var TargetName = TargetNameRaw.replace("_"," ");
var ResultRaw = ScoreVoteConfig[3].substring(1).split(/[0-9]/).slice(1);
var ResultTrue = ResultRaw[0].replace("_"," ");
var ResultFalse = ResultRaw[1].replace("_"," ");
var ExceptRaw = ScoreVoteConfig[4].substring(1).split(/[0-9]/).slice(1);
var ExceptOne = ExceptRaw[0].toLowerCase();
var ExceptTwo = ExceptRaw[1].toLowerCase();
//vote status helpers
var neutralIcon = '<img src="https://vignette.wikia.nocookie.net/spongebob/images/b/b3/Neutral.png/revision/latest/scale-to-width-down/15?cb=20140913201058" alt="Neutral" height="15" width="15">';
var supportIcon = '<img src="https://vignette.wikia.nocookie.net/spongebob/images/a/ab/Support.png/revision/latest/scale-to-width-down/15?cb=20140913200712" alt="Support" height="15" width="15">';
var opposeIcon = '<img src="https://vignette.wikia.nocookie.net/spongebob/images/b/bc/Oppose.png/revision/latest/scale-to-width-down/15?cb=20140913200954" alt="Oppose" width="15" height="15">';
var CurrScore = Math.round( (votesNumSum / votesCount) * 100 ) / 100;
var CurrScoreStr = !isNaN(CurrScore) ? CurrScore.toFixed(2) : 'ERROR';
var passes = PassScore > 0.00 ? CurrScore >= PassScore : CurrScore > 0.00;
var ExceptInfo = ["zeroicon"];
var ExceptCombRaw = ExceptOne + ExceptTwo;
var ExceptComb = [];
for (var i = 0; i < ExceptInfo.length; i++) {
ExceptComb.push(ExceptCombRaw.includes(ExceptInfo[i]));
}
//defining vote status
var currentVoteStatus = "";
if (ResultTrue !== "" && ResultFalse !== "") {
if (ExceptComb[0]) {
currentVoteStatus += passes ? supportIcon : (CurrScore >= 0.00 ? neutralIcon : opposeIcon);
} else {
currentVoteStatus += passes ? supportIcon : opposeIcon;
}
} else {
currentVoteStatus += CurrScore > 0.00 ? supportIcon : (CurrScore === 0.00 ? neutralIcon : opposeIcon);
}
currentVoteStatus += ' Community';
if (CurrScore < 0.00) {
currentVoteStatus += ' ' + WordMinus;
if (TargetName !== "") {
currentVoteStatus += ' ' + TargetName;
}
} else if (CurrScore > 0.00) {
currentVoteStatus += ' ' + WordPlus;
if (TargetName !== "") {
currentVoteStatus += ' ' + TargetName;
}
} else {
currentVoteStatus += ' is ' + WordZero;
if (TargetName !== "") {
currentVoteStatus += ' towards ' + TargetName;
}
}
if (!currentVoteStatus.includes(WordZero)) {
currentVoteStatus += ' with score "' + CurrScoreStr + '"';
}
if (ResultTrue !== "" && ResultFalse !== "") {
if (CurrScoreStr !== 'ERROR') {
currentVoteStatus += ', ' + outputWord + ' is "' + (passes ? ResultTrue : ResultFalse) + '"';
} else {
currentVoteStatus += ', ' + outputWord + ' is "undefined"';
}
}
currentVoteStatus += '.';
//writing vote status to page
ScoreVoteCount.innerHTML = currentVoteStatus;
}
if ( document.getElementById("ScoreVoteCountContainerMulti") !== null ) {
//determining outputWord
var outputWord = document.getElementsByClassName("Notice2")[0].innerHTML.includes("archive") ? "result" : "status";
//getting configuration
var ScoreVoteCount = document.getElementById("ScoreVoteCount");
var ScoreVoteConfig = ScoreVoteCount.className.split(" ");
var ResultRaw = ScoreVoteConfig[3].substring(1).split(/[0-9]/).slice(1);
var ResultTrue = ResultRaw[0].replace("_"," ");
var ResultNull = ResultRaw[2].replace("_"," ");
var ExceptRaw = ScoreVoteConfig[4].substring(1).split(/[0-9]/).slice(1);
var ExceptOne = ExceptRaw[0].toLowerCase();
var ExceptTwo = ExceptRaw[1].toLowerCase();
//collect exceptions
var ExceptInfo = ["multiresult", "bluegreen", "colorprods"];
var ExceptCombRaw = ExceptOne + ExceptTwo;
var ExceptComb = [];
for (var i = 0; i < ExceptInfo.length; i++) {
ExceptComb.push(ExceptCombRaw.includes(ExceptInfo[i]));
}
//exception variables
var resultExpr = "";
var currProds = [];
var currScores = [];
var keyB = ExceptComb[1] ? document.getElementById("489bce").innerHTML : "";
var keyG = ExceptComb[1] ? document.getElementById("5fa41e").innerHTML : "";
var colorProdsSpan = document.getElementsByClassName("ffffcc");
var colorProds = [];
//collecting all votes
var SupportVoteScores = document.getElementsByClassName("SupportVoteNum");
var NeutralVoteScores = document.getElementsByClassName("NeutralVoteNum");
var OpposeVoteScores = document.getElementsByClassName("OpposeVoteNum");
var dictVotesCount = {};
var dictVotesNumSum = {};
if (ExceptComb[2]) {
for (var keySpan in colorProdsSpan) {
if (colorProdsSpan.hasOwnProperty(keySpan)) {
var key = colorProdsSpan[keySpan].innerHTML; colorProds.push(key);
dictVotesCount[key] = 0.00; dictVotesNumSum[key] = 0.00;
}
}
} else if (ExceptComb[1]) {
dictVotesCount[keyB] = 0.00; dictVotesCount[keyG] = 0.00;
dictVotesNumSum[keyB] = 0.00; dictVotesNumSum[keyG] = 0.00;
}
//processing support votes
for (var i = 0; i < SupportVoteScores.length; i++) {
var key = SupportVoteScores[i].parentElement.className;
if (key === "" && ExceptComb[1]) {
key = SupportVoteScores[i].parentElement.parentElement.parentElement.innerHTML.includes("SupportBlue") ? keyB : keyG;
}
if (!dictVotesCount.hasOwnProperty(key)) {
dictVotesCount[key] = 0;
dictVotesNumSum[key] = 0;
}
if (SupportVoteScores[i].innerHTML !== "NaN") {
dictVotesCount[key] += 1;
dictVotesNumSum[key] += parseInt(SupportVoteScores[i].innerHTML);
}
}
//processing neutral votes
if (!ExceptComb[1]) {
for (var i = 0; i < NeutralVoteScores.length; i++) {
var key = NeutralVoteScores[i].parentElement.className;
if (!dictVotesCount.hasOwnProperty(key)) {
dictVotesCount[key] = 0;
dictVotesNumSum[key] = 0;
}
if (NeutralVoteScores[i].innerHTML !== "NaN") {
dictVotesCount[key] += 1;
}
}
}
//processing oppose votes
for (var i = 0; i < OpposeVoteScores.length; i++) {
var key = OpposeVoteScores[i].parentElement.className;
if (!dictVotesCount.hasOwnProperty(key)) {
dictVotesCount[key] = 0;
dictVotesNumSum[key] = 0;
}
if (OpposeVoteScores[i].innerHTML !== "NaN") {
dictVotesCount[key] += 1;
dictVotesNumSum[key] -= parseInt(OpposeVoteScores[i].innerHTML);
}
}
//defining vote status
var counter = 0;
var currentVoteStatus = "";
var hasError = false;
var tmpCollection = !ExceptComb[2] ? dictVotesCount : colorProds;
for (var key in tmpCollection) {
if (tmpCollection.hasOwnProperty(key)) {
var tmpCurrScore = 0.00, tmpCurrScoreB = 0.00, tmpCurrScoreG = 0.00;
if (ExceptComb[2]) key = colorProds[key];
if (!ExceptComb[1]) {
tmpCurrScore = Math.round( (dictVotesNumSum[key] / dictVotesCount[key]) * 100 ) / 100;
} else if (counter === 0) {
tmpCurrScoreB = dictVotesNumSum[keyB] * (parseFloat(dictVotesCount[keyB]) / (dictVotesCount[keyB] + dictVotesCount[keyG]));
tmpCurrScoreG = dictVotesNumSum[keyG] * (parseFloat(dictVotesCount[keyG]) / (dictVotesCount[keyB] + dictVotesCount[keyG]));
}
if (!ExceptComb[1] && counter > 0) currentVoteStatus += ", ";
if (!ExceptComb[1]) {
currentVoteStatus += '"' + key + '" has score "' + (!isNaN(tmpCurrScore) ? tmpCurrScore.toFixed(2) : 'ERROR') + '"';
} else if (counter === 0) {
currentVoteStatus += '"' + keyB + '" has score "' + (!isNaN(tmpCurrScoreB) ? tmpCurrScoreB : 0.00).toFixed(2) + '", ';
currentVoteStatus += '"' + keyG + '" has score "' + (!isNaN(tmpCurrScoreG) ? tmpCurrScoreG : 0.00).toFixed(2) + '"';
}
if (ExceptComb[0]) {
if (!ExceptComb[1]) {
currProds.push(key);
currScores.push(tmpCurrScore);
} else if (counter === 0) {
currProds.push(keyB); currProds.push(keyG);
currScores.push(tmpCurrScoreB); currScores.push(tmpCurrScoreG);
}
}
if (isNaN(tmpCurrScore)) hasError = true;
counter += 1;
}
}
if (ExceptComb[0]) {
var maxIX = 0;
for (var i = 1; i < currScores.length; i++) {
if (currScores[i] > currScores[maxIX]) maxIX = i;
}
var countMax = 0;
for (var i = 0; i < currScores.length; i++) {
if (currScores[i] === currScores[maxIX]) countMax += 1;
}
if (!hasError) {
resultExpr = ', ' + outputWord + ' is "' + (countMax === 1 ? currProds[maxIX] + ' ' + ResultTrue : ResultNull) + '"';
} else {
resultExpr = ', ' + outputWord + ' is "undefined"';
}
}
if (counter > 0) {
currentVoteStatus += (ExceptComb[0] ? resultExpr : "") + '.';
} else {
currentVoteStatus += 'N/A';
}
//writing vote status to page
document.getElementById("ScoreVoteCount").innerHTML = currentVoteStatus;
}
/* voting system end */
/* timeCircles begin - needs to be HTTPS compliant
mw.hook('wikipage.content').add(function($content) {
$content.find('.TimeCirclesDiv:not(.loaded)').each(function() {
var $this = $(this);
$this.html(
$('<iframe>', {
scrolling: 'no',
src: 'https://spongebobia.com/ESB/TimeCircle/TimeCirclesImport.php?dateTime=' +
mw.html.escape($this.text().slice(1, -1)),
width: '100%',
height: Math.round($this.prop('offsetWidth') / 4) + 'px'
})
);
});
});
/* timeCircles end */