mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-05 23:25:46 +08:00
92 lines
2.6 KiB
JavaScript
92 lines
2.6 KiB
JavaScript
function setupAssetsLoading() {
|
|
var DELAY = 2500;
|
|
var REPETITIONS = 60;
|
|
|
|
function refreshAssets() {
|
|
var elements = $("[data-status='asset-loading']");
|
|
|
|
if (!elements.length) {
|
|
return false;
|
|
}
|
|
|
|
$.each(elements, function(_, el) {
|
|
var $el = $(el);
|
|
|
|
// Perform an AJAX call to present URL
|
|
// to check if file already exists
|
|
$.ajax({
|
|
url: $el.data("present-url"),
|
|
type: "GET",
|
|
dataType: "json",
|
|
success: function (data) {
|
|
var wopiBtns;
|
|
$el.attr("data-status", "asset-loaded");
|
|
$el.find('img').hide();
|
|
$el.next().hide();
|
|
$el.html("");
|
|
|
|
if (data.type === 'image') {
|
|
$el.html(
|
|
"<a class='file-preview-link' id='modal_link" +
|
|
data['asset-id'] + "' data-status='asset-present' " +
|
|
"href='" + data['download-url'] + "' data-preview-url='" +
|
|
data['preview-url'] + "'>" +
|
|
"<img src='" + data['image-tag-url'] + "'><p>" +
|
|
data.filename + '</p></a>'
|
|
);
|
|
} else {
|
|
$el.html(
|
|
"<a class='file-preview-link' id='modal_link" +
|
|
data['asset-id'] + "' data-status='asset-present' " +
|
|
"href='" + data['download-url'] + "' data-preview-url='" +
|
|
data['preview-url'] + "'><p>" +
|
|
data.filename + '</p></a>'
|
|
);
|
|
}
|
|
animateSpinner(null, false);
|
|
initPreviewModal();
|
|
},
|
|
error: function(data) {
|
|
if (data.status == 403) {
|
|
$el.find('img').hide();
|
|
$el.next().hide();
|
|
// Image/file exists, but user doesn't have
|
|
// rights to download it
|
|
if (type === "image") {
|
|
$el.html(
|
|
"<img src='" + data['image-tag-url'] + "'><p>" +
|
|
data.filename + "</p>"
|
|
);
|
|
} else {
|
|
$el.html("<p>" + data.filename + "</p>");
|
|
}
|
|
} else {
|
|
// Do nothing, file is not yet present
|
|
animateSpinner(null, false);
|
|
}
|
|
}
|
|
});
|
|
});
|
|
|
|
return true;
|
|
}
|
|
|
|
function finalizeAssets() {
|
|
var elements = $("[data-status='asset-loading']");
|
|
|
|
$.each(elements, function(_, el) {
|
|
var $el = $(el);
|
|
$el.attr("data-status", "asset-failed");
|
|
$el.html($el.data("filename"));
|
|
});
|
|
}
|
|
|
|
var cntr = 0;
|
|
var intervalId = window.setInterval(function() {
|
|
cntr++;
|
|
if (cntr >= REPETITIONS || !refreshAssets()) {
|
|
finalizeAssets();
|
|
window.clearInterval(intervalId);
|
|
}
|
|
}, DELAY);
|
|
}
|