nopaque/app/static/js/add_job.js

55 lines
2.1 KiB
JavaScript
Raw Normal View History

2019-11-08 12:21:59 +01:00
function SubmitAddJobForm(newJobFormElement, progressModalElement, request) {
2019-11-19 09:54:31 +01:00
var formData = new FormData(newJobFormElement);
var progressModal = M.Modal.getInstance(progressModalElement);
progressModal.options.dismissible = false;
progressModalElement.querySelector(".title").innerHTML = newJobFormElement.title.value;
2019-11-19 09:54:31 +01:00
request.addEventListener("abort", function(event) {
progressModalElement.querySelector(".progress-in-percent").innerHTML = "0%";
progressModalElement.querySelector(".determinate").style.width = "0%";
2019-09-16 12:12:42 +02:00
});
2019-09-17 14:20:15 +02:00
request.addEventListener("load", function(event) {
if (request.status === 201) {
window.location.href = JSON.parse(this.responseText)['redirect_url'];
}
if (request.status === 400) {
2019-11-19 09:54:31 +01:00
progressModal.close();
progressModalElement.querySelector(".progress-in-percent").innerHTML = "0%";
progressModalElement.querySelector(".determinate").style.width = "0%";
for (let [field, errors] of Object.entries(JSON.parse(this.responseText))) {
let fieldElement = document.getElementById(field).closest('.input-field');
for (let error of errors) {
fieldElement.insertAdjacentHTML('beforeend', '<span class="helper-text red-text">' + error + '</span>');
}
}
}
if (request.status === 500) {
location.reload();
}
2019-09-16 12:12:42 +02:00
});
2019-11-19 09:54:31 +01:00
request.upload.addEventListener("progress", function(event) {
progressInPercent = Math.floor(100 * event.loaded / event.total).toString() + "%";
progressModalElement.querySelector(".progress-in-percent").innerHTML = progressInPercent;
progressModalElement.querySelector(".determinate").style.width = progressInPercent;
2019-09-17 16:15:37 +02:00
});
2019-11-19 09:54:31 +01:00
progressModal.open();
request.open("POST", window.location.href);
request.send(formData);
2019-09-16 12:12:42 +02:00
}
2019-09-17 14:20:15 +02:00
2019-11-08 12:21:59 +01:00
function initAddJobForm(addJobFormElement, progressModalElement) {
2019-09-17 14:20:15 +02:00
var request;
request = new XMLHttpRequest();
2019-11-08 12:21:59 +01:00
addJobFormElement.addEventListener("submit", function(event) {
2019-09-16 12:12:42 +02:00
event.preventDefault();
2019-11-08 12:21:59 +01:00
SubmitAddJobForm(addJobFormElement, progressModalElement, request);
2019-09-17 14:20:15 +02:00
});
progressModalElement.querySelector(".cancel").addEventListener("click", function(event) {
request.abort();
2019-09-16 12:12:42 +02:00
});
}