This repository has been archived on 2024-10-13. You can view files and clone it, but cannot push or open issues or pull requests.
VPModelFileTool/dist/js/scripts.js

182 lines
5.8 KiB
JavaScript
Raw Permalink Normal View History

let namespace = "vp";
2023-01-20 18:51:33 +00:00
$(document).ready(function () {
2024-04-14 15:36:28 +00:00
const $cmd = $("#custommodeldata");
2023-01-20 18:51:33 +00:00
const form = $("#calculatorForm");
const formOptions = $("#formItems");
2024-10-13 12:55:31 +00:00
const fileName = $("#filename");
2023-01-20 18:51:33 +00:00
const item = $("#item");
const itemCount = $("#itemcount");
const items = $("#items");
const output = $("#content");
const copyButton = $("#copyButton");
const downloadButton = $("#downloadButton");
const minus = $("#minus");
const plus = $("#plus");
const input = $("input[name='quant']");
const nsp = $("#namespace");
2023-01-20 18:51:33 +00:00
const $select = $('#item');
2024-04-14 17:51:38 +00:00
minus.click(function () {
2023-01-20 18:51:33 +00:00
const currentVal = parseInt(input.attr('value'));
if (!isNaN(currentVal)) {
if (currentVal > input.attr('min')) {
input.attr('value', (currentVal - 1).toString());
}
2024-04-14 17:51:38 +00:00
if (currentVal - 1 === input.attr('min')) {
2023-01-20 18:51:33 +00:00
$(this).attr('disabled', true);
}
$("#iteminput" + currentVal).remove();
} else {
input.attr('value', '0');
}
});
2024-04-14 17:51:38 +00:00
plus.click(function () {
2023-01-20 18:51:33 +00:00
const currentVal = parseInt(input.attr('value'));
if (!isNaN(currentVal)) {
if (currentVal < input.attr('max')) {
input.attr('value', (currentVal + 1).toString());
}
2024-04-14 17:51:38 +00:00
if (currentVal === input.attr('max')) {
2023-01-20 18:51:33 +00:00
$(this).attr('disabled', true);
return;
}
if (parseInt(input.attr('value')) > 1) {
minus.prop('disabled', false);
} else {
minus.prop('disabled', true);
}
2024-04-14 15:36:28 +00:00
items.append("<div id=\"iteminput" + (currentVal + 1) + "\" class=\"mb-3 w-50\"><label for=\"item" + (currentVal + 1) + "\">Model for damage " + (currentVal + 1) + ":</label><div class=\"input-group mb-3\"><span class=\"input-group-text\" id=\"namespace" + (currentVal + 1) + "\">" + namespace + ":item/</span><input type=\"text\" class=\"form-control\" id=\"item" + (currentVal + 1) + "\" name=\"item" + (currentVal + 1) + "\" placeholder=\"cars/" + randomModel() + "\" required></div></div>");
2023-01-20 18:51:33 +00:00
} else {
input.attr('value', '0');
}
});
2024-04-14 15:36:28 +00:00
// Append the items to the select on load (default for CMD is checked)
2024-04-14 17:51:38 +00:00
$.each(itemDamages, function (key) {
2024-04-14 15:36:28 +00:00
const itemName = capitalize(key);
$select.append($('<option></option>').attr('value', key).text(itemName));
});
$cmd.change(function () {
$select.find('option').each(function () {
const key = $(this).val();
const itemName = capitalize(key);
const hasSupportText = ($(this).text().includes('(supports'));
if (key === "") {
// Keep the default "Select an item..." option as is
return;
}
if ($cmd.is(':checked')) {
if (hasSupportText) {
2024-04-14 17:51:38 +00:00
$(this).text(itemName);
2024-04-14 15:36:28 +00:00
}
} else {
if (!hasSupportText) {
const updatedText = itemName + ' (supports ' + itemDamages[key] + ' models)';
$(this).text(updatedText);
}
}
});
});
nsp.change(function () {
namespace = nsp.val();
2024-04-14 17:51:38 +00:00
if (!namespace) namespace = "minecraft";
nsp.val(namespace);
2024-04-14 15:36:28 +00:00
$("span[id^='namespace']").text(namespace + ":item/");
});
2023-01-20 18:51:33 +00:00
item.change(function () {
2024-10-13 12:55:31 +00:00
// If value is not empty, show other options ...
2023-01-20 18:51:33 +00:00
if (this.value !== "") {
formOptions.show();
2024-10-13 12:55:31 +00:00
//... and set filename (in <code> tag)
fileName.text(this.value + ".json");
2023-01-20 18:51:33 +00:00
//... and set max value of item count.
const max = itemDamages[this.value];
itemCount.prop('max', max);
plus.prop('disabled', false);
2024-10-13 12:55:31 +00:00
} else {
// Or if empty, hide other options ...
2023-01-20 18:51:33 +00:00
formOptions.hide();
2024-10-13 12:55:31 +00:00
output.text("Fill in the form above to get an output.");
//... and reset filename
fileName.text("file");
2023-01-20 18:51:33 +00:00
}
});
form.on("submit", function (e) {
e.preventDefault();
2024-04-14 15:36:28 +00:00
//Check if custommodeldata is supported
const supportsCMD = $cmd.is(":checked");
2023-01-20 18:55:28 +00:00
//Get selected item and amount of models
2023-01-20 18:51:33 +00:00
const selectedItem = item.val();
const currentVal = parseInt(input.attr('value'));
//Build models array
const models = [];
for (let i = 0; i < currentVal; i++) {
models[i] = $("#item" + (i + 1)).val();
}
//Convert to JSON, and set in content field (with syntax highlighting)
2024-04-14 15:36:28 +00:00
const json = buildJSON(supportsCMD, selectedItem, namespace, models);
2023-01-20 18:51:33 +00:00
output.html(syntaxHighlight(json));
//And fix the Download button
2023-01-20 18:51:33 +00:00
const dataStr = "data:text/json;charset=utf-8," + encodeURIComponent(json);
downloadButton.attr("href", dataStr);
downloadButton.attr("download", selectedItem + ".json");
//Return false to not reload the page
return false;
});
copyButton.click(function (e) {
e.preventDefault();
navigator.clipboard.writeText(output.text());
});
/**
* Capitalize a string.
2024-04-14 17:51:38 +00:00
*
* @param {string} str A string to capitalize
2024-04-14 17:51:38 +00:00
* @returns
*/
function capitalize(str) {
return str.split('_').map(word => word.charAt(0).toUpperCase() + word.slice(1)).join(' ');
}
2023-01-20 18:51:33 +00:00
/**
* Get a random model.
*
* @return {string} The random model.
*/
function randomModel() {
const months = ["red_car", "blue_car", "green_car", "orange_car", "blue_bicycle", "red_bicycle", "green_bicycle", "orange_bicycle"];
return months[Math.floor(Math.random() * months.length)];
}
});