Refactor UI updates and AJAX logic
Flattened AJAX success handling and pruned conditional branches for clarity, enhancing code readability and maintainability. Optimized UI card element creation for handling image and video content, reducing DOM manipulation frequency for improved performance. Eliminated inefficient video thumbnail refresh intervals, switching to static resource loading to alleviate server load.
This commit is contained in:
parent
32562849c3
commit
addd45b356
2 changed files with 50 additions and 58 deletions
|
@ -29,48 +29,44 @@ function deletecard(jobid) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function checkServerForFile(jobid, title, interval) {
|
function checkServerForFile(jobid, title, interval) {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
type: "GET",
|
type: "GET",
|
||||||
cache: false,
|
cache: false,
|
||||||
url: "/status/" + jobid,
|
url: "/status/" + jobid,
|
||||||
statusCode: {
|
statusCode: {
|
||||||
403: function () {
|
403: function () {
|
||||||
Notification.requestPermission(function (permission) {
|
Notification.requestPermission(function (permission) {
|
||||||
if (permission === "granted") {
|
if (permission === "granted") {
|
||||||
var notification = new Notification("PIX360", {
|
var notification = new Notification("PIX360", {
|
||||||
body: "Your session has expired. Please log in again.",
|
body: "Your session has expired. Please log in again.",
|
||||||
});
|
});
|
||||||
}
|
|
||||||
});
|
|
||||||
window.location.href = "/";
|
|
||||||
},
|
|
||||||
404: function () {
|
|
||||||
clearInterval(intervals[jobid]);
|
|
||||||
failcard(jobid, title);
|
|
||||||
return;
|
|
||||||
},
|
|
||||||
200: function (data, tstatus, xhr) {
|
|
||||||
if (data.status == "completed") {
|
|
||||||
clearInterval(intervals[jobid]);
|
|
||||||
finishcard(
|
|
||||||
jobid,
|
|
||||||
title,
|
|
||||||
data.content_type == "video/mp4"
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
} else if (data.status == "failed") {
|
|
||||||
clearInterval(intervals[jobid]);
|
|
||||||
failcard(jobid, title);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
},
|
});
|
||||||
500: function () {
|
window.location.href = "/";
|
||||||
|
},
|
||||||
|
404: function () {
|
||||||
|
clearInterval(intervals[jobid]);
|
||||||
|
failcard(jobid, title);
|
||||||
|
return;
|
||||||
|
},
|
||||||
|
200: function (data, tstatus, xhr) {
|
||||||
|
if (data.status == "completed") {
|
||||||
|
clearInterval(intervals[jobid]);
|
||||||
|
finishcard(jobid, title, data.content_type == "video/mp4");
|
||||||
|
return;
|
||||||
|
} else if (data.status == "failed") {
|
||||||
clearInterval(intervals[jobid]);
|
clearInterval(intervals[jobid]);
|
||||||
failcard(jobid, title);
|
failcard(jobid, title);
|
||||||
return;
|
return;
|
||||||
},
|
}
|
||||||
},
|
},
|
||||||
});
|
500: function () {
|
||||||
|
clearInterval(intervals[jobid]);
|
||||||
|
failcard(jobid, title);
|
||||||
|
return;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function addcard(jobid, title) {
|
function addcard(jobid, title) {
|
||||||
|
@ -108,7 +104,9 @@ function failcard(jobid, title) {
|
||||||
'<div class="card"> <div style="text-align: center; color: red; font-weight: bold;" class="card-block">' +
|
'<div class="card"> <div style="text-align: center; color: red; font-weight: bold;" class="card-block">' +
|
||||||
title +
|
title +
|
||||||
': Export failed.</div><div style="text-align: center;" class="card-block"><a style="color: white;" onclick="restartconversion (\'' +
|
': Export failed.</div><div style="text-align: center;" class="card-block"><a style="color: white;" onclick="restartconversion (\'' +
|
||||||
jobid + '\', \'' + title +
|
jobid +
|
||||||
|
"', '" +
|
||||||
|
title +
|
||||||
'\');" class="btn btn-info">Retry</a> <a style="color: white;" onclick="deletecard(\'' +
|
'\');" class="btn btn-info">Retry</a> <a style="color: white;" onclick="deletecard(\'' +
|
||||||
jobid +
|
jobid +
|
||||||
'\');" class="btn btn-danger">Hide</a></div> </div>';
|
'\');" class="btn btn-danger">Hide</a></div> </div>';
|
||||||
|
@ -124,33 +122,27 @@ function finishcard(jobid, title, video) {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
var text =
|
var text =
|
||||||
'<div class="card"> <img ' +
|
'<div class="card"> <' +
|
||||||
(video ? 'id="' + jobid + '-thumb"' : "") +
|
(video ? "video" : "img") +
|
||||||
' class="card-img-top img-fluid" download src="/download/' +
|
' class="card-img-top img-fluid" download src="/download/' +
|
||||||
jobid +
|
jobid +
|
||||||
(video ? "-thumb" : "") +
|
|
||||||
'" alt="Final ' +
|
'" alt="Final ' +
|
||||||
(video ? "Video" : "Image") +
|
(video ? "Video" : "Image") +
|
||||||
'"><div style="text-align: center; font-weight: bold;" class="card-block">' +
|
'">' +
|
||||||
|
(video ? "</video>" : "") +
|
||||||
|
'<div style="text-align: center; font-weight: bold;" class="card-block">' +
|
||||||
title +
|
title +
|
||||||
'</div> <div style="text-align: center; color: white;" class="card-block"><a style="color: white;" onclick="restartconversion (\'' +
|
'</div> <div style="text-align: center; color: white;" class="card-block"><a style="color: white;" onclick="restartconversion(\'' +
|
||||||
jobid + '\', \'' + title +
|
jobid +
|
||||||
'\');" class="btn btn-info">Retry</a><a href="/download/' +
|
"', '" +
|
||||||
|
title +
|
||||||
|
'\');" class="btn btn-info">Retry</a> <a href="/download/' +
|
||||||
jobid +
|
jobid +
|
||||||
'" class="btn btn-primary">Download</a> <a onclick="deletecard(\'' +
|
'" class="btn btn-primary">Download</a> <a onclick="deletecard(\'' +
|
||||||
jobid +
|
jobid +
|
||||||
'\');" class="btn btn-danger">Hide</a> </div> </div>';
|
'\');" class="btn btn-danger">Hide</a> </div> </div>';
|
||||||
$("#" + jobid).html(text);
|
$("#" + jobid).html(text);
|
||||||
|
|
||||||
var counter = 0;
|
|
||||||
var interval = setInterval(function () {
|
|
||||||
var image = document.getElementById(jobid + "-thumb");
|
|
||||||
image.src = "/download/" + jobid + "-thumb?rand=" + Math.random();
|
|
||||||
if (++counter === 10) {
|
|
||||||
window.clearInterval(interval);
|
|
||||||
}
|
|
||||||
}, 2000);
|
|
||||||
|
|
||||||
$("#" + jobid + " img").on("click", function () {
|
$("#" + jobid + " img").on("click", function () {
|
||||||
imgurl = $(this).attr("src");
|
imgurl = $(this).attr("src");
|
||||||
pannellum.viewer("panorama", {
|
pannellum.viewer("panorama", {
|
||||||
|
@ -193,13 +185,13 @@ function initialize() {
|
||||||
intervals[job.id] = interval;
|
intervals[job.id] = interval;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
$(document).ready(function () {
|
$(document).ready(function () {
|
||||||
if (Notification.permission !== "granted") {
|
if (Notification.permission !== "granted") {
|
||||||
Notification.requestPermission();
|
Notification.requestPermission();
|
||||||
};
|
}
|
||||||
initialize();
|
initialize();
|
||||||
});
|
});
|
Loading…
Reference in a new issue