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

189 lines
5.1 KiB
JavaScript
Raw Normal View History

/*
* status.js
* Copyright (C) 2016 thegrumpydictator@gmail.com
*
* This software may be modified and distributed under the terms
* of the MIT license. See the LICENSE file for details.
*/
/* globals $, jobImportUrl, jobStartUrl, token, langImportMultiError, langImportSingleError, langImportFatalError, langImportTimeOutError */
var startedImport = false;
2016-08-13 23:28:01 +02:00
var startInterval = 2000;
var interval = 500;
var timeoutLimit = 5000;
var currentLimit = 0;
var stepCount = 0;
$(function () {
"use strict";
$('#import-status-intro').hide();
$('#import-status-more-info').hide();
// check status, every 500 ms.
2016-08-13 23:28:01 +02:00
setTimeout(checkImportStatus, startInterval);
});
function checkImportStatus() {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('checkImportStatus()');
$.getJSON(jobImportUrl).success(reportOnJobImport).fail(failedJobImport);
}
2016-08-13 23:28:01 +02:00
function importComplete(data) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('importComplete()');
2016-08-13 23:28:01 +02:00
var bar = $('#import-status-bar');
bar.removeClass('active');
}
2016-08-13 23:28:01 +02:00
function updateBar(data) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('updateBar()');
var bar = $('#import-status-bar');
if (data.showPercentage) {
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.stepsDone + '/' + data.steps);
if (data.percentage >= 100) {
2016-08-13 23:28:01 +02:00
importComplete(data);
return;
}
2016-08-13 23:28:01 +02:00
return;
}
// dont show percentage:
bar.removeClass('progress-bar-success').addClass('progress-bar-info');
bar.attr('aria-valuenow', 100);
bar.css('width', '100%');
}
function reportErrors(data) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('reportErrors()');
2016-08-13 23:28:01 +02:00
if (data.errors.length == 1) {
2016-08-14 08:34:59 +02:00
$('#import-status-error-intro').text(langImportSingleError);
//'An error has occured during the import. The import can continue, however.'
2016-08-13 23:28:01 +02:00
}
if (data.errors.length > 1) {
2016-08-14 08:34:59 +02:00
// 'Errors have occured during the import. The import can continue, however.'
$('#import-status-error-intro').text(langImportMultiError);
2016-08-13 23:28:01 +02:00
}
2016-08-14 08:34:59 +02:00
// fill the list with error texts
2016-08-13 23:28:01 +02:00
$('#import-status-error-list').empty();
for (var i = 0; i < data.errors.length; i++) {
var item = $('<li>').html(data.errors[i]);
2016-08-13 23:28:01 +02:00
$('#import-status-error-list').append(item);
}
2016-08-13 23:28:01 +02:00
}
2016-08-13 23:28:01 +02:00
function reportStatus(data) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('reportStatus()');
$('#import-status-txt').removeClass('text-danger').text(data.statusText);
2016-08-13 23:28:01 +02:00
}
function kickStartJob() {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('kickStartJob()');
2016-08-13 23:28:01 +02:00
$.post(jobStartUrl, {_token: token});
startedTheImport();
startedImport = true;
}
function updateTimeout(data) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('updateTimeout()');
if (data.stepsDone != stepCount) {
stepCount = data.stepsDone;
currentLimit = 0;
return;
}
currentLimit = currentLimit + interval;
2016-08-14 10:11:49 +02:00
// console.log("stepCount: " + stepCount + ", stepsDone: " + data.stepsDone + ", currentLimit: " + currentLimit);
}
function timeoutError() {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('timeoutError()');
// set status
$('#import-status-txt').addClass('text-danger').text(langImportTimeOutError);
// remove progress bar.
$('#import-status-holder').hide();
}
2016-08-14 10:11:49 +02:00
function importJobFinished(data) {
2016-08-13 23:28:01 +02:00
"use strict";
2016-08-14 10:11:49 +02:00
console.log('importJobFinished() = ' + data.finished);
return data.finished;
}
2016-08-13 23:28:01 +02:00
function finishedJob(data) {
2016-08-14 10:11:49 +02:00
"use strict";
console.log('finishedJob()');
// "There was an error during the import routine. Please check the log files. The error seems to be: '"
$('#import-status-txt').removeClass('text-danger').addClass('text-success').text(langImportFinished);
// remove progress bar.
$('#import-status-holder').hide();
// show info:
$('#import-status-intro').show();
$('#import-status-more-info').html(data.finishedText).show();
2016-08-14 10:11:49 +02:00
}
function reportOnJobImport(data) {
"use strict";
console.log('reportOnJobImport()');
2016-08-13 23:28:01 +02:00
updateBar(data);
reportErrors(data);
reportStatus(data);
updateTimeout(data);
2016-08-14 10:11:49 +02:00
if (importJobFinished(data)) {
finishedJob(data);
2016-08-14 10:11:49 +02:00
return;
}
// same number of steps as last time?
if (currentLimit > timeoutLimit) {
timeoutError();
return;
}
// if the job has not actually started, do so now:
if (!data.started && !startedImport) {
2016-08-13 23:28:01 +02:00
kickStartJob();
return;
}
2016-08-13 23:28:01 +02:00
// trigger another check.
setTimeout(checkImportStatus, interval);
}
function startedTheImport() {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('startedTheImport()');
2016-08-13 23:28:01 +02:00
setTimeout(checkImportStatus, interval);
}
function failedJobImport(jqxhr, textStatus, error) {
"use strict";
2016-08-14 10:11:49 +02:00
console.log('failedJobImport()');
// set status
2016-08-14 08:34:59 +02:00
// "There was an error during the import routine. Please check the log files. The error seems to be: '"
$('#import-status-txt').addClass('text-danger').text(langImportFatalError + ' ' + textStatus + ' ' + error);
// remove progress bar.
$('#import-status-holder').hide();
}