mirror of
https://github.com/chibicitiberiu/ytsm.git
synced 2024-02-24 05:43:31 +00:00
Fix task statuses on the video and other pages
This commit is contained in:
parent
794b9bd42d
commit
ce18c49407
@ -198,6 +198,85 @@ function ajaxLink_Clicked() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Notifications
|
||||||
|
///
|
||||||
|
const JOB_QUERY_INTERVAL = 1500;
|
||||||
|
|
||||||
|
|
||||||
|
function get_and_process_running_jobs()
|
||||||
|
{
|
||||||
|
$.get("{% url 'ajax_get_running_jobs' %}")
|
||||||
|
.done(function(data) {
|
||||||
|
|
||||||
|
let progress = $('#status-progress');
|
||||||
|
let jobPanel = $('#job_panel');
|
||||||
|
let jobTitle = jobPanel.find('#job_panel_title');
|
||||||
|
let jobTitleNoJobs = jobPanel.find('#job_panel_no_jobs_title');
|
||||||
|
let jobTemplate = jobPanel.find('#job_panel_item_template');
|
||||||
|
|
||||||
|
if (data.length > 0) {
|
||||||
|
|
||||||
|
// Update status bar
|
||||||
|
if (data.length > 1) {
|
||||||
|
$('#status-message').text(`Running ${data.length} jobs...`);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$('#status-message').text(`${data[0].description} | ${data[0].message}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update global progress bar
|
||||||
|
let combinedProgress = 0;
|
||||||
|
for (let entry of data) {
|
||||||
|
combinedProgress += entry.progress;
|
||||||
|
}
|
||||||
|
|
||||||
|
let percent = 100 * combinedProgress / data.length;
|
||||||
|
|
||||||
|
progress.removeClass('invisible');
|
||||||
|
let bar = progress.find('.progress-bar');
|
||||||
|
bar.width(percent + '%');
|
||||||
|
bar.text(`${percent.toFixed(0)}%`);
|
||||||
|
|
||||||
|
// Update entries in job list
|
||||||
|
jobTitle.removeClass('collapse');
|
||||||
|
jobTitleNoJobs.addClass('collapse');
|
||||||
|
|
||||||
|
data.sort(function (a, b) { return a.id - b.id });
|
||||||
|
jobPanel.find('.job_entry').remove();
|
||||||
|
|
||||||
|
for (let entry of data) {
|
||||||
|
let jobEntry = jobTemplate.clone();
|
||||||
|
jobEntry.attr('id', `job_${entry.id}`);
|
||||||
|
jobEntry.addClass('job_entry');
|
||||||
|
jobEntry.removeClass('collapse');
|
||||||
|
jobEntry.find('#job_panel_item_title').text(entry.description);
|
||||||
|
jobEntry.find('#job_panel_item_subtitle').text(entry.message);
|
||||||
|
|
||||||
|
let entryPercent = 100 * entry.progress;
|
||||||
|
let jobEntryProgress = jobEntry.find('#job_panel_item_progress');
|
||||||
|
jobEntryProgress.width(entryPercent + '%');
|
||||||
|
jobEntryProgress.text(`${entryPercent.toFixed(0)}%`);
|
||||||
|
|
||||||
|
jobEntry.appendTo(jobPanel);
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#btn_toggle_job_panel').dropdown('update');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
progress.addClass('invisible');
|
||||||
|
$('#status-message').text("");
|
||||||
|
|
||||||
|
jobTitle.addClass('collapse');
|
||||||
|
jobTitleNoJobs.removeClass('collapse');
|
||||||
|
jobPanel.find('.job_entry').remove();
|
||||||
|
|
||||||
|
$('#btn_toggle_job_panel').dropdown('update');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Initialization
|
/// Initialization
|
||||||
///
|
///
|
||||||
@ -205,4 +284,9 @@ $(document).ready(function ()
|
|||||||
{
|
{
|
||||||
$(".ajax-link").on("click", ajaxLink_Clicked);
|
$(".ajax-link").on("click", ajaxLink_Clicked);
|
||||||
$("#btn_sync_now").on("click", syncNow);
|
$("#btn_sync_now").on("click", syncNow);
|
||||||
|
$('[data-toggle="tooltip"]').tooltip()
|
||||||
|
|
||||||
|
// Notifications
|
||||||
|
get_and_process_running_jobs();
|
||||||
|
setInterval(get_and_process_running_jobs, JOB_QUERY_INTERVAL);
|
||||||
});
|
});
|
||||||
|
@ -175,84 +175,6 @@ function videos_Submit(e)
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
|
||||||
/// Notifications
|
|
||||||
///
|
|
||||||
const JOB_QUERY_INTERVAL = 1500;
|
|
||||||
|
|
||||||
|
|
||||||
function get_and_process_running_jobs()
|
|
||||||
{
|
|
||||||
$.get("{% url 'ajax_get_running_jobs' %}")
|
|
||||||
.done(function(data) {
|
|
||||||
|
|
||||||
let progress = $('#status-progress');
|
|
||||||
let jobPanel = $('#job_panel');
|
|
||||||
let jobTitle = jobPanel.find('#job_panel_title');
|
|
||||||
let jobTitleNoJobs = jobPanel.find('#job_panel_no_jobs_title');
|
|
||||||
let jobTemplate = jobPanel.find('#job_panel_item_template');
|
|
||||||
|
|
||||||
if (data.length > 0) {
|
|
||||||
|
|
||||||
// Update status bar
|
|
||||||
if (data.length > 1) {
|
|
||||||
$('#status-message').text(`Running ${data.length} jobs...`);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$('#status-message').text(`${data[0].description} | ${data[0].message}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update global progress bar
|
|
||||||
let combinedProgress = 0;
|
|
||||||
for (let entry of data) {
|
|
||||||
combinedProgress += entry.progress;
|
|
||||||
}
|
|
||||||
|
|
||||||
let percent = 100 * combinedProgress / data.length;
|
|
||||||
|
|
||||||
progress.removeClass('invisible');
|
|
||||||
let bar = progress.find('.progress-bar');
|
|
||||||
bar.width(percent + '%');
|
|
||||||
bar.text(`${percent.toFixed(0)}%`);
|
|
||||||
|
|
||||||
// Update entries in job list
|
|
||||||
jobTitle.removeClass('collapse');
|
|
||||||
jobTitleNoJobs.addClass('collapse');
|
|
||||||
|
|
||||||
data.sort(function (a, b) { return a.id - b.id });
|
|
||||||
jobPanel.find('.job_entry').remove();
|
|
||||||
|
|
||||||
for (let entry of data) {
|
|
||||||
let jobEntry = jobTemplate.clone();
|
|
||||||
jobEntry.attr('id', `job_${entry.id}`);
|
|
||||||
jobEntry.addClass('job_entry');
|
|
||||||
jobEntry.removeClass('collapse');
|
|
||||||
jobEntry.find('#job_panel_item_title').text(entry.description);
|
|
||||||
jobEntry.find('#job_panel_item_subtitle').text(entry.message);
|
|
||||||
|
|
||||||
let entryPercent = 100 * entry.progress;
|
|
||||||
let jobEntryProgress = jobEntry.find('#job_panel_item_progress');
|
|
||||||
jobEntryProgress.width(entryPercent + '%');
|
|
||||||
jobEntryProgress.text(`${entryPercent.toFixed(0)}%`);
|
|
||||||
|
|
||||||
jobEntry.appendTo(jobPanel);
|
|
||||||
}
|
|
||||||
|
|
||||||
$('#btn_toggle_job_panel').dropdown('update');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
progress.addClass('invisible');
|
|
||||||
$('#status-message').text("");
|
|
||||||
|
|
||||||
jobTitle.addClass('collapse');
|
|
||||||
jobTitleNoJobs.removeClass('collapse');
|
|
||||||
jobPanel.find('.job_entry').remove();
|
|
||||||
|
|
||||||
$('#btn_toggle_job_panel').dropdown('update');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Initialization
|
/// Initialization
|
||||||
///
|
///
|
||||||
@ -292,8 +214,4 @@ $(document).ready(function ()
|
|||||||
filters_form.find('select[name=results_per_page]').on('change', videos_ResetPageAndReloadWithTimer);
|
filters_form.find('select[name=results_per_page]').on('change', videos_ResetPageAndReloadWithTimer);
|
||||||
|
|
||||||
videos_Reload();
|
videos_Reload();
|
||||||
|
|
||||||
// Notifications
|
|
||||||
get_and_process_running_jobs();
|
|
||||||
setInterval(get_and_process_running_jobs, JOB_QUERY_INTERVAL);
|
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user