您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Allows you to have more Quickteams
当前为
// ==UserScript== // @name BvS Infinite Quickteams // @namespace rvQuick // @description Allows you to have more Quickteams // @include http://*animecubed.com/billy/bvs/team.html // @version 1.4.1 // @history 1.4.1 (9/9/2014) Added grant permissions. // @history 1.4 Added underline coloring for allies that couldn't be found, making a team unusable. // @history 1.3g Fixed a rare bug. // @history 1.3f Fixed a bug that I created from 1.3e. // @history 1.3e Fixed some of turn the page jutsu. // @history 1.3d Fixed bug where you couldn't drag n' drop newly created teams until you refreshed the page. // @history 1.3c Bug Fix // @history 1.3b Added Drag n' Drop support to the table // @history 1.3a Fixed up Export display. // @history 1.3 Added Export/Import functionality // @history 1.2e Fixed "None" quickteam to bypass confirm screen // @history 1.2d Temporary fix for FF4 bug. // @history 1.2c Improved cross browser support. // @history 1.2b Bug fixes. Hide Team MisAlignment dialog on team rename. // @history 1.2a Confirmed support for Chrome, but Escape doesn't work. // @history 1.2 Fixed more scrolling issues and added script support for other browsers besides FF. // @history 1.1c Fixed scrolling issues when renaming a QT. // @history 1.1b Fixed move QT down exception when there was only 1 QT. // @history 1.1a Fixed up final bug. // @history 1.1 Fixed a bug where you couldn't work with a QT that you didn't have one of the allies for. // @history 1.0 Start // @grant GM_getValue // @grant GM_setValue // @grant GM_addStyle // ==/UserScript== const VERSION = "1.4.1"; const GMSTORAGE_PATH = "BvS_Quickteams_"; var playerData; var playerName; var allies; var startPoint; var currentTeam; var quickteam; var testDiv; var turnThePage; function load(ev) { try { var temp = document.getElementByName("player"); if ((temp == null) || (temp.localName.toLowerCase() == "text") || (temp.value.length == 0)) return; playerName = temp.value; getGM(); parsePage(); applyGM(); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } } function getGM() { var value = GM_getValue(playerName, "{}"); if ((value == undefined) || (value == null) || (value == "")) value = "{}"; playerData = JSON.parse(value); } function saveGM() { GM_setValue(playerName, JSON.stringify(playerData)); } function parsePage() { turnThePage = document.getElementsByName("turnthepage"); if ((turnThePage) && (turnThePage.length == 0)) turnThePage = null; if (document.getElementByName("conteam") == null) { allies = new Array(); snap = document.evaluate("//div/table/tbody/tr/td/label/img", document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null); if ((snap != null) && (snap.snapshotLength > 0)) { var i; for (i = 0; temp = snap.snapshotItem(i); i++) { allies.push(new Array(document.getElementByName("teammate" + i).value, Allies.getAllyName(temp.src))); } } startPoint = document.getElementsByName("quickteam"); if ((startPoint != null) && (startPoint.length == 0)) startPoint = null; currentTeam = new Array(); snap = document.evaluate("//center/center/table/tbody/tr/td/img", document, null, XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null); if ((snap != null) && (snap.snapshotLength > 0)) { var i; for (i = 0; temp = snap.snapshotItem(i); i++) { currentTeam.push(Allies.getAllyName(temp.src)); } } } } function applyGM() { if ((allies != null) && (startPoint == null)) { startPoint = document.getElementByName("qteam"); if (startPoint == null) return; startPoint = startPoint.children[0]; var element = document.createElement('DIV'); var text = "<table><tbody><tr><td style=\"font-family: arial; border: 1px dotted black; padding: 3px;\">"; text += "<b>QuickTeams</b>: <font style=\"font-size: 12px;\">(Select team, and hit \"Use Quickteam\" - bypasses confirmation screen)</font><br>"; text += "<input type=\"radio\" id=\"noneqt\" checked=\"\" value=\"\" name=\"quickteam\"> <label for=\"noneqt\">None</label><br>"; text += "<a style=\"color: rgb(161, 0, 0);\" onfocus=\"this.blur();\" href=\"javascript:document.qteam.submit();\"><b>Use Quickteam ></b></a>"; text += "<noscript><input type=\"submit\" VALUE=\"Use Quickteam\"></noscript>"; text += "<font style=\"font-size: 10px;\"><br>(Teams in <font color=\"#cc0000\">red</font> have allies that are different Levels than listed, so may have different effects)</font>"; text += "</td></tr></tbody></table>"; text += "<br>"; element.innerHTML = text; startPoint.parentNode.insertBefore(element, startPoint.children[startPoint.children - 1]); startPoint = document.getElementsByName("quickteam"); if ((startPoint != null) && (startPoint.length == 0)) startPoint = null; } if (startPoint == null) return; if (turnThePage) { var temp = turnThePage[0]; // remove <br> temp.parentNode.removeChild(temp.nextSibling.nextSibling.nextSibling); // move 'use quickteam over some' var extra = document.createElement('SPAN'); extra.innerHTML = " "; temp.parentNode.insertBefore(extra, temp.nextSibling.nextSibling.nextSibling); } GM_addStyle("div#rvDialog {word-wrap: break-word; overflow: auto; background-image: url('http://www.animecubed.com/billy/layout/scrollbg.jpg'); min-width: 240px; min-height: 100px; z-index: 9002; padding: 0; border: 1px solid black;} #rvDialog h1 {color: white; font-size: 16px; font-weight: bold; padding: 4px; margin: 0; background-image: url('http://www.animecubed.com/billy/layout/scrolldark.jpg');} img#closebutton {float: right; cursor: pointer; margin: 6px;} #rvDialog div {font-size: 12px; font-family: arial; padding: 8px;} #rvDialog a {font-weight: bold; color: #a10000;} #rvDialog ul {margin: 0;} .high { font-weight: bold; color: #FFFF00; text-decoration: blink; } .mhigh { font-weight: bold; color: #00FF00; } .normal { font-weight: bold; } .mlow { font-weight: bold; color: #FF0000; } .low { font-weight: bold; color: #7F0000; text-decoration: line-through; } .special { font-weight: bold; border: 1px dotted white; background-color: #333; }"); document.getElementById("noneqt").value = "^"; ///////////////// var length = startPoint.length; startPoint = startPoint[startPoint.length - 1]; if (length == 1) { startPoint = startPoint.nextSibling.nextSibling.nextSibling.nextSibling; } else { if (startPoint.parentNode.localName == "div") { // BvS Loop Helper no personal teams, 1 GM team startPoint = startPoint.parentNode.nextSibling; } else { startPoint = startPoint.nextSibling.nextSibling; } } quickteam = document.createElement('DIV'); var text = "<table id='rvQT' cellpadding='0' cellspacing='0' width='100%'>"; text += "</table><br><b>New QuickTeam</b>:<br>"; var i; for (i = 0; i < 3; i++) { text += "<select id='rvAlly" + i + "'>"; if (i) text += "<option value='' />"; var j; for (j = 0; j < allies.length; j++) { var level = Allies.getAllyLevel(allies[j][1]); if (level > 1) { var name = Allies.getAllyWithoutLevel(allies[j][1]); var sname = escape(name); text += "<option value='" + sname + "'>" + name + "</option>"; var k; for (k = 2; k < level; k++) { text += "<option value='" + sname + " " + k + "'>" + name + " " + k + "</option>"; } } text += "<option value='" + escape(allies[j][1]) + "'>" + allies[j][1] + "</option>"; } text += "</select>"; } text += " <input id='rvAdd' type='image' src='' alt='Add' width='31' height='15'>"; text += " <input id='rvForm' type='image' src='%3D' alt='Form' width='40' height='15'>"; quickteam.style.borderTop = quickteam.style.borderBottom = "1px dotted black"; quickteam.innerHTML = text; startPoint.parentNode.insertBefore(quickteam, startPoint); tableDnD = new DnDTable(); tableDnD.init(document.getElementById('rvQT')); tableDnD.onStartDragging = function() { this.startRowIndex = this.dragObject.rowIndex; } tableDnD.onDragging = function() { this.dragObject.style.background = "yellow"; } tableDnD.onDrop = function() { this.dragObject.style.background = ""; var endRowIndex = this.dragObject.rowIndex; var pos = this.startRowIndex; if (pos != endRowIndex) { if (endRowIndex < pos) { // move up var diff = pos - endRowIndex; for (; diff > 0; diff--) { playerData["Quickteams"].shiftUp(pos); playerData["QuickteamNames"].shiftUp(pos); pos--; } } else { // move down var diff = endRowIndex - pos; for (; diff > 0; diff--) { playerData["Quickteams"].shiftDown(pos); playerData["QuickteamNames"].shiftDown(pos); pos++; } } saveGM(); updateNumbers(); } } var extra = document.createElement('SPAN'); text = " "; text += "<a id='rvExport' href='javascript:;' style='color:A10000'><b>Export ></b></a>"; text += " "; text += " "; text += "<a id='rvImport' href='javascript:;' style='color:A10000'><b>Import ></b></a>"; if (turnThePage) { text += "<br />"; } extra.innerHTML = text; if (turnThePage) { startPoint.parentNode.insertBefore(extra, startPoint.nextSibling); } else { startPoint.parentNode.insertBefore(extra, startPoint.nextSibling.nextSibling); } redoQuickteamList(); document.getElementById("rvAdd").addEventListener("click", addNewQuickteam, true); document.getElementById("rvForm").addEventListener("click", formTeam, true); document.getElementById("rvExport").addEventListener("click", exportQuickteams, true); document.getElementById("rvImport").addEventListener("click", importQuickteams, true); ///////////////// testDiv = document.createElement('DIV'); testDiv.style.opacity = 0; testDiv.style.fontFamily = "arial"; testDiv.style.fontWeight = "bold"; testDiv.style.display = "inline"; document.body.insertBefore(testDiv, null); ///////////////// startPoint = document.getElementByName("quickteamnumber"); if (startPoint != null) { var table = startPoint.parentNode.parentNode.parentNode.parentNode.parentNode; table.cellSpacing = "0"; table.cellPadding = "0"; var empty = table.insertRow(table.rows.length).insertCell(0); empty.style.height = "10"; empty.style.backgroundColor = "#ead8c3"; var row = table.insertRow(table.rows.length); var element = row.insertCell(0); element.align = "center"; element.style.backgroundColor = "#ead8c3"; element.style.fontFamily = "arial"; element.innerHTML = "<form style='margin: 0pt;'>Save current team as a GM Quickteam: <input id='rvAddCurrent' type='image' src='' alt='Add' width='31' height='15'></form>"; document.getElementById("rvAddCurrent").addEventListener("click", addCurrentQuickteam, true); } } var tableDnD = null; function redoQuickteamList() { try { var table = document.getElementById("rvQT"); while (table.rows.length > 0) { table.deleteRow(0); } if (playerData["Quickteams"] != null) { var i; for (i = 0; i < playerData["Quickteams"].length; i++) { createQuickTeam(playerData["Quickteams"][i], playerData["QuickteamNames"][i], i+1); tableDnD.makeDraggable(table.rows[i]); } } } catch(e) { alert("Exception when Loading QuickTeams!\n\nError name: " + e.name + "\nError message: " + e.message); } } var dialog = null; var dialogHeader = null; var dialogText = null; function exportQuickteams(ev) { try { if (dialog == null) { dialog = document.createElement("div"); dialog.style.visibility = "hidden"; dialog.id = "rvDialog"; dialog.innerHTML = "<img id='closebutton' onclick=\"document.getElementById('rvDialog').style.visibility='hidden';\" title='Close' src='data:image/png,%89PNG%0D%0A%1A%0A%00%00%00%0DIHDR%00%00%00%10%00%00%00%10%08%03%00%00%00(-%0FS%00%00%00%01sRGB%00%AE%CE%1C%E9%00%00%00TPLTE%BA%0C%0C%BF%1D%1D%C1%26%26%C1((%C1))%C8%3D%3D%C8%3F%3F%CBHH%CDPP%D6nn%DC%83%83%DD%89%89%DE%89%89%E2%98%98%E4%A0%A0%EC%BA%BA%F1%CB%CB%F3%D7%D7%F4%D7%D7%F6%E1%E1%F7%E3%E3%FB%F0%F0%FB%F2%F2%FB%F3%F3%FC%F6%F6%FE%FB%FB%FE%FE%FE%FF%FF%FFD%88%E1%E1%00%00%00rIDAT%18%D3%5D%CFY%0E%80%20%10%03%D0%BA%E0%8E%8A%0A(%BD%FF%3D%8Da%08%EA%FC%F5%25M%3A%08%FC%5C%00%F19%3EP%A5T%09lK%CC%CB%26%80%F9%EC%80%EE%9CS%05%188%8E%1C%90%01%139%E1%05%E5N%EEe%86%C6q%5D%E9%9A%04%B5%E7%01%1C%F4%B5%80%E5%A5%00u%D1Fh%03%F5S%D7%0C%AD%80%89%C3%8C%00%FA%22B%D1%E7%1D%AF%E7%FE%EF%DF%8Eb%0A%CB%F1%17%10%11%00%00%00%00IEND%AEB%60%82' />"; dialogHeader = document.createElement("h1"); dialogText = document.createElement("div"); dialog.appendChild(dialogHeader); dialog.appendChild(dialogText); document.body.appendChild(dialog); } centerdiv(dialog, "300", "200"); dialogText.innerHTML = "<textarea rows='3' id='rvExportText' readOnly='true' style='background: #ccc; width: 100%; height: 150px;'>" + JSON.stringify(playerData).sanitizeHTML() + "</textarea>"; dialogHeader.innerHTML = "Infinite QuickTeams Export"; dialog.style.visibility = "visible"; selectAll("rvExportText"); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function importQuickteams(ev) { try { var input = prompt("Enter your saved 'Infinite QuickTeams' Export:", ""); if ((input != null) && (input != "")) { var failed = false; var newData = null; try { newData = JSON.parse(input); failed = ((newData == undefined) || (newData == null)); } catch (e) { failed = true; } if (failed) { alert("Failed to understand the Import text!"); } else { playerData = newData; saveGM(); redoQuickteamList(); } } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function formTeam(ev) { try { var ally1 = unescape(document.getElementById("rvAlly0").value); var ally2 = unescape(document.getElementById("rvAlly1").value); var ally3 = unescape(document.getElementById("rvAlly2").value); if ((ally2 == "") && (ally3 != "")) { ally2 = ally3; ally3 = ""; } var spot = document.getElementByName("quickteam"); spot = spot.nextSibling.nextSibling.nextSibling.nextSibling; var element = document.createElement('DIV'); var text = "<input type='radio' id='rvTempQT' value='"; ally1 = Allies.get(Allies.getAllyWithoutLevel(ally1)); text += ally1[0]; if (ally2 != "") { ally2 = Allies.get(Allies.getAllyWithoutLevel(ally2)); text += "^" + ally2[0]; } if (ally3 != "") { ally3 = Allies.get(Allies.getAllyWithoutLevel(ally3)); text += "^" + ally3[0]; } text += "' name='quickteam'><b>Temporary Quickteam</b><br>"; element.innerHTML = text; spot.parentNode.insertBefore(element, spot); document.getElementById("rvTempQT").checked = true; } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } return true; } function addCurrentQuickteam(ev) { try { var newQT = currentTeam; if (newQT.length != 0) { while (newQT.length < 3) newQT.push(""); genericAddNewQuickteam(newQT); redoQuickteamList(); } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function addNewQuickteam(ev) { try { var ally1 = unescape(document.getElementById("rvAlly0").value); var ally2 = unescape(document.getElementById("rvAlly1").value); var ally3 = unescape(document.getElementById("rvAlly2").value); var cancel = false; if ((ally2 == "") && (ally3 != "")) { ally2 = ally3; ally3 = ""; } if ((Allies.equals(ally1, ally2)) || (Allies.equals(ally1, ally3)) || ((Allies.equals(ally2, ally3)) && (ally2 != ""))) { alert("Invalid QuickTeam."); cancel = true; } if (!cancel) { var newQT = new Array(ally1, ally2, ally3); genericAddNewQuickteam(newQT); redoQuickteamList(); } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function genericAddNewQuickteam(newQT) { if (playerData["Quickteams"] == null) { playerData["Quickteams"] = new Array(); playerData["QuickteamNames"] = new Array(); } var existing = playerData["Quickteams"].getPos(newQT); if (existing != -1) { alert("Quickteam is already in use in position #" + existing + ", named '" + (playerData["QuickteamNames"][existing] == "" ? "GM Quickteam " + (existing+1) : playerData["QuickteamNames"][existing]) + "'."); return; } var newName = ""; createQuickTeam(newQT, newName, playerData["Quickteams"].length+1); playerData["QuickteamNames"].push(newName); playerData["Quickteams"].push(newQT); saveGM(); } function createQuickTeam(qt, name, number) { var table = document.getElementById("rvQT"); var row = table.insertRow(table.rows.length); var element = row.insertCell(0); var valid = true; var svalid = new Array(true, true, true) var same = new Array(); var id = ""; var allyNames = ""; var allyNamesNow = ""; var realAllyNames = new Array(); var i; for (i = 0; i < 3; i++) { if (qt[i] == "") { same.push(true); continue; } var ally = Allies.get(Allies.getAllyWithoutLevel(qt[i])); if (i > 0) allyNames += ", "; allyNames += qt[i]; if (ally == null) { valid = false; svalid[i] = false; } else { if (i > 0) { id += "^"; allyNamesNow += ", "; } id += ally[0]; allyNamesNow += ally[1]; realAllyNames.push(ally[1]); if (qt[i] == ally[1]) { same.push(true); } else { same.push(false); } } } var allyNamesColor = ""; for (i = 0; i < 3; i++) { if (qt[i] == "") continue; if (i > 0) { allyNamesColor += ", "; } if (valid) { if (same[i]) allyNamesColor += realAllyNames[i]; else allyNamesColor += "<font color='#cc0000'><i>" + realAllyNames[i] + "</i></font>"; } else { if (!svalid[i]) allyNamesColor += "<span style='border-bottom: 1px solid red;'>"; allyNamesColor += qt[i]; if (!svalid[i]) allyNamesColor += "</span>"; } } var enames = escape(allyNames); var teamName = (name == "" ? "GM Quickteam" : name); var allsame = (same[0]) && (same[1]) && (same[2]); var coloring = ((allsame) || (!valid) ? "#000000" : "#cc0000"); var text = ""; text += "<input type='radio' id='" + id + "' value='" + id + "' name='quickteam'" + (valid ? "" : " disabled") + ">"; text += "<input type='text' id='nname" + enames + "' value='" + teamName + "' style='color: " + coloring + "; outline: none; font-weight: bold; font-family: arial; font-size: 100%; display: none; border: 0px; background: none;' onfocus='var evt = new Object(); evt.target = document; moveMouse(evt); return true;'>"; if (valid) { text += "<label for='" + id + "'>"; if (!allsame) text += "<span title='header=[Team Misalignment ] body=[Original Team: " + allyNames.replaceAll("'", "'") + " <br>Changed to: " + allyNamesNow.replaceAll("'", "'") + " ] offsetx=[0] offsety=[18] redswitch=[1] offsety=[-10]'>"; } text += "<b style='color: " + coloring + ";'><div id='name" + enames + "' style='display: inline'>"; text += teamName.sanitizeHTML(); text += "</div>"; text += " <div name='rvQTNumber' style='display: inline'>"; if (name != "") text += "("; text += number; if (name != "") text += ")"; text += "</div></b>"; if ((!allsame) && (valid)) text += "</span>"; text += ": <font style='font-size: 12px;'>"; text += allyNamesColor; text += "<br></font>"; if (valid) text += "</label>"; element.innerHTML = text; element = row.insertCell(1); element.style.borderLeftStyle = "dotted"; element.style.textAlign = "right"; element.setAttribute("NoDrag", "true", 0); element.innerHTML = "<img id='down" + enames + "' alt='Move Down' src='%3D' width='12' height='14' style='cursor: pointer;'>" + " <img id='up" + enames + "' alt='Move Up' src='%3D%3D' width='12' height='14' style='cursor: pointer;'>" + " <img id='delete" + enames + "' alt='Remove' src='/billy/layout/xremove.gif' style='cursor: pointer;'>"; document.getElementById("name" + enames).addEventListener("dblclick", renameQuickteam, true); document.getElementById("nname" + enames).addEventListener("blur", endQuickteamEdit, true); document.getElementById("nname" + enames).addEventListener("keydown", keydownQuickteamEdit, true); document.getElementById("nname" + enames).addEventListener("keypress", keypressQuickteamEdit, true); document.getElementById("nname" + enames).addEventListener("keyup", keyupQuickteamEdit, true); document.getElementById("nname" + enames).addEventListener("cut", cutQuickteamEdit, true); //document.getElementById("nname" + enames).addEventListener("paste", changeQuickteamEdit, true); document.getElementById("down" + enames).addEventListener("click", moveQuickteamDown, true); document.getElementById("up" + enames).addEventListener("click", moveQuickteamUp, true); document.getElementById("delete" + enames).addEventListener("click", removeQuickteam, true); } var currentlyEditing; function renameQuickteam(ev) { try { if (currentlyEditing != null) { endQuickteamEdit(); } currentlyEditing = this.id; var width = this.offsetWidth; var height = this.offsetHeight; this.style.display = "none"; var edit = document.getElementById("n" + currentlyEditing); edit.value = this.textContent; edit.style.height = height + "px"; edit.style.width = (width+3) + "px"; edit.style.display = ""; edit.focus(); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function endQuickteamEdit(save) { try { if (currentlyEditing == null) return; var id = currentlyEditing; currentlyEditing = null; var edit = document.getElementById("n" + id); var text = document.getElementById(id); var newName = edit.value; edit.style.display = 'none'; if (newName == "GM Quickteam") newName = ""; if (save == false) { //edit.value = text.textContent; // this isn't possible with onkeypress } else if (newName != text.textContent) { var qt = getQTFromId(text, 4); var existing = playerData["Quickteams"].getPos(qt); if (existing != -1) { playerData["QuickteamNames"][existing] = newName; saveGM(); } edit.value = (newName == "" ? "GM Quickteam" : newName); text.innerHTML = edit.value.sanitizeHTML(); var num = text.parentNode; num = num.childNodes[num.childNodes.length - 1]; if (num.textContent.charAt(0) != '(') { if (newName != "") num.innerHTML = "(" + num.textContent + ")"; } else if (newName == "") { num.innerHTML = num.textContent.replace("(","").replace(")",""); } } text.style.display = 'inline'; text.focus(); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } } function keydownQuickteamEdit(ev) { return keypressQuickteamEdit(ev, true); } function keypressQuickteamEdit(ev, keydown) { var rtrn = true; keydown = (keydown == true ? true : false); var obj = ev.currentTarget; try { if (ev != null) { switch (ev.keyCode) { case 27: // escape if (ev && ev.preventDefault) ev.preventDefault(); rtrn = false; endQuickteamEdit(false); break; case 13: // enter if (ev && ev.preventDefault) ev.preventDefault(); endQuickteamEdit(); break; case 46: // delete case 8: // backspace var start = obj.selectionStart; var end = obj.selectionEnd; if (start == end) { if (ev.keyCode == 46) end++; else start--; } testDiv.innerHTML = (obj.value.substring(0, start) + obj.value.substring(end)).sanitizeHTML(); obj.style.width = (testDiv.offsetWidth+3) + "px"; break; default: if (keydown) break; var char = String.fromCharCode((ev.charCode ? ev.charCode : ev.which)); //document.getElementByName("rvQTNumber").innerHTML // = ev.keyCode + "," + ev.charCode + "," + ev.which + "," + ev.shiftKey + "," + ev.ctrlKey + "," + String.fromCharCode(ev.keyCode) + "," + char; if ((!ev.ctrlKey) && (char.isPrintable())) { testDiv.innerHTML = (obj.value + char).sanitizeHTML(); obj.style.width = (testDiv.offsetWidth+3) + "px"; } } } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } return rtrn; } function keyupQuickteamEdit(ev) { try { testDiv.innerHTML = this.value.sanitizeHTML(); this.style.width = (testDiv.offsetWidth+3) + "px"; } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } } function cutQuickteamEdit(ev) { try { var start = this.selectionStart; var end = this.selectionEnd; if (start != end) { testDiv.innerHTML = (this.value.substring(0, start) + this.value.substring(end)).sanitizeHTML(); this.style.width = (testDiv.offsetWidth+3) + "px"; } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } } function moveQuickteamDown(ev) { try { var qt = getQTFromId(this, 4); var existing = playerData["Quickteams"].getPos(qt); moveTableRowDown(this.parentNode.parentNode); playerData["Quickteams"].shiftDown(existing); playerData["QuickteamNames"].shiftDown(existing); saveGM(); updateNumbers(); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function moveQuickteamUp(ev) { try { var qt = getQTFromId(this, 2); var existing = playerData["Quickteams"].getPos(qt); moveTableRowUp(this.parentNode.parentNode); playerData["Quickteams"].shiftUp(existing); playerData["QuickteamNames"].shiftUp(existing); saveGM(); updateNumbers(); } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function removeQuickteam(ev) { try { var qt = getQTFromId(this, 6); var existing = playerData["Quickteams"].getPos(qt); if (existing != -1) { this.parentNode.parentNode.parentNode.deleteRow(existing); playerData["Quickteams"].splice(existing, 1); playerData["QuickteamNames"].splice(existing, 1); saveGM(); updateNumbers(); } } catch(e) { alert("Exception!\n\nError name: " + e.name + "\nError message: " + e.message); } if (ev && ev.preventDefault) ev.preventDefault(); return false; } function getQTFromId(elem, cut) { var qt = unescape(elem.id.substring(cut)).split(", "); while (qt.length < 3) qt.push(""); return qt; } function updateNumbers() { var elems = document.getElementsByName("rvQTNumber"); if (elems == null) return; var i; for (i = 0; i < elems.length; i++) { if (elems[i].textContent.charAt(0) == '(') elems[i].textContent = "(" + (i+1) + ")"; else elems[i].textContent = (i+1); } } function moveTableRowUp(node) { var prevRow = node.previousSibling; var tableNode = node.parentNode; var remove = tableNode.removeChild(node); tableNode.insertBefore(remove, prevRow); return (prevRow == null); } function moveTableRowDown(node) { var nextRow = node.nextSibling; var tableNode = node.parentNode; var rtrn = nextRow == null; if (rtrn) nextRow = tableNode.firstChild; else nextRow = nextRow.nextSibling; if (nextRow == node) return true; var remove = tableNode.removeChild(node); tableNode.insertBefore(remove, nextRow); return rtrn; } var Allies = new Object(); Allies.getAllyName = function(src) { var pos = src.lastIndexOf("/")+1; var text = src.substring(pos).replaceAll("_", " ").replaceAll(" Lvl. ", " ").replaceAll("%27", "'").replace("ss\\.gif", "").replace(/\.gif/, ""); return text; }; Allies.getAllyWithoutLevel = function(name) { if (name.match(" \\d+$")) { var pos = name.lastIndexOf(" "); return name.substring(0, pos); } return name; }; Allies.getPos = function(name) { if (allies != null) { var i; for (i = 0; i < allies.length; i++) { if (Allies.equals(name, allies[i][1])) return i; } } return -1; }; Allies.get = function(name) { var pos = Allies.getPos(name); if (pos == -1) return null; return allies[pos]; }; Allies.getAllyLevel = function(name) { var match; if (match = name.match(" (\\d+)")) { return parseInt(match[1]); } return 1; }; Allies.equals = function(input, arraytest) { if (arraytest == null) return (input == null); return (arraytest.match("^" + input + "( \\d+)?$") != null); }; function selectAll(id) { document.getElementById(id).focus(); document.getElementById(id).select(); } function centerdiv(div, Xwidth, Yheight) { // First, determine how much the visitor has scrolled /*var scrolledX, scrolledY; if( self.pageYoffset ) { scrolledX = self.pageXoffset; scrolledY = self.pageYoffset; } else if( document.documentElement && document.documentElement.scrollTop ) { scrolledX = document.documentElement.scrollLeft; scrolledY = document.documentElement.scrollTop; } else if( document.body ) { scrolledX = document.body.scrollLeft; scrolledY = document.body.scrollTop; }*/ // Next, determine the coordinates of the center of browser's window var centerX, centerY; if( self.innerHeight ) { centerX = self.innerWidth; centerY = self.innerHeight; } else if( document.documentElement && document.documentElement.clientHeight ) { centerX = document.documentElement.clientWidth; centerY = document.documentElement.clientHeight; } else if( document.body ) { centerX = document.body.clientWidth; centerY = document.body.clientHeight; } if (Yheight.substring(Yheight.length-1) == "%") Yheight = parseInt(Yheight) / 100 * centerY; if (Xwidth.substring(Xwidth.length-1) == "%") Xwidth = parseInt(Xwidth) / 100 * centerX; // Xwidth is the width of the div, Yheight is the height of the // div passed as arguments to the function: var leftoffset = /*scrolledX + */(centerX - Xwidth) / 2; var topoffset = /*scrolledY + */(centerY - Yheight) / 2; // The initial width and height of the div can be set in the // style sheet with display:none; divid is passed as an argument to // the function var r = div.style; r.position = 'fixed'; r.top = topoffset + 'px'; r.left = leftoffset + 'px'; r.width = Xwidth + 'px'; r.height = Yheight + 'px'; } document.getElementByName = function(str) { var rtrn = document.getElementsByName(str); if ((rtrn == null) || (rtrn.length == 0)) return null; return rtrn[0]; }; String.prototype.replaceAll = function(str, str2) { return (this.replace(new RegExp(str, "g"), str2)); }; String.prototype.isPrintable = function() { return (this.match(/[\x00-\x1F\x80-\xFF]/) == null); }; String.prototype.sanitizeHTML = function() { return (this.replaceAll("&", "&").replaceAll(" ", " ").replaceAll("<", "<").replaceAll(">", ">")); }; Array.prototype.swap = function (x,y) { var b = this[x]; this[x] = this[y]; this[y] = b; return this; } Array.prototype.shiftUp = function (pos) { if (pos == 0) { this.push(this.shift()); } else { this.swap(pos, pos - 1); } } Array.prototype.shiftDown = function (pos) { if (pos == this.length - 1) { this.unshift(this.pop()); } else { this.swap(pos, pos + 1); } } Array.prototype.getPos = function(obj) { var i = this.length; while (i--) { if (isArray(this[i])) { if ((isArray(obj)) && (this[i].length == obj.length)) { var j; for (j = 0; j < obj.length; j++) { if (this[i][j] != obj[j]) break; } if (j == obj.length) return i; } } if (this[i] === obj) { return i; } } return -1; }; function isArray(obj) { return obj.constructor == Array; } function DnDTable() { this.init = false; this.table = null; this.dragObject = null; this.dragPosition = null; this.oldY = 0; // attach to table this.init = function (table) { // can't run this script without the event listeners if (!window.addEventListener) { return; } this.table = table; this.init = true; var self = this; // make rows draggable var rows = table.rows; var i; for (i = 0; i < rows.length; i++) { this.makeDraggable(rows[i]); } window.addEventListener('mousemove', function (ev) { return self.onMouseMove(ev || window.event); } ,false); window.addEventListener('mouseup', function (ev) { return self.onMouseUp(ev || window.event); } ,false); } // make a element in the table draggable this.makeDraggable = function (item) { if ((!item) || (!this.init)) return; var nodrag = item.getAttribute("NoDrag"); if ((nodrag != null) && (nodrag != "undefined")) return; var self = this; var cells = item.cells; var i; for (i = 0; i < cells.length; i++) { var cell = cells[i]; var nodrag = cell.getAttribute("NoDrag"); if ((nodrag == null) || (nodrag == "undefined")) { cell.addEventListener('mousedown', function (ev) { // // allow normal processing on form controls // var targetName = this.getEventSource(ev).tagName.toUpperCase(); // // if ((targetName == 'INPUT') || (targetName == 'SELECT') || (targetName == 'TEXTAREA')) // return true; if (self.dragObject != null) { return self.onMouseUp(ev); } else { self.dragObject = item; self.mouseOffset = self.getMouseOffset(this, ev); if (self.onStartDragging) { self.onStartDragging(); } } if (ev && ev.preventDefault) ev.preventDefault(); return false; } ,false); cell.style.cursor = "move"; } } } this.getEventSource = function getEventSource(evt) { if (window.event) { return window.event.srcElement; // For IE } else { return evt.target; // For Firefox } } this.onMouseMove = function (ev) { if (this.dragObject) { var mousePos = this.mouseCoords(ev); var y = mousePos.y - this.mouseOffset.y; if (y != this.oldY) { var movingDown = y > this.oldY; this.oldY = y; // If we're over a row then move the dragged row to there so that the user sees the effect dynamically var currentRow = this.findDropTargetRow(y); if (this.onDragging) this.onDragging(currentRow); if ((currentRow) && (this.dragObject != currentRow)) { if (movingDown) { this.dragObject.parentNode.insertBefore(this.dragObject, currentRow.nextSibling); } else { this.dragObject.parentNode.insertBefore(this.dragObject, currentRow); } } } } return false; } this.onMouseUp = function (ev) { if (this.dragObject) { if (this.onDrop) this.onDrop(); this.dragObject = null; } if (ev && ev.preventDefault) ev.preventDefault(); return false; } // get the mouse offset from the element's position this.getMouseOffset = function (target, ev) { ev = ev || window.event; var docPos = this.getPosition(target); var mousePos = this.mouseCoords(ev); return {x:mousePos.x - docPos.x, y:mousePos.y - docPos.y}; } // get the position of an element by going up the DOM tree and adding up all the offsets this.getPosition = function (e) { var left = 0; var top = 0; // Safari fix if (e.offsetHeight == 0) { /** Safari 2 doesn't correctly grab the offsetTop of a table row this is detailed here: http://jacob.peargrove.com/blog/2006/technical/table-row-offsettop-bug-in-safari/ the solution is likewise noted there, grab the offset of a table cell in the row - the firstChild. note that firefox will return a text node as a first child, so designing a more thorough solution may need to take that into account, for now this seems to work in firefox, safari, ie */ e = e.firstChild; // a table cell } while (e.offsetParent) { left += e.offsetLeft; top += e.offsetTop; e = e.offsetParent; } left += e.offsetLeft; top += e.offsetTop; return {x:left, y:top}; } // get the mouse coordinates from the event this.mouseCoords = function (ev) { if ((ev.pageX) || (ev.pageY)) { return {x:ev.pageX, y:ev.pageY}; } return {x:ev.clientX + document.body.scrollLeft - document.body.clientLeft, y:ev.clientY + document.body.scrollTop - document.body.clientTop}; } // this.findDropTargetRow = function (y) { var rows = this.table.rows; var i; for (i = 0; i < rows.length; i++) { var row = rows[i]; var nodrop = row.getAttribute("NoDrop"); if ((nodrop == null) || (nodrop == "undefined")) { var rowY = this.getPosition(row).y; var rowHeight; if (row.offsetHeight == 0) { rowY = this.getPosition(row.firstChild).y; rowHeight = parseInt(row.firstChild.offsetHeight); } else { rowHeight = parseInt(row.offsetHeight); } rowHeight /= 2; // we need to offset the height a bit because we are inserting before if ((y > rowY - rowHeight) && (y < rowY + rowHeight)) { return row; } } } return null; } this.endDragging = function () { if (this.dragObject != null) self.onMouseUp(ev); } // this function is called when you start dragging a row, so redefine it in your code to do whatever you want // takes 0 parameters this.onStartDragging = null; // this function is called when a row is being dragged, so redefine it in your code to do whatever you want // takes 1 parameters: row hovering over in table this.onDragging = null; // this function is called when you drop a row, so redefine it in your code to do whatever you want // takes 0 parameters this.onDrop = null; } var gvar = new Object(); function GM_ApiBrowserCheck() { if (typeof(unsafeWindow) == 'undefined') { unsafeWindow=window; } if (typeof(GM_log) == 'undefined') { GM_log = function(msg) { try { unsafeWindow.console.log('GM_log: ' + msg); } catch(e) {} }; } GM_clog = function(msg) { if (arguments.callee.counter) { arguments.callee.counter++; } else { arguments.callee.counter=1; } GM_log('('+arguments.callee.counter+') '+msg); } GM_addGlobalStyle = function(css) { var sel = document.createElement('style'); sel.setAttribute('type','text/css'); sel.appendChild(document.createTextNode(css)); var hel = document.documentElement.firstChild; while (hel && hel.nodeName != 'HEAD') { hel=hel.nextSibling; } if (hel && hel.nodeName == 'HEAD') { hel.appendChild(sel); } else { document.body.insertBefore(sel,document.body.firstChild); } return sel; } var needApiUpgrade=false; if(window.navigator.appName.match(/^opera/i) && typeof(window.opera) != 'undefined') { needApiUpgrade=true; gvar.isOpera=true; GM_log=window.opera.postError; GM_log('Opera detected...'); } if(typeof(GM_setValue) != 'undefined') { try { var gsv=GM_setValue.toString(); if (gsv.indexOf('staticArgs') > 0) { gvar.isGreaseMonkey = true; GM_log('GreaseMonkey Api detected...'); } else if (gsv.match(/not\s+supported/)) { needApiUpgrade = true; gvar.isBuggedChrome = true; GM_log('Bugged Chrome GM Api detected...'); } } catch(e) { gvar.isGreaseMonkey = (typeof(GM_setValue) == 'function'); if (gvar.isGreaseMonkey) GM_log('GreaseMonkey Api is assumed because of exception...'); else needApiUpgrade = true; } } else { needApiUpgrade=true; GM_log('No GM Api detected...'); } if(needApiUpgrade) { GM_log('Try to recreate needed GM Api...'); var ws = null; try { ws=typeof(unsafeWindow.localStorage); unsafeWindow.localStorage.length; } catch(e) { ws=null; } // Catch Security error if (ws=='object') { GM_log('Using localStorage for GM Api.'); GM_getValue=function(name,defValue) { var value=unsafeWindow.localStorage.getItem(GMSTORAGE_PATH+name); if(value==null) { return defValue; } else { switch(value.substr(0,2)) { case 'S]': return value.substr(2); case 'N]': return parseInt(value.substr(2)); case 'B]': return value.substr(2)=='true'; } } return value; } GM_setValue=function(name,value) { switch (typeof(value)) { case 'string': unsafeWindow.localStorage.setItem(GMSTORAGE_PATH+name,'S]'+value); break; case 'number': if(value.toString().indexOf('.')<0) { unsafeWindow.localStorage.setItem(GMSTORAGE_PATH+name,'N]'+value); } break; case 'boolean': unsafeWindow.localStorage.setItem(GMSTORAGE_PATH+name,'B]'+value); break; } } GM_deleteValue=function(name) { unsafeWindow.localStorage.removeItem(GMSTORAGE_PATH+name); } } else if(!gvar.isOpera || typeof(GM_setValue)=='undefined') { GM_log('Using temporarilyStorage for GM Api.'); gvar.temporarilyStorage=new Array(); GM_getValue=function(name,defValue) { if(typeof(gvar.temporarilyStorage[GMSTORAGE_PATH+name])=='undefined') { return defValue; } else { return gvar.temporarilyStorage[GMSTORAGE_PATH+name]; } } GM_setValue=function(name,value) { switch (typeof(value)) { case "string": case "boolean": case "number": gvar.temporarilyStorage[GMSTORAGE_PATH+name]=value; } } GM_deleteValue=function(name) { delete gvar.temporarilyStorage[GMSTORAGE_PATH+name]; }; } if(typeof(GM_addStyle)=='undefined') { GM_addStyle=function(css) { var heads = document.getElementsByTagName("head"); if (heads.length > 0) { var node = document.createElement("style"); node.type = "text/css"; node.appendChild(document.createTextNode(css)); heads[0].appendChild(node); } } } if(typeof(GM_openInTab)=='undefined') { GM_openInTab=function(url) { unsafeWindow.open(url,""); } } if(typeof(GM_registerMenuCommand)=='undefined') { GM_registerMenuCommand=function(name,cmd) { GM_log("Notice: GM_registerMenuCommand is not supported."); } } // Dummy if(!gvar.isOpera || typeof(GM_xmlhttpRequest)=='undefined') { GM_log('Using XMLHttpRequest for GM Api.'); GM_xmlhttpRequest=function(obj) { var request=new XMLHttpRequest(); request.onreadystatechange=function() { if(obj.onreadystatechange) { obj.onreadystatechange(request); }; if(request.readyState==4 && obj.onload) { obj.onload(request); } } request.onerror=function() { if(obj.onerror) { obj.onerror(request); } } try { request.open(obj.method,obj.url,true); } catch(e) { if(obj.onerror) { obj.onerror( {readyState:4,responseHeaders:'',responseText:'',responseXML:'',status:403,statusText:'Forbidden'} ); }; return; } if(obj.headers) { for(name in obj.headers) { request.setRequestHeader(name,obj.headers[name]); } } request.send(obj.data); return request; } } } } function waitForReady(callback) { var docState; try { docState = unsafeWindow.document.readyState; } catch(e) { docState = null; } if(docState) { if ((docState != 'complete') && (docState != 'interactive')) { window.setTimeout(waitForReady, 150, callback); return; } } callback(); } GM_ApiBrowserCheck(); waitForReady(load);