From 8c92aa538e66e28d719ba45081c6625d01a71324 Mon Sep 17 00:00:00 2001 From: Kasper Brandt Date: Sun, 25 Oct 2015 17:04:22 +0300 Subject: [PATCH] [#1868] Additional results framework enhancements --- .../iati/exports/elements/other_identifier.py | 2 +- akvo/rsr/static/scripts-src/project-main.js | 104 ++++++++++++------ akvo/rsr/static/scripts-src/project-main.jsx | 104 ++++++++++++------ akvo/templates/project_main_tabs/results.html | 2 +- 4 files changed, 146 insertions(+), 66 deletions(-) diff --git a/akvo/iati/exports/elements/other_identifier.py b/akvo/iati/exports/elements/other_identifier.py index 1626aecab0..e1b62cd5fe 100644 --- a/akvo/iati/exports/elements/other_identifier.py +++ b/akvo/iati/exports/elements/other_identifier.py @@ -34,7 +34,7 @@ def other_identifier(project): if partnership.internal_id: element = etree.Element("other-identifier") element.attrib['ref'] = str(partnership.internal_id) - element.attrib['type'] = 'A1' if org == project.reporting_organisation else 'B9' + element.attrib['type'] = 'A1' if org == project.reporting_partner else 'B9' owner_org_element = etree.SubElement(element, "owner-org") diff --git a/akvo/rsr/static/scripts-src/project-main.js b/akvo/rsr/static/scripts-src/project-main.js index 41643800f0..23bbbdb7c5 100755 --- a/akvo/rsr/static/scripts-src/project-main.js +++ b/akvo/rsr/static/scripts-src/project-main.js @@ -426,6 +426,37 @@ if (firstAccordionChild !== null) { } } + function savingPeriod(periodNode, saving) { + var saveMessageContainer = periodNode.querySelector('.add-new-update-container'); + var saveMessageNode; + if (saving) { + saveMessageNode = document.createElement('div'); + saveMessageNode.classList.add('save-message'); + saveMessageNode.innerHTML = 'Saving...'; + saveMessageContainer.appendChild(saveMessageNode); + } else { + saveMessageNode = saveMessageContainer.querySelector('.save-message'); + if (saveMessageNode !== null) { + saveMessageNode.parentNode.removeChild(saveMessageNode); + } + } + } + + function savingPeriodError(periodNode, message) { + var saveMessageContainer = periodNode.querySelector('.add-new-update-container'); + var saveMessageNode = saveMessageContainer.querySelector('.save-message'); + if (saveMessageNode !== null) { + saveMessageNode = document.createElement('div'); + saveMessageNode.classList.add('save-message'); + saveMessageContainer.appendChild(saveMessageNode); + } + saveMessageNode.innerHTML = message; + + setInterval(function () { + saveMessageNode.parentNode.removeChild(saveMessageNode); + }, 10000); + } + function addSaveOnClicks() { var els = document.querySelectorAll('.save-button'); @@ -466,8 +497,7 @@ if (firstAccordionChild !== null) { photo = photoNode.files.length > 0 ? photoNode.files[0] : undefined; } periodId = parseInt(this.closest('tbody').getAttribute('period-id')); - updateId === 'add' ? addNewUpdate(description, periodId, value, photo) : editUpdate(updateId, periodId, description, value, photo); - this.closest('td').querySelector('.edit-button').click(); + updateId === 'add' ? addNewUpdate(description, periodId, value, photo) : editUpdate(updateId, periodId, description, value, updateContainer.getAttribute('current-change'), photo); }); } } @@ -494,24 +524,28 @@ if (firstAccordionChild !== null) { request.setRequestHeader("X-CSRFToken", csrftoken); request.setRequestHeader("Content-Type", "application/json;charset=UTF-8"); + // TODO: Create recalculation function so that closing isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); + request.onload = function() { if (request.status === 204) { // Object successfully deleted removeUpdatefromStore(periodId, parseInt(updateId)); updateActualValue(periodId, updateChange * -1); - // TODO: Create recalculation function so that closing isn't necessary - periodNode.querySelector('.expand-indicator-period').click(); - + savingPeriod(periodNode, false); return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Could not delete update.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; @@ -678,10 +712,9 @@ if (firstAccordionChild !== null) { } /* Upload photo */ - function uploadPhoto(photo, updateNode) { - var apiUrl, fileRequest, formData, updateId; + function uploadPhoto(photo, updateId, periodNode) { + var apiUrl, fileRequest, formData; - updateId = updateNode.getAttribute('update-id'); apiUrl = '/rest/v1/project_update/' + updateId + '/upload_photo/?format=json'; formData = new FormData(); @@ -694,15 +727,18 @@ if (firstAccordionChild !== null) { fileRequest.onload = function() { if (fileRequest.status >= 200 && fileRequest.status < 400) { addAdditionalUpdateData(updateId); + savingPeriod(periodNode, false); return false; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Uploading photo failed.'); return false; } }; fileRequest.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Uploading photo failed: connection error.'); return false; }; @@ -711,7 +747,14 @@ if (firstAccordionChild !== null) { /* Add new update */ function addNewUpdate(text, periodId, value, photo) { - var api_url, request, requestData; + var api_url, periodNode, request, requestData; + + removeUpdatefromStore(periodId, 'add'); + periodNode = findPeriod(periodId); + + // TODO: Create recalculation function per period so that closing it isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); // Create request api_url = '/rest/v1/project_update/?format=json'; @@ -727,31 +770,28 @@ if (firstAccordionChild !== null) { response = JSON.parse(request.response); updateId = response.id; - removeUpdatefromStore(periodId, 'add'); updateActualValue(periodId, value); - updateUpdateValues(periodId, 'add', updateId, value); - addAdditionalUpdateData(updateId); + // updateUpdateValues(periodId, 'add', updateId, value); // Upload photo if (photo !== undefined) { - updateNode = findUpdate(periodId, updateId); - uploadPhoto(photo, updateNode); + uploadPhoto(photo, updateId, periodNode); + } else { + savingPeriod(periodNode, false); } - // TODO: Create recalculation function so that closing isn't necessary - var periodNode = findPeriod(periodId); - periodNode.querySelector('.expand-indicator-period').click(); - return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Adding update failed.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; @@ -768,8 +808,14 @@ if (firstAccordionChild !== null) { } /* Edit existing update */ - function editUpdate(updateId, periodId, text, value, photo) { - var api_url, request; + function editUpdate(updateId, periodId, text, value, oldValue, photo) { + var api_url, periodNode, request; + + periodNode = findPeriod(periodId); + + // TODO: Create recalculation function per period so that closing it isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); // Create request api_url = '/rest/v1/project_update/' + updateId + '/?format=json'; @@ -781,34 +827,28 @@ if (firstAccordionChild !== null) { request.onload = function() { if (request.status >= 200 && request.status < 400) { // Object successfully saved - var oldValue, updateNode; - - updateNode = findUpdate(periodId, updateId); - oldValue = parseInt(updateNode.getAttribute('current-change')); - addAdditionalUpdateData(updateId); updateActualValue(periodId, value - oldValue); - updateUpdateValues(periodId, updateId, updateId, value); + // updateUpdateValues(periodId, updateId, updateId, value); // Upload photo if (photo !== undefined) { - uploadPhoto(photo, updateNode); + uploadPhoto(photo, updateId, periodNode); + } else { + savingPeriod(periodNode, false); } - // Close the updates view, because it could be one of the first updates and all values need to be recalculated - // TODO: Create recalculation function so that closing isn't necessary - var periodNode = findPeriod(periodId); - periodNode.querySelector('.expand-indicator-period').click(); - return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Editing update failed.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; diff --git a/akvo/rsr/static/scripts-src/project-main.jsx b/akvo/rsr/static/scripts-src/project-main.jsx index 889d4317eb..bbf67fe9a0 100755 --- a/akvo/rsr/static/scripts-src/project-main.jsx +++ b/akvo/rsr/static/scripts-src/project-main.jsx @@ -426,6 +426,37 @@ if (firstAccordionChild !== null) { } } + function savingPeriod(periodNode, saving) { + var saveMessageContainer = periodNode.querySelector('.add-new-update-container'); + var saveMessageNode; + if (saving) { + saveMessageNode = document.createElement('div'); + saveMessageNode.classList.add('save-message'); + saveMessageNode.innerHTML = 'Saving...'; + saveMessageContainer.appendChild(saveMessageNode); + } else { + saveMessageNode = saveMessageContainer.querySelector('.save-message'); + if (saveMessageNode !== null) { + saveMessageNode.parentNode.removeChild(saveMessageNode); + } + } + } + + function savingPeriodError(periodNode, message) { + var saveMessageContainer = periodNode.querySelector('.add-new-update-container'); + var saveMessageNode = saveMessageContainer.querySelector('.save-message'); + if (saveMessageNode !== null) { + saveMessageNode = document.createElement('div'); + saveMessageNode.classList.add('save-message'); + saveMessageContainer.appendChild(saveMessageNode); + } + saveMessageNode.innerHTML = message; + + setInterval(function () { + saveMessageNode.parentNode.removeChild(saveMessageNode); + }, 10000); + } + function addSaveOnClicks() { var els = document.querySelectorAll('.save-button'); @@ -466,8 +497,7 @@ if (firstAccordionChild !== null) { photo = photoNode.files.length > 0 ? photoNode.files[0] : undefined; } periodId = parseInt(this.closest('tbody').getAttribute('period-id')); - updateId === 'add' ? addNewUpdate(description, periodId, value, photo) : editUpdate(updateId, periodId, description, value, photo); - this.closest('td').querySelector('.edit-button').click(); + updateId === 'add' ? addNewUpdate(description, periodId, value, photo) : editUpdate(updateId, periodId, description, value, updateContainer.getAttribute('current-change'), photo); }); } } @@ -494,24 +524,28 @@ if (firstAccordionChild !== null) { request.setRequestHeader("X-CSRFToken", csrftoken); request.setRequestHeader("Content-Type", "application/json;charset=UTF-8"); + // TODO: Create recalculation function so that closing isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); + request.onload = function() { if (request.status === 204) { // Object successfully deleted removeUpdatefromStore(periodId, parseInt(updateId)); updateActualValue(periodId, updateChange * -1); - // TODO: Create recalculation function so that closing isn't necessary - periodNode.querySelector('.expand-indicator-period').click(); - + savingPeriod(periodNode, false); return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Could not delete update.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; @@ -678,10 +712,9 @@ if (firstAccordionChild !== null) { } /* Upload photo */ - function uploadPhoto(photo, updateNode) { - var apiUrl, fileRequest, formData, updateId; + function uploadPhoto(photo, updateId, periodNode) { + var apiUrl, fileRequest, formData; - updateId = updateNode.getAttribute('update-id'); apiUrl = '/rest/v1/project_update/' + updateId + '/upload_photo/?format=json'; formData = new FormData(); @@ -694,15 +727,18 @@ if (firstAccordionChild !== null) { fileRequest.onload = function() { if (fileRequest.status >= 200 && fileRequest.status < 400) { addAdditionalUpdateData(updateId); + savingPeriod(periodNode, false); return false; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Uploading photo failed.'); return false; } }; fileRequest.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Uploading photo failed: connection error.'); return false; }; @@ -711,7 +747,14 @@ if (firstAccordionChild !== null) { /* Add new update */ function addNewUpdate(text, periodId, value, photo) { - var api_url, request, requestData; + var api_url, periodNode, request, requestData; + + removeUpdatefromStore(periodId, 'add'); + periodNode = findPeriod(periodId); + + // TODO: Create recalculation function per period so that closing it isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); // Create request api_url = '/rest/v1/project_update/?format=json'; @@ -727,31 +770,28 @@ if (firstAccordionChild !== null) { response = JSON.parse(request.response); updateId = response.id; - removeUpdatefromStore(periodId, 'add'); updateActualValue(periodId, value); - updateUpdateValues(periodId, 'add', updateId, value); - addAdditionalUpdateData(updateId); + // updateUpdateValues(periodId, 'add', updateId, value); // Upload photo if (photo !== undefined) { - updateNode = findUpdate(periodId, updateId); - uploadPhoto(photo, updateNode); + uploadPhoto(photo, updateId, periodNode); + } else { + savingPeriod(periodNode, false); } - // TODO: Create recalculation function so that closing isn't necessary - var periodNode = findPeriod(periodId); - periodNode.querySelector('.expand-indicator-period').click(); - return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Adding update failed.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; @@ -768,8 +808,14 @@ if (firstAccordionChild !== null) { } /* Edit existing update */ - function editUpdate(updateId, periodId, text, value, photo) { - var api_url, request; + function editUpdate(updateId, periodId, text, value, oldValue, photo) { + var api_url, periodNode, request; + + periodNode = findPeriod(periodId); + + // TODO: Create recalculation function per period so that closing it isn't necessary + savingPeriod(periodNode, true); + periodNode.querySelector('.expand-indicator-period').click(); // Create request api_url = '/rest/v1/project_update/' + updateId + '/?format=json'; @@ -781,34 +827,28 @@ if (firstAccordionChild !== null) { request.onload = function() { if (request.status >= 200 && request.status < 400) { // Object successfully saved - var oldValue, updateNode; - - updateNode = findUpdate(periodId, updateId); - oldValue = parseInt(updateNode.getAttribute('current-change')); - addAdditionalUpdateData(updateId); updateActualValue(periodId, value - oldValue); - updateUpdateValues(periodId, updateId, updateId, value); + // updateUpdateValues(periodId, updateId, updateId, value); // Upload photo if (photo !== undefined) { - uploadPhoto(photo, updateNode); + uploadPhoto(photo, updateId, periodNode); + } else { + savingPeriod(periodNode, false); } - // Close the updates view, because it could be one of the first updates and all values need to be recalculated - // TODO: Create recalculation function so that closing isn't necessary - var periodNode = findPeriod(periodId); - periodNode.querySelector('.expand-indicator-period').click(); - return true; } else { // We reached our target server, but it returned an error + savingPeriodError(periodNode, 'Editing update failed.'); return false; } }; request.onerror = function() { // There was a connection error of some sort + savingPeriodError(periodNode, 'Connection error.'); return false; }; diff --git a/akvo/templates/project_main_tabs/results.html b/akvo/templates/project_main_tabs/results.html index 9ca1947dcf..d089a828b9 100644 --- a/akvo/templates/project_main_tabs/results.html +++ b/akvo/templates/project_main_tabs/results.html @@ -19,7 +19,7 @@

{% for indicator in result.indicators.all %}