mirror of
https://github.com/jellyfin/jellyfin-web.git
synced 2024-11-18 03:18:19 -07:00
150 lines
3.9 KiB
JavaScript
150 lines
3.9 KiB
JavaScript
|
|
$.fn.taskButton = function (options) {
|
|
|
|
function pollTasks(button) {
|
|
|
|
ApiClient.getScheduledTasks({
|
|
|
|
IsEnabled: true
|
|
|
|
}).done(function (tasks) {
|
|
|
|
updateTasks(button, tasks);
|
|
});
|
|
|
|
}
|
|
|
|
function updateTasks(button, tasks) {
|
|
|
|
var task = tasks.filter(function (t) {
|
|
|
|
return t.Key == options.taskKey;
|
|
|
|
})[0];
|
|
|
|
if (options.panel) {
|
|
if (task) {
|
|
$(options.panel).show();
|
|
} else {
|
|
$(options.panel).hide();
|
|
}
|
|
}
|
|
|
|
if (!task) {
|
|
return;
|
|
}
|
|
|
|
button.buttonEnabled(task.State == 'Idle').attr('data-taskid', task.Id);
|
|
|
|
var progress = (task.CurrentProgressPercentage || 0).toFixed(1);
|
|
|
|
if (options.progressElem) {
|
|
var progressElem = options.progressElem.val(progress);
|
|
|
|
if (task.State == 'Running') {
|
|
progressElem.show();
|
|
} else {
|
|
progressElem.hide();
|
|
}
|
|
}
|
|
|
|
if (options.lastResultElem) {
|
|
var lastResult = task.LastExecutionResult ? task.LastExecutionResult.Status : '';
|
|
|
|
if (lastResult == "Failed") {
|
|
options.lastResultElem.html('<span style="color:#FF0000;">' + Globalize.translate('LabelFailed') + '</span>');
|
|
}
|
|
else if (lastResult == "Cancelled") {
|
|
options.lastResultElem.html('<span style="color:#0026FF;">' + Globalize.translate('LabelCancelled') + '</span>');
|
|
}
|
|
else if (lastResult == "Aborted") {
|
|
options.lastResultElem.html('<span style="color:#FF0000;">' + Globalize.translate('LabelAbortedByServerShutdown') + '</span>');
|
|
} else {
|
|
options.lastResultElem.html(lastResult);
|
|
}
|
|
}
|
|
}
|
|
|
|
function onScheduledTaskMessageConfirmed(instance, id) {
|
|
ApiClient.startScheduledTask(id).done(function () {
|
|
|
|
pollTasks(instance);
|
|
});
|
|
}
|
|
|
|
function onButtonClick(instance, id) {
|
|
|
|
var key = 'scheduledTaskButton' + options.taskKey;
|
|
var expectedValue = '4';
|
|
|
|
if (store.getItem(key) == expectedValue) {
|
|
onScheduledTaskMessageConfirmed(instance, id);
|
|
} else {
|
|
|
|
var msg = Globalize.translate('ConfirmMessageScheduledTaskButton');
|
|
msg += '<br/>';
|
|
msg += '<br/>';
|
|
msg += '<a href="scheduledtasks.html">' + Globalize.translate('ButtonScheduledTasks') + '</a>';
|
|
|
|
Dashboard.confirm(msg, Globalize.translate('HeaderConfirmation'), function (result) {
|
|
|
|
if (result) {
|
|
|
|
store.setItem(key, expectedValue);
|
|
onScheduledTaskMessageConfirmed(instance, id);
|
|
}
|
|
});
|
|
|
|
}
|
|
}
|
|
|
|
var self = this;
|
|
|
|
if (options.panel) {
|
|
$(options.panel).hide();
|
|
}
|
|
|
|
if (options.mode == 'off') {
|
|
|
|
this.off(".taskbutton");
|
|
$(ApiClient).off(".taskbutton");
|
|
|
|
if (ApiClient.isWebSocketOpen()) {
|
|
ApiClient.sendWebSocketMessage("ScheduledTasksInfoStop");
|
|
}
|
|
|
|
} else if (this.length) {
|
|
|
|
this.on('click.taskbutton', function () {
|
|
|
|
var button = this;
|
|
var id = button.getAttribute('data-taskid');
|
|
|
|
onButtonClick(self, id);
|
|
});
|
|
|
|
pollTasks(self);
|
|
|
|
if (ApiClient.isWebSocketOpen()) {
|
|
ApiClient.sendWebSocketMessage("ScheduledTasksInfoStart", "1000,1000");
|
|
}
|
|
|
|
$(ApiClient).on("websocketmessage.taskbutton", function (e, msg) {
|
|
|
|
if (msg.MessageType == "ScheduledTasksInfo") {
|
|
|
|
var tasks = msg.Data;
|
|
|
|
updateTasks(self, tasks);
|
|
}
|
|
|
|
}).on('websocketopen.taskbutton', function () {
|
|
|
|
if (ApiClient.isWebSocketOpen()) {
|
|
ApiClient.sendWebSocketMessage("ScheduledTasksInfoStart", "1000,1000");
|
|
}
|
|
});
|
|
}
|
|
|
|
return this;
|
|
}; |