Files
firefly-iii/public/js/ff/import/status.js

251 lines
6.9 KiB
JavaScript
Raw Normal View History

/*
* status.js
2017-10-21 08:40:00 +02:00
* Copyright (c) 2017 thegrumpydictator@gmail.com
*
2017-10-21 08:40:00 +02:00
* This file is part of Firefly III.
*
2017-10-21 08:40:00 +02:00
* Firefly III is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Firefly III is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
2017-12-17 14:43:13 +01:00
* along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
*/
2017-12-16 19:47:14 +01:00
/** global: langImportSingleError, langImportMultiError, jobStartUrl, langImportTimeOutError, langImportFinished, langImportFatalError */
var timeOutId;
var startInterval = 1000;
var interval = 500;
2017-06-22 21:50:10 +02:00
// these vars are used to detect a stalled job:
var numberOfSteps = 0;
var numberOfReports = 0;
var jobFailed = false;
// counts how many errors have been detected
var knownErrors = 0;
2017-06-22 21:50:10 +02:00
$(function () {
"use strict";
2017-12-16 19:47:14 +01:00
timeOutId = setTimeout(checkJobStatus, startInterval);
$('.start-job').click(startJob);
2017-12-16 19:47:14 +01:00
if (job.configuration['auto-start']) {
startJob();
}
});
/**
* Downloads some JSON and responds to its content to see what the status is of the current import.
*/
2017-12-16 19:47:14 +01:00
function checkJobStatus() {
$.getJSON(jobStatusUri).done(reportOnJobStatus).fail(reportFailedJob);
}
/**
* This method is called when the JSON query returns an error. If possible, this error is relayed to the user.
*/
2017-12-16 19:47:14 +01:00
function reportFailedJob(jqxhr, textStatus, error) {
// hide all possible boxes:
$('.statusbox').hide();
2017-06-22 21:50:10 +02:00
// fill in some details:
var errorMessage = textStatus + " " + error;
2017-06-24 06:57:24 +02:00
$('.fatal_error_txt').text(errorMessage);
2017-06-24 06:57:24 +02:00
// show the fatal error box:
$('.fatal_error').show();
2017-06-22 21:50:10 +02:00
}
/**
* This method is called when the job enquiry (JSON) returns some info.
* It also decides whether or not to check again.
*
* @param data
*/
2017-12-16 19:47:14 +01:00
function reportOnJobStatus(data) {
switch (data.status) {
case "configured":
// job is ready. Do not check again, just show the start-box. Hide the rest.
2017-12-16 19:47:14 +01:00
if (!job.configuration['auto-start']) {
$('.statusbox').hide();
$('.status_configured').show();
}
break;
case "running":
// job is running! Show the running box:
$('.statusbox').hide();
$('.status_running').show();
// update the bar
updateBar(data);
// update the status text:
updateStatusText(data);
// report on detected errors:
reportOnErrors(data);
if (jobIsStalled(data)) {
// do something
showStalledBox();
} else {
// check again in 500ms
2017-12-16 19:47:14 +01:00
timeOutId = setTimeout(checkJobStatus, interval);
}
break;
case "finished":
$('.statusbox').hide();
$('.status_finished').show();
// show text:
2017-06-24 06:57:24 +02:00
$('#import-status-more-info').html(data.finishedText);
break;
2017-12-16 19:47:14 +01:00
case "errored":
// TODO this view is not yet used.
// hide all possible boxes:
$('.statusbox').hide();
// fill in some details:
var errorMessage = data.error_message;
$('.fatal_error_txt').text(errorMessage);
// show the fatal error box:
$('.fatal_error').show();
break;
2017-08-12 07:47:42 +02:00
default:
break;
2017-06-22 21:50:10 +02:00
}
}
2017-06-22 21:50:10 +02:00
/**
2017-06-24 06:57:24 +02:00
* Shows a fatal error when the job seems to be stalled.
*/
function showStalledBox() {
$('.statusbox').hide();
2017-06-24 06:57:24 +02:00
$('.fatal_error').show();
$('.fatal_error_txt').text(langImportTimeOutError);
}
/**
* Detects if a job is frozen.
*
* @param data
*/
function jobIsStalled(data) {
2017-06-24 08:37:09 +02:00
if (data.done === numberOfSteps) {
numberOfReports++;
2017-06-22 21:50:10 +02:00
}
if (data.done !== numberOfSteps) {
numberOfReports = 0;
2017-06-22 21:50:10 +02:00
}
if (numberOfReports > 20) {
return true;
2017-06-22 21:50:10 +02:00
}
numberOfSteps = data.done;
return false;
}
/**
* This function tells Firefly start the job. It will also initialize a re-check in 500ms time.
*/
function startJob() {
// disable the button, add loading thing.
$('.start-job').prop('disabled', true).text('...');
2017-12-16 19:47:14 +01:00
$.post(jobStartUri).fail(reportOnSubmitError);
// check status, every 500 ms.
2017-12-16 19:47:14 +01:00
timeOutId = setTimeout(checkJobStatus, startInterval);
}
2017-12-16 19:47:14 +01:00
/**
* When the start button fails (returns error code) this function reports. It assumes a time out.
*/
function reportOnSubmitError(jqxhr, textStatus, error) {
// stop the refresh thing
clearTimeout(timeOutId);
// hide all possible boxes:
$('.statusbox').hide();
// fill in some details:
2017-12-16 19:47:14 +01:00
var errorMessage = "Submitting the job returned an error: " + textStatus + ' ' + error;
2017-06-24 06:57:24 +02:00
$('.fatal_error_txt').text(errorMessage);
2017-06-24 06:57:24 +02:00
// show the fatal error box:
$('.fatal_error').show();
jobFailed = true;
2016-08-13 23:28:01 +02:00
}
/**
* This method updates the percentage bar thing if the job is running!
*/
2016-08-13 23:28:01 +02:00
function updateBar(data) {
var bar = $('#import-status-bar');
2017-06-24 06:57:24 +02:00
if (data.show_percentage) {
bar.addClass('progress-bar-success').removeClass('progress-bar-info');
bar.attr('aria-valuenow', data.percentage);
bar.css('width', data.percentage + '%');
$('#import-status-bar').text(data.done + '/' + data.steps);
return true;
2016-08-13 23:28:01 +02:00
}
// dont show percentage:
bar.removeClass('progress-bar-success').addClass('progress-bar-info');
bar.attr('aria-valuenow', 100);
bar.css('width', '100%');
2017-07-23 08:16:11 +02:00
return true;
2016-08-13 23:28:01 +02:00
}
/**
* Add text with current import status.
* @param data
*/
function updateStatusText(data) {
2016-08-13 23:28:01 +02:00
"use strict";
$('#import-status-txt').removeClass('text-danger').text(data.statusText);
2016-08-13 23:28:01 +02:00
}
/**
* Report on errors found in import:
* @param data
*/
function reportOnErrors(data) {
if (knownErrors === data.errors.length) {
return;
}
if (data.errors.length === 0) {
return;
}
if (data.errors.length === 1) {
$('#import-status-error-intro').text(langImportSingleError);
//'An error has occured during the import. The import can continue, however.'
}
if (data.errors.length > 1) {
// 'Errors have occured during the import. The import can continue, however.'
$('#import-status-error-intro').text(langImportMultiError);
}
$('.info_errors').show();
// fill the list with error texts
$('#import-status-error-list').empty();
for (var i = 0; i < data.errors.length; i++) {
var errorSet = data.errors[i];
for (var j = 0; j < errorSet.length; j++) {
var item = $('<li>').html(errorSet[j]);
$('#import-status-error-list').append(item);
}
}
2017-06-24 13:03:09 +02:00
}