|
|
|
|
@@ -1,3 +1,8 @@
|
|
|
|
|
let tomorrow = new Date(new Date().getTime() + 24*60*60*1000);
|
|
|
|
|
tomorrow.setHours(0, 0, 0, 0);
|
|
|
|
|
let afterTomorrow = new Date(tomorrow.getTime() + 24*60*60*1000);
|
|
|
|
|
let movingDuration = 0;
|
|
|
|
|
|
|
|
|
|
function num(s) {
|
|
|
|
|
return parseInt(s.replace(".", ""));
|
|
|
|
|
}
|
|
|
|
|
@@ -18,25 +23,54 @@ function str(n) {
|
|
|
|
|
return s.replace(/^0+/, "");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createRow(key, value) {
|
|
|
|
|
let keyCell = document.createElement("td");
|
|
|
|
|
keyCell.textContent = key;
|
|
|
|
|
function createCustomElement(tag, attrs, text, style) {
|
|
|
|
|
let elt = document.createElement(tag);
|
|
|
|
|
if (attrs) {
|
|
|
|
|
for (let [key, value] of Object.entries(attrs)) {
|
|
|
|
|
if (value !== null) {
|
|
|
|
|
elt.setAttribute(key, value.toString());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (text) {
|
|
|
|
|
elt.textContent = text.toString();
|
|
|
|
|
}
|
|
|
|
|
if (style) {
|
|
|
|
|
for (let [key, value] of Object.entries(style)) {
|
|
|
|
|
elt.style[key] = value.toString();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return elt;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let valueCell = document.createElement("td");
|
|
|
|
|
valueCell.textContent = value;
|
|
|
|
|
function createCustomInput(type, name, value, attrs, style) {
|
|
|
|
|
let mergedAttrs = {};
|
|
|
|
|
if (attrs) {
|
|
|
|
|
mergedAttrs = attrs;
|
|
|
|
|
}
|
|
|
|
|
mergedAttrs["type"] = type;
|
|
|
|
|
if (name) {
|
|
|
|
|
mergedAttrs["name"] = name;
|
|
|
|
|
}
|
|
|
|
|
if (value) {
|
|
|
|
|
mergedAttrs["value"] = value;
|
|
|
|
|
}
|
|
|
|
|
return createCustomElement("input", mergedAttrs, null, style);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let row = document.createElement("tr");
|
|
|
|
|
function createKeyValueRow(key, value) {
|
|
|
|
|
let row = createCustomElement("tr");
|
|
|
|
|
let keyCell = createCustomElement("td", null, key);
|
|
|
|
|
let valueCell = createCustomElement("td", null, value);
|
|
|
|
|
row.appendChild(keyCell);
|
|
|
|
|
row.appendChild(valueCell);
|
|
|
|
|
return row;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function createInput(type, name, value) {
|
|
|
|
|
let elt = document.createElement("input");
|
|
|
|
|
elt.setAttribute("type", type);
|
|
|
|
|
elt.setAttribute("name", name);
|
|
|
|
|
elt.setAttribute("value", value);
|
|
|
|
|
return elt;
|
|
|
|
|
function searchPoint(text) {
|
|
|
|
|
let index = text.search(/\d{3}\|\d{3}/);
|
|
|
|
|
let point = text.slice(index, index + 7).split("|");
|
|
|
|
|
return {x: point[0], y: point[1]}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function shortcutElementReplace(elt, img, text) {
|
|
|
|
|
@@ -55,33 +89,59 @@ function shortcutElementReplace(elt, img, text) {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let spanImageElement = document.createElement("span");
|
|
|
|
|
spanImageElement.classList.add("shortcut_element_image");
|
|
|
|
|
|
|
|
|
|
let imgElement = document.createElement("img");
|
|
|
|
|
imgElement.setAttribute("src", chrome.runtime.getURL("images/" + img + ".svg"));
|
|
|
|
|
let spanImageElement = createCustomElement("span", {"class": "shortcut_element_image"});
|
|
|
|
|
let imgElement = createCustomElement("img", {"src": chrome.runtime.getURL("images/" + img + ".svg")});
|
|
|
|
|
spanImageElement.appendChild(imgElement);
|
|
|
|
|
|
|
|
|
|
aElements[0].textContent = "";
|
|
|
|
|
aElements[0].appendChild(spanImageElement);
|
|
|
|
|
|
|
|
|
|
if (text) {
|
|
|
|
|
let spanDescElement = document.createElement("span");
|
|
|
|
|
spanDescElement.classList.add("shortcut_element_desc");
|
|
|
|
|
spanDescElement.textContent = text;
|
|
|
|
|
let spanDescElement = createCustomElement("span", {"class": "shortcut_element_desc"}, text);
|
|
|
|
|
aElements[0].appendChild(spanDescElement);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function countUpMs() {
|
|
|
|
|
let arrivalDate = new Date(new Date().getTime() + movingDuration * 1000);
|
|
|
|
|
let prefix = "";
|
|
|
|
|
if (arrivalDate >= afterTomorrow) {
|
|
|
|
|
prefix = "le " + arrivalDate.getDate() + "." + arrivalDate.getMonth() + " ";
|
|
|
|
|
} else if (arrivalDate > tomorrow) {
|
|
|
|
|
prefix = "demain ";
|
|
|
|
|
}
|
|
|
|
|
document.getElementById("countup-time-ms").textContent = prefix
|
|
|
|
|
+ "à "
|
|
|
|
|
+ arrivalDate.getHours().toString().padStart(2, "0")
|
|
|
|
|
+ ":"
|
|
|
|
|
+ arrivalDate.getMinutes().toString().padStart(2, "0")
|
|
|
|
|
+ ":"
|
|
|
|
|
+ arrivalDate.getSeconds().toString().padStart(2, "0")
|
|
|
|
|
+ ":"
|
|
|
|
|
+ Math.floor(arrivalDate.getMilliseconds() / 100);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function handleDomContentLoaded() {
|
|
|
|
|
/* Remove iframe banner */
|
|
|
|
|
document.getElementById("banner_skyscraper").remove();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function main() {
|
|
|
|
|
/* Exit immediately if extension has already been loaded */
|
|
|
|
|
let kaplus = document.getElementById("kaplus-marker");
|
|
|
|
|
if (kaplus) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Exit immediately if not on game page */
|
|
|
|
|
let layCastleTopElements = document.getElementsByClassName("lay_castle_top");
|
|
|
|
|
if (layCastleTopElements.length === 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
window.addEventListener("DOMContentLoaded", handleDomContentLoaded);
|
|
|
|
|
|
|
|
|
|
/* Remove iframe banner */
|
|
|
|
|
document.getElementById("banner_skyscraper").remove();
|
|
|
|
|
/* Add extension marker */
|
|
|
|
|
document.body.appendChild(createCustomElement("div", {"id": "kaplus-marker"}, null, {"display": "none"}));
|
|
|
|
|
|
|
|
|
|
/* Improve navbar icons */
|
|
|
|
|
let shortcutElements = layCastleTopElements[0].getElementsByClassName("shortcut_element");
|
|
|
|
|
@@ -103,6 +163,26 @@ function main() {
|
|
|
|
|
let section = urlParams.get("s");
|
|
|
|
|
let module = urlParams.get("m");
|
|
|
|
|
let sub = urlParams.get("sub");
|
|
|
|
|
let sendCommandForm = document.getElementById("sendCommandForm");
|
|
|
|
|
|
|
|
|
|
/* Add player id on ranking */
|
|
|
|
|
if (section === "ranking" || (section === "ally" && module === "members")) {
|
|
|
|
|
let mainContentPane = document.getElementsByClassName("contentpane")[1];
|
|
|
|
|
let borderListTable = mainContentPane.getElementsByClassName("borderlist")[0];
|
|
|
|
|
let playerRows = borderListTable.getElementsByTagName("tr");
|
|
|
|
|
|
|
|
|
|
let headerCells = playerRows[0].getElementsByTagName("th");
|
|
|
|
|
let idHeaderCell = createCustomElement("th", {"class": headerCells[0].getAttribute("class")}, "Id");
|
|
|
|
|
playerRows[0].insertBefore(idHeaderCell, headerCells[1]);
|
|
|
|
|
|
|
|
|
|
for (let i = 1; i < playerRows.length; i ++) {
|
|
|
|
|
let playerCells = playerRows[i].getElementsByTagName("td");
|
|
|
|
|
let playerProfileLink = playerCells[1].getElementsByTagName("a")[0].getAttribute("href");
|
|
|
|
|
let idValue = playerProfileLink.replace(/^.*id=(\d+)$/, "$1");
|
|
|
|
|
let idCell = createCustomElement("td", {"class": playerCells[0].getAttribute("class")}, idValue);
|
|
|
|
|
playerRows[i].insertBefore(idCell, playerCells[1]);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Display unit-points on user profile */
|
|
|
|
|
if (section === "info_player" && (module === "profile" || module === null)) {
|
|
|
|
|
@@ -128,8 +208,8 @@ function main() {
|
|
|
|
|
armyPercent = (Math.round(armyPoints / villagesCount) / 100).toString() + " %";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
playerPropertiesTable.appendChild(createRow("Points troupes:", str(armyPoints)));
|
|
|
|
|
playerPropertiesTable.appendChild(createRow("% points troupes:", armyPercent));
|
|
|
|
|
playerPropertiesTable.appendChild(createKeyValueRow("Points troupes:", str(armyPoints)));
|
|
|
|
|
playerPropertiesTable.appendChild(createKeyValueRow("% points troupes:", armyPercent));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Display unit-points on village overview */
|
|
|
|
|
@@ -149,34 +229,111 @@ function main() {
|
|
|
|
|
villagePointsRow.after(unitPointsRow);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Allow multiple attacks */
|
|
|
|
|
if (section === "build_barracks" && module === "command" && sub === "send") {
|
|
|
|
|
let table = document.createElement("table");
|
|
|
|
|
table.classList.add("borderlist");
|
|
|
|
|
let tbody = document.createElement("tbody");
|
|
|
|
|
let tr = document.createElement("tr");
|
|
|
|
|
let th = document.createElement("th");
|
|
|
|
|
th.textContent = "Nombre d'attaques:";
|
|
|
|
|
/* Units order page */
|
|
|
|
|
if (section === "build_barracks" && (module === null || module === "command") && sendCommandForm !== null) {
|
|
|
|
|
let barracksCommands = sendCommandForm.getElementsByClassName("barracksCommand");
|
|
|
|
|
let borderListTables = sendCommandForm.getElementsByClassName("borderlist");
|
|
|
|
|
|
|
|
|
|
let quantityLabel = createCustomElement("label");
|
|
|
|
|
let quantityInput = createCustomElement("input", {"type": "checkbox"});
|
|
|
|
|
quantityInput.addEventListener("change", function () {
|
|
|
|
|
let clickSpans = [];
|
|
|
|
|
if (barracksCommands.length === 1) {
|
|
|
|
|
clickSpans = barracksCommands[0].getElementsByClassName("click");
|
|
|
|
|
} else if (borderListTables.length === 1) {
|
|
|
|
|
clickSpans = borderListTables[0].getElementsByClassName("click");
|
|
|
|
|
}
|
|
|
|
|
for (let i = 0; i < 12; i++) {
|
|
|
|
|
if (clickSpans[i].classList.contains("all")) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
clickSpans[i].click();
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
quantityLabel.appendChild(quantityInput);
|
|
|
|
|
let quantitySpan = createCustomElement("span", {"class": "click all"}, "(Tout sélectionner)");
|
|
|
|
|
quantityLabel.appendChild(quantitySpan);
|
|
|
|
|
|
|
|
|
|
if (barracksCommands.length === 1) {
|
|
|
|
|
let boxCell = createCustomElement("div", {"class": "box"});
|
|
|
|
|
|
|
|
|
|
let backgroundCell = createCustomElement("div", {"class": "background"});
|
|
|
|
|
let backgroundImg = createCustomElement(
|
|
|
|
|
"img", {"src": "//s58-fr.kingsage.gameforge.com/img/modern/card_sendunit.png"}
|
|
|
|
|
);
|
|
|
|
|
backgroundCell.appendChild(backgroundImg);
|
|
|
|
|
boxCell.appendChild(backgroundCell);
|
|
|
|
|
|
|
|
|
|
let imageCell = createCustomElement("div", {"class": "image"});
|
|
|
|
|
let imageImg = createCustomElement(
|
|
|
|
|
"img", {"src": "//s58-fr.kingsage.gameforge.com/img/shortcut/barracks.png"}, null, {"width": "28px"}
|
|
|
|
|
);
|
|
|
|
|
imageCell.appendChild(imageImg);
|
|
|
|
|
boxCell.appendChild(imageCell);
|
|
|
|
|
|
|
|
|
|
let nameCell = createCustomElement("div", {"class": "name"});
|
|
|
|
|
let nameA = createCustomElement("a", {"href": "help.php?m=units", "target": "_help"});
|
|
|
|
|
let nameB = createCustomElement("b", null, "Tout");
|
|
|
|
|
nameA.appendChild(nameB);
|
|
|
|
|
nameCell.appendChild(nameA);
|
|
|
|
|
boxCell.appendChild(nameCell);
|
|
|
|
|
|
|
|
|
|
let quantityCell = createCustomElement("div", {"class": "quantity"});
|
|
|
|
|
quantityCell.appendChild(quantityLabel);
|
|
|
|
|
boxCell.appendChild(quantityCell);
|
|
|
|
|
|
|
|
|
|
let brTag = barracksCommands[0].getElementsByTagName("br")[1];
|
|
|
|
|
barracksCommands[0].insertBefore(boxCell, brTag);
|
|
|
|
|
|
|
|
|
|
} else if (borderListTables.length === 1) {
|
|
|
|
|
let borderListRows = borderListTables[0].getElementsByTagName("tr");
|
|
|
|
|
let selectAllCell = borderListRows[1].getElementsByTagName("td")[3];
|
|
|
|
|
|
|
|
|
|
let imageA = createCustomElement("a", {"href": "help.php?m=units", "target": "_help"});
|
|
|
|
|
let imageImg = createCustomElement(
|
|
|
|
|
"img", {"src": "//s58-fr.kingsage.gameforge.com/img/shortcut/barracks.png", "title": "Tout"}
|
|
|
|
|
);
|
|
|
|
|
imageA.appendChild(imageImg);
|
|
|
|
|
selectAllCell.appendChild(imageA);
|
|
|
|
|
|
|
|
|
|
selectAllCell.appendChild(quantityLabel);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Units sending page */
|
|
|
|
|
if (section === "build_barracks" && module === "command" && sub === "send" && sendCommandForm === null) {
|
|
|
|
|
/* Improve countup time cell */
|
|
|
|
|
let oldCell = document.getElementById("countup-time");
|
|
|
|
|
let hms = oldCell.parentElement.previousElementSibling.getElementsByTagName("td")[1].textContent.split(":");
|
|
|
|
|
movingDuration = parseInt(hms[0]) * 3600 + parseInt(hms[1]) * 60 + parseInt(hms[2]) ;
|
|
|
|
|
let newRow = createCustomElement("tr");
|
|
|
|
|
let newLeftCell = createCustomElement("td", null, "Arrivée:");
|
|
|
|
|
newRow.appendChild(newLeftCell);
|
|
|
|
|
let newRightCell = createCustomElement("td", {"id": "countup-time-ms"});
|
|
|
|
|
newRow.appendChild(newRightCell);
|
|
|
|
|
oldCell.parentElement.parentElement.insertBefore(newRow, oldCell.parentElement);
|
|
|
|
|
oldCell.parentElement.style.display = "none";
|
|
|
|
|
setInterval(countUpMs, 100);
|
|
|
|
|
|
|
|
|
|
/* Allow multiple occurrences of send */
|
|
|
|
|
let table = createCustomElement("table", {"class": "borderlist"});
|
|
|
|
|
let tbody = createCustomElement("tbody");
|
|
|
|
|
let tr = createCustomElement("tr");
|
|
|
|
|
let th = createCustomElement("th", null, "Nombre d'occurrences:");
|
|
|
|
|
tr.appendChild(th)
|
|
|
|
|
let td = document.createElement("td");
|
|
|
|
|
let input = document.createElement("input");
|
|
|
|
|
input.setAttribute("type", "number");
|
|
|
|
|
input.setAttribute("name", "attack_count");
|
|
|
|
|
input.setAttribute("value", "1");
|
|
|
|
|
let td = createCustomElement("td");
|
|
|
|
|
let input = createCustomElement("input", {"type": "number", "name": "occurrences", "value": "1"});
|
|
|
|
|
td.appendChild(input);
|
|
|
|
|
tr.appendChild(td);
|
|
|
|
|
tbody.appendChild(tr);
|
|
|
|
|
table.appendChild(tbody);
|
|
|
|
|
|
|
|
|
|
let form = document.getElementsByTagName("form")[0];
|
|
|
|
|
let firstInput = form.getElementsByTagName("input")[0];
|
|
|
|
|
form.insertBefore(table, firstInput);
|
|
|
|
|
form.addEventListener("submit", function (event) {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
let formData = new FormData(this);
|
|
|
|
|
let attackCount = parseInt(formData.get("attack_count").toString());
|
|
|
|
|
formData.delete("attack_count");
|
|
|
|
|
|
|
|
|
|
let attackCount = parseInt(formData.get("occurrences").toString());
|
|
|
|
|
formData.delete("occurrences");
|
|
|
|
|
let sent = 0;
|
|
|
|
|
for (let i = 0; i < attackCount; i++) {
|
|
|
|
|
let xhr = new XMLHttpRequest();
|
|
|
|
|
@@ -192,8 +349,9 @@ function main() {
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Fix select bug in market */
|
|
|
|
|
/* Market sending page */
|
|
|
|
|
if (section === "build_market" && (module === "send" || module === null)) {
|
|
|
|
|
/* Fix select bug in target village select */
|
|
|
|
|
let select = document.getElementsByName("village_name")[0];
|
|
|
|
|
select.removeAttribute("onchange");
|
|
|
|
|
select.addEventListener("change", function () {
|
|
|
|
|
@@ -208,15 +366,61 @@ function main() {
|
|
|
|
|
sendY.value = xy[1];
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
/* Add form to send resources by thousands */
|
|
|
|
|
let sendForm = document.getElementsByTagName("form")[0]
|
|
|
|
|
sendForm.addEventListener("submit", function () {
|
|
|
|
|
let inputs = this.getElementsByTagName("input");
|
|
|
|
|
for (let i = 0; i < inputs.length; i ++) {
|
|
|
|
|
if (inputs[i].getAttribute("name").endsWith("_k")) {
|
|
|
|
|
inputs[i].setAttribute("name", "");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
let sendFormTables = sendForm.getElementsByTagName("table");
|
|
|
|
|
let newTable = sendFormTables[0].cloneNode(true);
|
|
|
|
|
newTable.getElementsByTagName("th")[0].textContent = "Ressources par milliers";
|
|
|
|
|
let resCells = newTable.getElementsByTagName("td");
|
|
|
|
|
for (let i = 0; i < resCells.length; i ++) {
|
|
|
|
|
let resInput = resCells[i].getElementsByTagName("input")[0];
|
|
|
|
|
let resName = resInput.getAttribute("name");
|
|
|
|
|
let resNameK = resInput.getAttribute("name") + "_k";
|
|
|
|
|
resInput.setAttribute("name", resNameK);
|
|
|
|
|
resInput.addEventListener("change", function () {
|
|
|
|
|
document.getElementsByName(resName)[0].value = 1000 * parseInt(this.value);
|
|
|
|
|
});
|
|
|
|
|
let spanInput = resCells[i].getElementsByTagName("span")[0];
|
|
|
|
|
let resMax = spanInput.textContent.replace(/\(/, "").replace("\)", "").replace(/\./, "");
|
|
|
|
|
let rMax = Math.floor(parseInt(resMax) / 1000);
|
|
|
|
|
spanInput.setAttribute(
|
|
|
|
|
"onclick",
|
|
|
|
|
"insertNum('kingsage', '" + resNameK + "', '" + rMax.toString() + "'); " +
|
|
|
|
|
"insertNum('kingsage', '" + resName + "', '" + (1000 * rMax).toString() + "');"
|
|
|
|
|
)
|
|
|
|
|
spanInput.textContent = "(" + rMax.toString() + "K)";
|
|
|
|
|
}
|
|
|
|
|
sendForm.insertBefore(newTable, sendFormTables[0]);
|
|
|
|
|
sendForm.insertBefore(createCustomElement("br"), sendFormTables[1]);
|
|
|
|
|
|
|
|
|
|
/* Set inputs type=number */
|
|
|
|
|
let sendInputs = sendForm.getElementsByTagName("input");
|
|
|
|
|
for (let i = 0; i < sendInputs.length; i ++) {
|
|
|
|
|
if (sendInputs[i].name.startsWith("send_")) {
|
|
|
|
|
sendInputs[i].setAttribute("type", "number");
|
|
|
|
|
sendInputs[i].value = "";
|
|
|
|
|
sendInputs[i].style.width = "65px";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Improve attacks display */
|
|
|
|
|
if (section === "ally" && module === "attacks") {
|
|
|
|
|
let serverTime = parseInt(document.getElementById("servertime").getAttribute("time"));
|
|
|
|
|
let contentPane = document.getElementsByClassName("contentpane")[1]
|
|
|
|
|
let table = contentPane.getElementsByClassName("borderlist")[0];
|
|
|
|
|
let rows = table.getElementsByTagName("tr");
|
|
|
|
|
|
|
|
|
|
let headCell = document.createElement("th");
|
|
|
|
|
let headCell = createCustomElement("th");
|
|
|
|
|
rows[0].appendChild(headCell);
|
|
|
|
|
|
|
|
|
|
for (let i = 1; i < rows.length; i ++) {
|
|
|
|
|
@@ -225,26 +429,27 @@ function main() {
|
|
|
|
|
let arrivalTimeCell = cells[4];
|
|
|
|
|
|
|
|
|
|
let seconds = parseInt(arrivalTimeCell.getElementsByTagName("span")[0].getAttribute("time"));
|
|
|
|
|
let arrival = new Date(Date.now() + seconds * 1000);
|
|
|
|
|
let arrival = new Date((serverTime + seconds) * 1000);
|
|
|
|
|
let hour = arrival.toLocaleTimeString("fr-FR");
|
|
|
|
|
arrivalDateCell.textContent = arrivalDateCell.textContent.replace(/(.*)\d\d:\d\d(.*)/, "$1" + hour + "$2");
|
|
|
|
|
|
|
|
|
|
let startPoint = cells[2].textContent.replace(/.*(\d{3}\|\d{3}).*/, "$1").split("|");
|
|
|
|
|
let targetPoint = cells[1].textContent.replace(/.*(\d{3}\|\d{3}).*/, "$1").split("|");
|
|
|
|
|
let calculatorCell = document.createElement("td");
|
|
|
|
|
let calculatorForm = document.createElement("form");
|
|
|
|
|
calculatorForm.setAttribute("method", "post");
|
|
|
|
|
calculatorForm.setAttribute("action", "/?s=tools&m=runtime_calculator&inta=calculate");
|
|
|
|
|
calculatorForm.appendChild(createInput("hidden", "start_x", startPoint[0]));
|
|
|
|
|
calculatorForm.appendChild(createInput("hidden", "start_y", startPoint[1]));
|
|
|
|
|
calculatorForm.appendChild(createInput("hidden", "target_x", targetPoint[0]));
|
|
|
|
|
calculatorForm.appendChild(createInput("hidden", "target_y", targetPoint[1]));
|
|
|
|
|
let calculatorImg = document.createElement("input");
|
|
|
|
|
calculatorImg.setAttribute("type", "image");
|
|
|
|
|
calculatorImg.setAttribute("src", chrome.runtime.getURL("images/calculator.svg"));
|
|
|
|
|
calculatorImg.style.width = "20px";
|
|
|
|
|
calculatorImg.style.height = "20px";
|
|
|
|
|
calculatorImg.style.border = "none";
|
|
|
|
|
let startPoint = searchPoint(cells[2].textContent);
|
|
|
|
|
let targetPoint = searchPoint(cells[1].textContent);
|
|
|
|
|
let calculatorCell = createCustomElement("td");
|
|
|
|
|
let calculatorForm = createCustomElement(
|
|
|
|
|
"form", {"method": "post", "action": "/?s=tools&m=runtime_calculator&inta=calculate"}
|
|
|
|
|
);
|
|
|
|
|
calculatorForm.appendChild(createCustomInput("hidden", "start_x", startPoint.x));
|
|
|
|
|
calculatorForm.appendChild(createCustomInput("hidden", "start_y", startPoint.y));
|
|
|
|
|
calculatorForm.appendChild(createCustomInput("hidden", "target_x", targetPoint.x));
|
|
|
|
|
calculatorForm.appendChild(createCustomInput("hidden", "target_y", targetPoint.y));
|
|
|
|
|
let calculatorImg = createCustomInput(
|
|
|
|
|
"image",
|
|
|
|
|
null,
|
|
|
|
|
null,
|
|
|
|
|
{"src": chrome.runtime.getURL("images/calculator.svg")},
|
|
|
|
|
{"width": "20px", "height": "20px", "border": "none"}
|
|
|
|
|
);
|
|
|
|
|
calculatorForm.appendChild(calculatorImg);
|
|
|
|
|
calculatorCell.appendChild(calculatorForm);
|
|
|
|
|
rows[i].appendChild(calculatorCell);
|
|
|
|
|
|