From 2bd79fd95454f0c70311412e62d2861e927eed43 Mon Sep 17 00:00:00 2001 From: Albert Gasset Date: Wed, 23 Jan 2019 13:29:48 +0100 Subject: [PATCH] MOBILE-2429 feedback: Use responses of the last submission --- src/addon/mod/feedback/providers/feedback.ts | 31 ++++++++++---------- 1 file changed, 15 insertions(+), 16 deletions(-) diff --git a/src/addon/mod/feedback/providers/feedback.ts b/src/addon/mod/feedback/providers/feedback.ts index 3fcb0099e..6310b3deb 100644 --- a/src/addon/mod/feedback/providers/feedback.ts +++ b/src/addon/mod/feedback/providers/feedback.ts @@ -135,18 +135,6 @@ export class AddonModFeedbackProvider { */ protected fillValues(feedbackId: number, items: any[], offline: boolean, ignoreCache: boolean, siteId: string): Promise { return this.getCurrentValues(feedbackId, offline, ignoreCache, siteId).then((valuesArray) => { - if (valuesArray.length == 0) { - // Try sending empty values to get the last completed attempt values. - return this.processPageOnline(feedbackId, 0, {}, undefined, siteId).then(() => { - return this.getCurrentValues(feedbackId, offline, ignoreCache, siteId); - }).catch(() => { - // Ignore errors - }); - } - - return valuesArray; - - }).then((valuesArray) => { const values = {}; valuesArray.forEach((value) => { @@ -440,7 +428,7 @@ export class AddonModFeedbackProvider { } /** - * Returns the temporary completion record for the current user. + * Returns the temporary responses or responses of the last submission for the current user. * * @param {number} feedbackId Feedback ID. * @param {boolean} [offline=false] True if it should return cached data. Has priority over ignoreCache. @@ -465,11 +453,22 @@ export class AddonModFeedbackProvider { } return site.read('mod_feedback_get_unfinished_responses', params, preSets).then((response) => { - if (response && typeof response.responses != 'undefined') { - return response.responses; + if (!response || typeof response.responses == 'undefined') { + return Promise.reject(null); } - return Promise.reject(null); + if (response.responses.length == 0) { + // No unfinished responses, fetch responses of the last submission. + return site.read('mod_feedback_get_finished_responses', params, preSets).then((response) => { + if (!response || typeof response.responses == 'undefined') { + return Promise.reject(null); + } + + return response.responses; + }); + } + + return response.responses; }); }); }