mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-10 09:28:37 +08:00
65 lines
1.6 KiB
JavaScript
65 lines
1.6 KiB
JavaScript
(function(){
|
|
var count = 0;
|
|
|
|
function init(){
|
|
$("[data-id]").each(function(){
|
|
var that = $(this);
|
|
that.find(".workflowimg-container").hide();
|
|
initProjectExperiment(that);
|
|
});
|
|
}
|
|
|
|
function initProjectExperiment(element){
|
|
var container = element.find(".workflowimg-container");
|
|
var url = container.data("check-img");
|
|
var timestamp = container.data("timestamp");
|
|
var img_url = container.data('updated-img');
|
|
|
|
animateSpinner(container, true);
|
|
checkUpdatedImg(img_url, url, timestamp, container);
|
|
}
|
|
|
|
// checks if the experiment image is updated
|
|
function checkUpdatedImg(img_url, url, timestamp, container){
|
|
if (count < 30 && timestamp){
|
|
$.ajax({
|
|
url: url,
|
|
type: "GET",
|
|
data: { "timestamp": timestamp },
|
|
dataType: "json",
|
|
success: function (data) {
|
|
getNewWorkforwImg(container, img_url);
|
|
container.show();
|
|
animateSpinner(container, false);
|
|
},
|
|
error: function (ev) {
|
|
if (ev.status == 404) {
|
|
setTimeout(checkUpdatedImg(img_url, url, timestamp, container), 500);
|
|
} else {
|
|
animateSpinner(container, false);
|
|
}
|
|
count++;
|
|
}
|
|
});
|
|
} else {
|
|
animateSpinner(container, false);
|
|
}
|
|
}
|
|
|
|
// fetch the new experiment image
|
|
function getNewWorkforwImg(el, url){
|
|
$.ajax({
|
|
url: url,
|
|
type: "GET",
|
|
dataType: "json",
|
|
success: function (data) {
|
|
el.append(data.workflowimg);
|
|
},
|
|
error: function (ev) {
|
|
// TODO
|
|
}
|
|
});
|
|
}
|
|
// init
|
|
init();
|
|
})();
|